查看mysql版本

mysql -V


192.168.60.166 主

192.168.60.167 从

1.首先安装mysql

apt-get install mysql-server


2.修改主服务器的配置文件/etc/mysql/my.cnf

vim /etc/mysql/my.cnf

把下面2行注释去掉

server-id = 1

log_bin                 = /var/log/mysql/mysql-bin.log

bind-address           = 192.168.60.166


service mysql stop

service mysql start

mysql -uroot -p #登录管理mysql

GRANT REPLICATION SLAVE ON *.* to 'root'@'192.168.60.167' identified by '123456';

#授权给从数据库服务器192.168.60.167


GRANT ALL ON *.* TO 'root'@'192.168.60.86' IDENTIFIED BY '123456';

flush privileges;

#允许远程连接MYSQL


show master status; #查询主数据库状态

+------------------+----------+--------------+------------------+

| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+------------------+----------+--------------+------------------+

| mysql-bin.000003 |      106 |              |                  |

+------------------+----------+--------------+------------------+

1 row in set (0.00 sec)


记录下 FILE 及 Position 的值,在后面进行从服务器操作的时候需要用到。

xf是如下

+------------------+----------+--------------+------------------+

| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+------------------+----------+--------------+------------------+

| mysql-bin.000001 |      106 |              |                  |

+------------------+----------+--------------+------------------+


3.配置从服务器

修改从服务器的配置文件/etc/mysql/my.cnf

vim /etc/mysql/my.cnf

将 server-id = 1修改为 server-id = 10,并确保这个ID没有被别的MySQL服务所使用。

bind-address           = 192.168.1.153

service mysql stop

service mysql start

mysql -uroot -p


change master to

master_host='192.168.1.156',

master_user='rep1',

master_password='ylmf',

master_log_file='mysql-bin.000005',

master_log_pos=242;

xf如下

mysql> change master to

master_host='192.168.60.166',

master_user='root',

master_password='123456',

master_log_file='mysql-bin.000001',

master_log_pos=106;


正确执行后启动Slave同步进程


mysql> START SLAVE; #主从同步检查

show slave status;

其中Slave_IO_Running 与 Slave_SQL_Running 的值都必须为YES,才表明状态正常。


GRANT ALL ON *.* TO 'root'@'192.168.60.86' IDENTIFIED BY '123456';

flush privileges;

#允许远程连接MYSQL


如果主服务器已经存在应用数据,则在进行主从复制时,需要做以下处理:

(1)主数据库进行锁表操作,不让数据再进行写入动作

FLUSH TABLES WITH READ LOCK;


(2)查看主数据库状态

show master status;


(3)记录下 FILE 及 Position 的值。

将主服务器的数据文件(整个/opt/mysql/data目录)复制到从服务器,建议通过tar归档压缩后再传到从服务器解压。

(4)取消主数据库锁定

mysql> UNLOCK TABLES;


4.验证主从复制效果

在主服务器上创建数据库first_db

create database first_db;


在主服务器上创建表first_tb

create table first_tb(id int(3),name char(10));


在主服务器上的表first_tb中插入记录

insert into first_tb values (001,'myself');


在从服务器上查看,所有记录已复制过来

由此,整个MySQL主从复制的过程就完成了.


##############################################

5.MYSQL读写分离Amoeba方式 xf

(MySQL-Proxy方式脚本配置比较复杂,不容易扩展)

jdk1.5以上

主服务器:192.168.60.166

从服务器:192.168.60.167

MySQL-Proxy调度服务器:192.168.60.168


配置参考:Amoeba搞定mysql主从读写分离.htm


Amoeba下载地址

http://ncu.dl.sourceforge.net/sourceforge/amoeba/


9. 测试读写分离效果

为了清晰的看到读写分离的效果,需要暂时关闭MySQL主从复制功能

登陆从数据库服务器192.168.60.167 (从),通过命令行登录管理MySQL服务器

mysql -u root -pylmf 

stop slave;

连接MySQL-Proxy

mysql -uroot -p123456 -P3307 -h192.168.60.168

mysql -uroot -p123456 -h192.168.60.168 -P8066

登陆成功后,在first_db数据的first_tb表中插入两条记录

use first_db;

insert into first_tb values (007,'first');

insert into first_tb values (008,'second');

quit


分别登陆到主从数据库服务器,对比记录信息,首先,检查主数据库服务器

登录到192.168.1.156主数据库服务器

use first_db;

select * from first_tb;


然后,检查从数据库服务器

登录到192.168.1.153从数据库服务器

use first_db;

select * from first_tb;

没有新记录存在



由此,我们已经实现了MySQL读写分离,目前所有的写操作都全部在Master主服务器上,

另外,所有的读操作都分摊给了其它各个Slave从服务器上,用来分担数据库压力。


 


调整服务脚本,重启mysqld服务

    通过修改start()函数的执行语句,可以调控mysqld服务的启动选项。例如:

--log-slave-updates=1              #//记录从库更新,以便允许链式复制

--read-only                        #//将从库设为只读,仅允许从服务器线程或具有SUPER权限的用户执行

--relay-log=mysqld-relay-bin       #//使用固定的中继日志文件

--report-host=server205            #//报告给主服务器的主机名或IP地址

--slave_compressed_protocol=1      #//复制过程启用压缩,若启用此项,主、从服务器都应该添加

--replicate-do-db=mysql            #//仅复制指定的库,其他库将被忽略,此选项可设置多条(省略时复制所有库)

--replicate-do-db=mytestdb

--replicate-ignore-db=test         #//不复制(忽略)指定的库,此选项也可以设置多条,do和ignore用其中一种就可以了

--skip-slave-start                 #//服务器启动时跳过复制,需要手动 SLAVE START

--slave-net-timeout=60             #//当从服务器网络中断时,再次重试之前等待的时间(默认为60秒)

--master-connect-retry=60          #//当主服务器连接丢失时,再次重试之前等待的时间(默认为60秒)