千家信息网

如何进行MySQL管理基础中的维护、备份和恢复

发表于:2024-09-22 作者:千家信息网编辑
千家信息网最后更新 2024年09月22日,如何进行MySQL管理基础中的维护、备份和恢复,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.日志记录MySQL的日志
千家信息网最后更新 2024年09月22日如何进行MySQL管理基础中的维护、备份和恢复

如何进行MySQL管理基础中的维护、备份和恢复,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

1.日志记录

MySQL的日志文件可用于分析性能和排查问题,保存在与数据文件相同的目录下。有以下几种不同类型日志文件:

日志文件类型 默认文件名 mysqld选项 作用

错误日志 <主机名>.err log-error 记录服务器上发生的每个错误。
一般查询日志 <主机名>.log log 记录客户机发给服务器的每个查询的踪迹。
慢查询日志 <主机名>-slow.log log-slow-queries 记录执行时间超过long_query_time值的所有查询。
二进制日志 <主机名>-bin-###### log-bin 记录更新了或已经潜在更新了数据的所有语句。

注:log-bin选项中的"######"是二进制日志文件的编号,每次生成新日志文件会自动增加。如果指定日志文件名,MySQL会只取第一个"."前面的部分,并自动添加6位数字编号,从000001开始。

可以使用FLUSH LOGS命令刷新日志,错误日志的内容写入相同路径下的*.err-old文件,然后*.err文件被清空;一般查询日志和慢查询日志中会生成一条包含mysqld信息和列标题的记录,将新旧记录分割开;当前的二进制日志会被关闭,使用新的顺序编号创建新日志。

[@more@]2.检查和修理表

检查表可以使用myisamchk工具或CHECK TABLE命令,前者只能用于MYISAM表,后者适用于所有表。myisamchk可以分别使用-F、-m、-e、-C、-w选项执行快速检查、中速检查、扩展检查(最慢)、变更检查、等待检查,CHECK TABLE命令可以添加FAST、MEDIUM、EXTENDED等关键字来指定检查的种类。
检查表时如果发现错误,就应该对其进行修理。最好先复制存在问题的表,以便尝试不同的修理方法。myisamchk工具使用-r选项,可以修理损坏的表,与检查表时相同,被修理的表不能被锁定。另外,还可以使用-o、-q选项执行不同类型的修理操作。还可以使用REPAIR TABLE命令对表进行修复,类似地,可以添加QUICK或EXTENDED关键字设置修理操作的类型。
myiasmchk工具要求表不能被锁定,所以最好在服务器关闭的情况下使用,而CHECK TABLE和REPAIR TABLE命令则必须在服务器运行时使用。
此外,使用OPTIMIZE TABLE命令可以对表进行优化,整理数据文件碎片,对索引页进行排序,更新表的统计信息。需要注意的是,优化操作会锁定表,过程中客户机无法访问。


3.备份和恢复

使用mysqldump工具可以对表或数据库进行备份。执行备份操作的用户应在进行转储的表或数据库上具有select和lock tables权限。

mysql> show grants for ggyy@localhost;
+-------------------------------------------------------------------------------------------------------------+
| Grants for ggyy@localhost |
+-------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'ggyy'@'localhost' IDENTIFIED BY PASSWORD '*484FFAA42C12F40931C794D33A11B7F075B91467' |
| GRANT SELECT, LOCK TABLES ON `ggyy`.* TO 'ggyy'@'localhost' |
+-------------------------------------------------------------------------------------------------------------+
2 rows in set (0.00 sec)


下面是一些转储表的例子:

<1>转储ggyy数据库中的blob_text_test表,将结果重定向到一个指定的文件。

mysqldump ggyy blob_text_test -u ggyy -p > E:ackupMySQLlob_text_test.sql

<2>转储ggyy数据库中的char_test表,使结果直接输出到一个指定的文件。( -r 选项用于在MSDOS环境中使输出文件行尾只有换行符,而不是换行符+回车符。)

mysqldump ggyy char_test -u ggyy -p -r E:ackupMySQLchar_test.sql

<3>转储ggyy数据库中的多个表,将结果重定向到一个指定的文件。

mysqldump ggyy date_time_test float_test int_test members members_temp test_crttb test_crttb2 test_crttb3 test_crttb4 test_crttb5 ts_dt_test -u ggyy -p > E:ackupMySQLggyy-tables.sql

<4>转储test数据库中的namelist和oraleng表,只产生少量的输出,将结果重定向到一个指定的文件。( --compact 选项使转储结果中不包含DROP TABLE、ALTER TABLE ... DISABLE KEYS、LOCK TABLES等语句和"--"开头的注释。)

mysqldump test namelist oraleng --compact -u root -p > E:ackupMySQL amelist+oraleng.sql

<5>只转储test数据库中test表的定义,将结果重定向到一个指定的文件。

mysqldump test test -d -u root -p > E:ackupMySQL est_def.sql

<6>只转储test数据库中test表的数据,将结果重定向到一个指定的文件。

mysqldump test test -t -u root -p > E:ackupMySQL est_data.sql

当然还可以对整个数据库进行转储,语法是 mysqldump

。如果同时转储多个数据库可以使用 -B 选项,例如转储ggyy和test数据库:

mysqldump -B ggyy test -u root -p -r E:ackupMySQLmysqlback_20100319.sql

mysqldump工具生成的包含SQL语句的文件,可以使用mysql命令行工具运行,从而达到恢复数据的目的。执行恢复操作的用户应该在进行导入的数据库上具有drop、create、alter、insert等权限。

mysql> show grants for ggyy@localhost;
+-------------------------------------------------------------------------------------------------------------+
| Grants for ggyy@localhost |
+-------------------------------------------------------------------------------------------------------------+
| GRANT USAGE ON *.* TO 'ggyy'@'localhost' IDENTIFIED BY PASSWORD '*484FFAA42C12F40931C794D33A11B7F075B91467' |
| GRANT SELECT, INSERT, CREATE, DROP, ALTER, LOCK TABLES ON `ggyy`.* TO 'ggyy'@'localhost' |
+-------------------------------------------------------------------------------------------------------------+
2 rows in set (0.00 sec)


下面的命令可以将之前转储的ggyy数据库中的表导入到ggyy数据库中:

mysql ggyy -u ggyy -p < E:ackupMySQLlob_text_test.sql

mysql ggyy -u ggyy -p < E:ackupMySQLchar_test.sql

mysql ggyy -u ggyy -p < E:ackupMySQLggyy-tables.sql

另外,在mysql提示符下使用SOURCE命令同样可以进行恢复。下面的语句可以将之前转储的test数据库中的表导入到test数据库中:

source E:ackupMySQL amelist+oraleng.sql

source E:ackupMySQL est_def.sql

source E:ackupMySQL est_data.sql

undefinedundefinedundefinedundefinedundefinedundefined

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。

数据 文件 日志 数据库 检查 命令 结果 修理 工具 查询 备份 服务器 类型 语句 错误 服务 不同 相同 二进制 更新 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 南昌航空大学网络技术专业怎么样 网络安全分析五官扁平 win服务器最好用的系统 电子商务网络技术基础综合实训 怎么理解数据库表中的值为空 服务器域名不能访问 软件开发纯技术 中山汇源通网络技术有限公司 浙江吉利控股校招有软件开发吗 2008数据库数据配置库 炸我的世界服务器的人现在咋样了 阿里巴巴泉州网络技术有限公司 赴日软件开发学4个月 网络安全专职人员勤奋工作 上海智能网络技术诚信服务 网络技术研究院专业 游戏服务器安全设置 点查询数据库 设计企业软件开发 湖州品牌网络技术优势 自学软件开发 知乎 数据库正在使用无法获得独占 软件开发 在线教学 抚宁软件开发公司 一般情况下网络安全员月薪多少 服务器防爆破 章丘移动城管软件开发公司 天然气表信息管理数据库连接失败 一个小企业需要几个服务器 数据库中全角符号占几位
0