1、安装MySQL(192.168.10.164 192.168.10.165)
$ sudo apt-get install mysql-server mysql-client
2、修改MySQL配置(192.168.10.164 192.168.10.165)
$ sudo vim /etc/mysql/my.cnf
注释掉:
bind-address = 127.0.0.1
在[mysqld]节点下添加:
log-bin=mysql-bin# 启用日志
server-id=164# 指定ID,另一台为165
重启:
$ sudo service mysql restart
3、设置单向主从同步(164同步到165)
登录192.168.10.164
$ mysql -uroot -p
Enter password: # 输入密码
设置同步用户:mysync,密码:q123456
mysql> GRANT REPLICATION SLAVE ON *.* to 'mysync'@'%' identified by 'q123456';
Query OK, 0 rows affected (0.00 sec)
查看MASTER状态
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 252 | | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
记住File和Position的值。
登录192.168.10.165
设置主服务器:
mysql> change master to master_host='192.168.10.164',master_user='mysync',master_password='q123456', master_log_file='mysql-bin.000001',master_log_pos=252;
Query OK, 0 rows affected (0.01 sec)
启动从服务器的复制功能:
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
查看服务器复制状态:
mysql> show slave status\G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.10.164
Master_User: mysync
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 252
Relay_Log_File: mysqld-relay-bin.000002
Relay_Log_Pos: 253
Relay_Master_Log_File: mysql-bin.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
注意红色部分是否正常,必须两个Yes,否则无法同步。
4、测试同步(164为主库,165为从库)
登录192.168.10.164
执行:
mysql> create database TEST_DB;
mysql> use TEST_DB;
mysql> CREATE TABLE TEST_TAB ( ID int NOT NULL AUTO_INCREMENT, NAME varchar(50) NOT NULL, PRIMARY KEY (ID) ) ENGINE=`InnoDB` DEFAULT CHARACTER SET utf8;
mysql> INSERT INTO TEST_TAB(NAME) VALUES('root’);
mysql> INSERT INTO TEST_TAB(NAME) VALUES('user01’);
mysql> INSERT INTO TEST_TAB(NAME) VALUES(‘user02');
登录192.168.10.165
执行:
mysql> show databases;
mysql> use TEST_DB;
mysql> show tables;
mysql> select * from TEST_TAB;
+----+--------+
| ID | NAME |
+----+--------+
| 1 | root |
| 2 | user01 |
| 3 | user02 |
+----+--------+
单向同步成功。
5、设置双向同步(165同步到164)
登录192.168.10.165
执行:
mysql> GRANT REPLICATION SLAVE ON *.* to 'mysync'@'%' identified by 'q123456';
Query OK, 0 rows affected (0.00 sec)
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 259 | | |
+------------------+----------+--------------+------------------+
登录192.168.10.164
执行:
mysql> change master to master_host='192.168.10.165',master_user='mysync',master_password='q123456', master_log_file='mysql-bin.000001',master_log_pos=259;
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
mysql> show slave status\G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.10.165
Master_User: mysync
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000001
Read_Master_Log_Pos: 259
Relay_Log_File: mysqld-relay-bin.000002
Relay_Log_Pos: 253
Relay_Master_Log_File: mysql-bin.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
双向同步设置成功,任何一台数据库的操作都将同步到另一台中。
6、避免ID冲突
在my.cnf的[mysqld]节点添加:
auto_increment_offset=1# 起始ID,第一台设置成1、第2台设置成2,以此类推……
auto_increment_increment=2# 每次增长值,>=数据库服务器的总数量
7、Nginx负载均衡(192.168.10.163)
将通过Nginx源码+TCP补丁安装Nginx,配置TCP协议的3306端口转发实现MySQL数据库负载均衡。
安装依赖包:
$ sudo apt-get install gcc g++ libpcre3 libpcre3-dev openssl libssl-dev make git
下载Nginx源码和TCP补丁:
$ cd ~
$ wget http://nginx.org/download/nginx-1.2.1.tar.gz# 当前最新版是1.9,但是补丁打不上,改用tcp_proxy推荐的1.2.1
$ tar zxvf nginx-1.2.1.tar.gz
$ git clone https://github.com/yaoweibin/nginx_tcp_proxy_module.git
将补丁加入Nginx源码编译、安装:
$ cd nginx-1.2.1/
$ patch -p1 < ../nginx_tcp_proxy_module/tcp.patch
$ ./configure --add-module=../nginx_tcp_proxy_module
$ sudo make
$ sudo make install
以上过程不能报错,完成后配置TCP协议:
$ sudo vim /usr/local/nginx/conf/nginx.conf
在http->server节点中添加:
location /status {
tcp_check_status;
}
添加一个与http并行的节点tcp(events和http之间):
tcp {
upstream mysql {
server 192.168.10.164:3306 weight=1;
server 192.168.10.165:3306 weight=1;
#check interval=3000 rise=2 fall=5 timeout=1000;
}
server {
listen 3306;
proxy_pass mysql;
}
}
启动Nginx:
$ sudo /usr/local/nginx/sbin/nginx
$ netstat -nat
Proto Recv-Q Send-Q Local Address Foreign Address State
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN
3306和80端口都已经启动,用客户端登录163的3306。如果无法登录请设置164和165的用户远程登录权限。
8、设置Nginx自动启动。
$ sudo cp ~/nginx /etc/init.d/
$ cd /etc/init.d/
$ sudo chmod +x nginx
$ sudo update-rc.d -f nginx defaults
$ sudo service nginx restart
Restarting Nginx Daemon: nginx.
添加到系统服务成功。
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于