mysql主从搭建及mysql运维相关命令
1,安装mysql,方式很多,rpm方式安装
yum -y install mysql-server mysql-devel mysql mysql-bench mysql-test
2 ,启动
/etc/init.d/mysqld start
3,master
编辑/etc/my.cnf
# 确保有如下行
server-id = 1
log-bin=mysql-bin
binlog-do-db=mysql #需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
binlog-ignore-db=mysql #不需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
slave-skip-errors #是跳过错误,继续执行复制操作
linux: useradd repl_user
passwd repl_user
mysql> grant replication slave on *.* 'repl_user'@'slave_ip' identified by 'repl_password';
备份
flush tables with read lock;
reset master
不要退出终端,再开启一个终端
linux :cd /var/lib #mysql数据目录
tar zcvf mysql.tar.gz mysql
scp mysql.tar.gz root@slave_ip :/var/lib
mysl>unlock tables;
show master status;
4,salve
tar zxvf mysql.tar.gz
chown -r mysql:mysql mysql
编辑 /etc/my.cnf
server-id=2
log-bin=mysql-bin
master-host=192.168.0.1
master-user=slave
master-password=111111
master-port=3306
replicate-do-db=test #需要备份的数据库名
replicate-ignore-db=mysql #忽略的数据库
master-connect-retry=60 #如果从服务器发现主服务器断掉,重新连接的时间差(秒)
log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
slave-skip-errors #是跳过错误,继续执行复制操作
验证连接master
# mysql -h192.168.0.1 -uslave -ppassword
mysql> show grants for slave@192.168.0.2;
在slave上设置同步
设置连接master master_log_file为主库的file,master_log_pos为主库的position
mysql> slave stop;
mysql> change master to master_host='192.168.0.1',master_user='slave',master_password='111111',master_log_file='mysql-bin.000001',master_log_pos=106;
启动slave服务
mysql> slave stop;
mysql> slave start;
查看slave状态
mysql> show slave status/g;
其中 slave_io_running 和 slave_sql_running 两列的值都为 yes,表明 slave 的 i/o 和 sql 线程都在正常运行。
mysql运维常用命令:
show processlist
show full processlist
show open tables;
show status;
show variables
show engine innodb status;/g;
linux 命令行连接数据库执行命令
printf select system_user() from dual|mysql -h192.1.1.161 -uroot -proot -p3306 test -n
bitscn.com
