在一个项目中,很多用户同时使用业务功能,这可能会对我们的数据库磁盘造成损害甚至损害到我们的项目功能,因此我们可以使用多个数据库来缓解数据库压力。比如一个数据库用来修改数据,另外一个数据库用来查询数据,或者用多个数据库来实现查询功能,分担数据库的压力。
我们可以使用一个数据库做为主库,另外一个甚至几个数据库作为从库。主从的数据是同步的,但是主库用来修改数据,从库用来查询数据。
我们可以这样做:
- 对数据库进行配置。
MySQL之间数据复制的基础是二进制日志文件(binary log file)。一台MySQL数据库一旦启用二进制日志后,其作为master,它的数据库中所有操作都会以“事件”的方式记录在二进制日志中,其他数据库作为slave通过一个I/O线程与主服务器保持通信,并监控master的二进制日志文件的变化,如果发现master二进制日志文件发生变化,则会把变化复制到自己的中继日志中,然后slave的一个SQL线程会把相关的“事件”执行到自己的数据库中,以此实现从数据库和主数据库的一致性,也就实现了主从复制。
实现MySQL主从复制需要进行的配置:
主服务器:
开启二进制日志
配置唯一的server-id
获得master二进制日志文件名及位置
创建一个用于slave和master通信的用户账号
从服务器:
配置唯一的server-id
使用master分配的用户账号读取master二进制日志
启用slave服务
具体实现过程如下:
一、准备工作:
1.主从数据库版本最好一致
2.主从数据库内数据保持一致
1.修改mysql配置
找到主数据库的配置文件my.cnf,我的在/etc/mysql/my.cnf,(一些版本中my.cnf为一个综合的配置文件,他包含了其他两个配置文件,“/etc/mysql/mysql.conf.d/mysqld.cnf” 和 “/etc/mysql/conf.d/mysqld.cnf”另两个文件,[mysqld]在“/etc/mysql/mysql.conf.d/mysqld.cnf”中)在[mysqld]部分插入如下两行:
[mysqld]
log-bin=mysql-bin #开启二进制日志
server-id=1 #设置server-id
character_set_server=utf8
init_connect='SET NAMES utf8'
2.重启mysql