Mysql主从搭建及Mysql运维相关命令

jopen 11年前

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为主库的FileMASTER_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

来自:http://blog.csdn.net/liuzhoulong/article/details/9154853