mysqldump -u 用户名 -p 数据库名> 备份的文件名
本文中因服务器为多实例,所以在执行登陆等命令时指定了-S参数,即指定其中一个数据库
备份:
mysqldump -u root -p‘root‘ oldboy>/opt/oldboy.sql[root@MySQL opt]# mysql -S /data/3307/mysql.sock -uroot -p -e "show variables like ‘%character%‘"
Enter password:+--------------------------+--------------------------------------------------------------+
| Variable_name | Value |
+--------------------------+--------------------------------------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8mb4 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8mb4 |
| character_set_system | utf8 |
| character_sets_dir | /usr/local/mysql-5.7.9-linux-glibc2.5-x86_64/share/charsets/ |
+--------------------------+--------------------------------------------------------------+
指定字符集备份:
[root@MySQL opt]# mysqldump -u root -p‘root‘ --default-character-set=utf8 oldboy>/opt/oldboy.sql
备份参数:
-e : 后面可以执行mysql 命令用;分开-B :参数的作用是增加创建数据库和连接数据库的命令,即create database,use database
-d : 备份表结构-t : 备份数据-A :alldatabases-F : 刷新binlog日志文件,切割binlog-x,--lock-all-tables 锁表
-l,--lock-tables 只读锁表--master-data=1(=2) : 增加binlog日志文件名及对应的位置点--compact :去掉注释,适用于debug,生产不用--single-transaction : 适合innodb事务数据库备份
InnoDB表在备份时,通常启用选项 --single-transaction来保证备份的一致性,实际上它的工作原理是设