时间:2021-07-01 10:21:17 帮助过:21人阅读
首先确保主从服务器上的Mysql版本相同
(master)ip:192.168.1.107
(slave) ip:192.168.1.109
2. 安装、配置MySQL
cd /usr/local/src/ wget http://syslab.comsenz.com/downloads/linux/mysql-5.1.40-linux-i686-icc-glibc23.tar.gz 注意:上面的地址是32位机器用的,如果你的机器是64位,下载这个包(http://syslab.comsenz.com/downloads/linux/mysql-5.1.40-linux-x86_64-icc-glibc23.tar.gz)安装方法是一样的。 tar zxvf /usr/local/src/mysql-5.1.40-linux-i686-icc-glibc23.tar.gz mv mysql-5.1.40-linux-i686-icc-glibc23 /usr/local/mysql useradd -s /sbin/nologin mysql cd /usr/local/mysql mkdir -p /data/mysql chown -R mysql:mysql /data/mysql ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql cp support-files/my-large.cnf /etc/my.cnf cp support-files/mysql.server /etc/init.d/mysqld chmod 755 /etc/init.d/mysqld
vim /etc/init.d/mysqld
需要修改的地方有
basedir=/usr/local/mysql
datadir=/data/mysql
在master(192.168.1.107)创建测试库: create database db1;
然后导出主的mysql库数据然后导入给db1
mysqldump -uroot -S /tmp/mysql.sock mysql > 123.sql ;
mysql -uroot -S /tmp/mysql.sock db1 < 123.sql
4. 配置主(master)
vim /etc/my.cnf #修改或添加:
server-id=1
log-bin=mysql-bin
两个可选参数(2选1):
binlog-do-db=db1,db2 #需要同步的库
binlog-ignore-db=db1,db2 #忽略不同步的库
修改配置文件后,重启mysql
你可以把mysql加入到PAHT中
vim /etc/profile.d/path.sh
#!/bin/bash PATH=$PATH:/usr/local/mysql/bin/
增加完后 source !$
新安装的mysql是没有密码的
启动mysql:mysql
设置一个从数据库的账户,使用REPLICATION SLAVE赋予权限,如:
GRANT ALL PRIVILEGES ON *.* TO ‘real‘@‘192.168.1.109‘ IDENTIFIED BY ‘123.com‘ WITH GRANT OPTION;
flush privileges;
show databases;
你可以看到db1 这个库;
之后可以得到主服务器当前二进制日志名和偏移量,这个操作的目的是为了在从数据库启动后,从这个点开始进行数据的恢复 mysql> show master status\G; *************************** 1. row *************************** File: mysql-bin.000004 Position: 369 Binlog_Do_DB: Binlog_Ignore_DB: 1 row in set (0.00 sec) 记住File Position 后面的参数; 注意在导出数据之前先对主数据库进行READ LOCK,以保证数据的一致性 mysql> flush tables with read lock; Query OK, 0 rows affected (0.19 sec)
5. 设置从(slave)
vim /etc/my.cnf #修改或增加
server-id = 2 #这个数值不能和主一样
可选参数:replicate-do-db=db1,db2 和 replicate-ignore-db=db1,db2 #意义同主的那两个可选参数
拷贝主的db1库数据到从:
mysqldump -h192.168.1.107 -P3306 -uroot -p123.com db1> db1.sql;mysql -p -e "create database db1"; mysql -uroot -p db1 < db1.sql
启动 mysql:service mysqld start
如果 启动时你遇到了这样的错误:
Starting MySQL…… ERROR! Manager of pid-file quit without updating file
那么 你需要做这样的操作
vi /etc/my.cnf
log-bin=mysql-bin
binlog_format=mixed
注释掉这两行,然后重启
登陆从的mysql
slave stop;
change master to master_host=‘192.168.1.107‘, master_port=3306, master_user=‘real‘, master_password=‘123123‘, master_log_file=‘mysql-bin.000004‘, master_log_pos=369;
slave start;
主上: mysql -uroot -S /tmp/mysql2.sock -p123456 -e "unlock tables"
从上查看从的状态: show slave status\G;
Slave_IO_Running: Yes Slave_SQL_Running: Yes
查看这两个是否为yes
6. 测试主从
主上清空db1库的db表 :use db1; select count(*) from db"; truncate table db;
进入slave,查看db1库db表: use db1; select count(*) from db";
主上删除表db: drop table db;
从上看db表不存在了
建议: MySQL主从机制比较脆弱,谨慎操作。如果重启master,务必要先把slave停掉,也就是说需要在slave上去执行 slave stop 命令,然后再去重启master的mysql服务,否则很有可能就会中断了。当然重启完后,还需要把slave给开启 slave start.
mysql 主从配置
标签:mysql主从配置