MySQL主从复制是一个异步的复制过程,主库发送更新事件到从库,从库读取更新记录,并执行更新记录,使得从库的内容与主库保持一致。mysql
在[mysqld]段下添加:sql
#启用二进制日志数据库 log-bin=mysql-bin安全 #服务器惟一ID,通常取IP最后一段bash server-id=133服务器 |
service mysqld restart并发
mysql>GRANT FILE ON *.* TO 'backup'@'%' IDENTIFIED BY '123456';运维
mysql>GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* to 'backup'@'%' identified by '123456';异步
#通常不用root账号,“%”表示全部客户端均可能连,只要账号,密码正确,此处可用具体客户端IP代替,如192.168.145.226,增强安全。ide
刷新权限
mysql> FLUSH PRIVILEGES;
查看mysql如今有哪些用户
mysql>select user,host from mysql.user;
mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 | 120 | db1 | mysql | |
+------------------+----------+--------------+------------------+-------------------+
1 row in set
[mysqld]
server-id=134
错误处理: 若是出现此错误: Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work. 由于是mysql是克隆的系统因此mysql的uuid是同样的,因此须要修改。 |
解决方法: 删除/var/lib/mysql/auto.cnf文件,从新启动服务。 |
mysql>change master to master_host='192.168.25.134',master_port=3306,master_user='backup',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=120
注意语句中间不要断开,master_port为mysql服务器端口号(无引号),master_user为执行同步操做的数据库帐户,“120”无单引号(此处的120就是show master status 中看到的position的值,这里的mysql-bin.000001就是file对应的值)。
mysql>start slave;
mysql> show slave status
……………………(省略部分)
Slave_IO_Running: Yes //此状态必须YES
Slave_SQL_Running: Yes //此状态必须YES
……………………(省略部分)
注:Slave_IO及Slave_SQL进程必须正常运行,即YES状态,不然都是错误的状态(如:其中一个NO均属错误)。
Mysql做为目前世界上使用最普遍的免费数据库,相信全部从事系统运维的工程师都必定接触过。但在实际的生产环境中,由单台Mysql做为独立的数据库是彻底不能知足实际需求的,不管是在安全性,高可用性以及高并发等各个方面。
所以,通常来讲都是经过 主从复制(Master-Slave)的方式来同步数据,再经过读写分离(MySQL-Proxy)来提高数据库的并发负载能力 这样的方案来进行部署与实施的。
首先咱们在前面当中已经运行了mysql-proxy咱们须要先杀死这个进程:sudo killall mysql-proxy
#!bash/bin
/opt/mysql-proxy/bin/mysql-proxy \
--proxy-address=1.0.0.3:4040 \
--proxy-backend-addresses=17.16.15.112:3125 \ #在3125端口的服务器中配置可读可写
--proxy-read-only-backend-addresses=172.16.15.112:3126 \ #在3126端口的服务器中配置只读
--proxy-lua-script=/opt/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua \ #用这个lua脚原本实现读写分离
--log-level=info \
--log-file=/opt/mysql-proxy/logs/mysql-proxy-12.log \ #这是它的日志
--daemon
3)咱们查看一下日志,看是否脚本运行成功
sudo vi /opt/mysql-proxy/logs/mysql-proxy-12.log
2017-09-20 03:03:58: (critical) plugin proxy 0.8.5 started
2017-09-20 03:03:58: (message) proxy listening on port 1.0.0.3:4040
2017-09-20 03:03:58: (message) added read/write backend: 17.16.15.112:3125
2017-09-20 03:03:58: (message) added read-only backend: 172.16.15.112:3126
4)获取链接:mysql -uroot -p123456 -h1.0.0.3 -P4040
分析:咱们的用户名和密码是使用的是MySQL服务器的用户名和密码,由于是要从他们两个当中获取链接,ip和端口都是使用代理的ip和端口。