2、用mysqlConnector/J 提供的ReplicationDriver实现读写分离
我的框架是springmvc+mybatis,数据库连接池使用的是阿里的druid,他们的具体配置这里就不说了,主要说和读写分离有关的地方。
(1)要使用driver不能是之前的默认的com.mysql.jdbc.Driver,而要使用提供的com.mysql.jdbc.ReplicationDriver,并且url也不是单个的url了,详细如下:
db.connection.driver=com.mysql.jdbc.ReplicationDriver
db.connection.url=jdbc:mysql:replication://192.168.1.99:3306,192.168.1.92:3306/testdb?useUnicode=true&characterEncoding=UTF-8&autoReconnect=false&useSSL=false&failOverReadOnly=true&loadBalanceStrategy=random&readFormMasterNoSlaves=true
db.connection.username=root
db.connection.password=password
其中192.168.1.99是主从数据库中的master,92是slave,如果有多个slave可以继续在后面追加,注意数据库是放在最后面的,然后是后面的一串东西,建议最好和我这个保持一致。
spring配置的地方如下,部分代码,主要是diverClassName这个地方,默认是没有的,这里需要制定下:
init-method="init" destroy-method="close">
(2)为了实现读写分离,在下面事务配置的地方非常重要,什么get、find、query、select的方法都需要配置为read-only="true",否则读的时候还是从master库读数据
好了,这样基本就实现了读写分离了,不过有个弊端,数据库在做主从复制时,多少会出现延迟,如果插入数据后立马在从库里面读数据,刚刚插入的数据可能会查不到,这就需要在业务上稍作处理了,不要插入数据后里面就查数据,主从复制是在毫秒级的,所以插入数据后1、2后再插数据完全是没问题的。
当然这种方式也会问题,找了很多博客有比这更好的方法,但感觉稍微比较麻烦点,大家可以参考以下几篇文章看看
http://shift-alt-ctrl.iteye.com/blog/2271730
http://jinnianshilongnian.iteye.com/blog/1720618?page=2#comments
http://ahuaxuan.iteye.com/blog/205926