怎么提高项目的数据库性能,Java如何实现主从复制,读写分离?

一台MySQL数据库一旦启用二进制日志后,其作为master,它的数据库中所有操作都会以“事件”的方式记录在二进制日志中,其他数据库作为slave通过一个I/O线程与主服务器保持通信,并监控master的二进制日志文件的变化,如果发现master二进制日志文件发生变化,则会把变化复制到自己的中继日志中,然后slave的一个SQL线程会把相关的“事件”执行到自己的数据库中,以此实现从数据库和主数据库的一致性,也就实现了主从复制。主从的数据是同步的,但是主库用来修改数据,从库用来查询数据。
摘要由CSDN通过智能技术生成

在一个项目中,很多用户同时使用业务功能,这可能会对我们的数据库磁盘造成损害甚至损害到我们的项目功能,因此我们可以使用多个数据库来缓解数据库压力。比如一个数据库用来修改数据,另外一个数据库用来查询数据,或者用多个数据库来实现查询功能,分担数据库的压力。

我们可以使用一个数据库做为主库,另外一个甚至几个数据库作为从库。主从的数据是同步的,但是主库用来修改数据,从库用来查询数据。

我们可以这样做:

  1. 对数据库进行配置。

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值