您当前的位置:首页 > 电脑百科 > 数据库 > MYSQL

MySQL5.7数据库主从架构部署,你再也不用去问度娘了

时间:2021-01-11 14:00:48  来源:  作者:

啰嗦的话,不多说,我们直接开始部署,我相信有点linux基础的人都能看得懂。

MySQL5.7.22主从部署,既然是主从那肯定是需要至少2台服务器了,2台的安装都是一样的,请看下面!

1、 创建mysql用户:useradd -m -d /home/mysql mysql

2、 上传mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz安装包到/App目录下。

附官方下载链接:https://dev.mysql.com/downloads/file/?id=476936

3、 解压安装包到/app目录下tar -zxvf mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz

4、 将解压完的安装包重命名为:mysql5722

mv mysql-5.7.22-linux-glibc2.12-x86_64 mysql5722

5、 进入mysql5722目录下创建data、logs目录。

cd mysql5722/

mkdir data && mkdir logs

6、 进入刚刚创建的logs目录下创建日志文件

cd logs touch error.log && touch general.log

授权/app/mysql5722目录属主属组为mysql

chown -R mysql:mysql /app/mysql5722

7、 进入mysql的bin目录下进行初始化设置:

cd ../bin/ ./mysqld --initialize --user=mysql --basedir=/app/mysql5722/ --datadir=/app/mysql5722/data

注意:初始化的时候会提示root用户的默认密码记得保存,首次登陆需要。

8、 创建mysql配置文件:

cd /etc/&& mv my.cnf my.cnf.bak

新建配置文件:touch my.cnf,内容如下:

Master节点配置文件内容:

[mysqld]
server-id=1
log_bin=master-bin
log_bin_index=master-bin.index
binlog_do_db=mysql
expire_logs_days=7
#skip-grant-tables
lower_case_table_names=1
explicit_defaults_for_timestamp
port = 3306
datadir = /app/mysql5722/data
socket = /app/mysql5722/mysql.sock
user = mysql
symbolic-links = 0
basedir = /app/mysql5722
big-tables
character-set-server = utf8
#general-log-file = /app/mysql5722/logs/general.log
language = /app/mysql5722/share
lc-messages-dir = /app/mysql5722/share
general-log = on
#GENERAL_LOG=ON
general-log-file = /app/mysql5722/logs/mysqld.log
slow-query-log = 1
pid-file = /app/mysql5722/mysql.pid
slow-query-log-file = /app/mysql5722/logs/mysqld_slow.log
slave-load-tmpdir = /app/mysql5722/tmp
plugin-dir = /app/mysql5722/lib/plugin
max_connections = 1000
#innodb
#innodb_log_file_size=512M
#innodb_buffer_pool_size=2G
[mysqld_safe]
log-error=/app/mysql5722/logs/mysql_error.log
pid-file=/app/mysql5722/mysql.pid
[client]
port = 3306
socket=/app/mysql5722/mysql.sock
user=mysql

9、 配置启动命令:

cd /app/mysql5722/support-files/

cp mysql.server /etc/init.d/mysqld

cd /etc/init.d/

修改mysqld配置文件内容添加如下两行信息:

MySQL5.7数据库主从架构部署,你再也不用去问度娘了

 

10、 配置开机启动

chkconfig --add mysqld
chkconfig mysqld on
chown -R mysql:mysql mysql5722/

11、 启动mysql数据库

service mysqld start

12、 登录mysql

./mysql -uroot -p'LRabR;xaS9lh'
修改root默认密码,不然无法执行sql:
alter user user() identified by "Abcd@123";修改root用户密码
flush privileges;刷新
user mysql;
create user 'master'@'%' identified by 'Abcd@123';
grant replication slave on *.* to 'master'@'%';
flush privileges
show master status;

备slave节点配置文件:

vim /etc/my.cnf

[mysqld]
server-id=2
relay_log=slave-relay-bin
relay_log_index=slave-relay-bin.index
basedir=/app/mysql5722
datadir=/app/mysql5722/data
socket=/app/mysql5722/mysql.sock
user=mysql
character-set-server=utf8
lower_case_table_names=1
explicit_defaults_for_timestamp
port=3306
general-log=1
general-log-file=/app/mysql5722/logs/general.log
slow-query-log=1
long_query_time=1
slow_query_log_file=/app/mysql5722/slowquery.log
pid-file=/app/mysql5722/mysql.pid
slave-load-tmpdir=/app/mysql5722/slavetmp
max_connections=1000
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
#skip-grant-tables
[mysqld_safe]
log-error=/app/mysql5722/logs/error.log
pid-file=/app/mysql5722/mysql.pid
[client]
port=3306
socket=/app/mysql5722/mysql.sock
user=mysql

保存后重启从节点mysql。

备机:(slave)上配置:

登录mysql后执行:

user mysql;
change master to master_host='10.1.60.71',master_user='master',master_password='abcd@123',master_log_file='master-bin.000001',master_log_pos=154;
show slave statusG;
MySQL5.7数据库主从架构部署,你再也不用去问度娘了

 

保证如下两个值都为YES说明主从复制已经配置成功,需要注意的是两台服务器的防火墙策略,网络必须是互通的。

Slave_IO_Running:YES

Slave_SQL_Running:YES

当然此架构如果对外提供服务不想使用服务器的真实IP,你也可以安装keepalived做VIP对外进行提供服务!

更加详细的内容,可以转发关注我哦,咱们一起在技术的这条道路上相互帮助前进!



Tags:数据库 主从架构   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
啰嗦的话,不多说,我们直接开始部署,我相信有点linux基础的人都能看得懂。Mysql5.7.22主从部署,既然是主从那肯定是需要至少2台服务器了,2台的安装都是一样的,请看下面!1、 创建mysq...【详细内容】
2021-01-11  Tags: 数据库 主从架构  点击:(127)  评论:(0)  加入收藏
▌简易百科推荐
作者:雷文霆 爱可生华东交付服务部 DBA 成员,主要负责Mysql故障处理及相关技术支持。爱好看书,电影。座右铭,每一个不曾起舞的日子,都是对生命的辜负。 本文来源:原创投稿 *爱可生...【详细内容】
2021-12-24  爱可生    Tags:MySQL   点击:(6)  评论:(0)  加入收藏
生成间隙(gap)锁、临键(next-key)锁的前提条件 是在 RR 隔离级别下。有关Mysql记录锁、间隙(gap)锁、临键锁(next-key)锁的一些理论知识之前有写过,详细内容可以看这篇文章...【详细内容】
2021-12-14  python数据分析    Tags:MySQL记录锁   点击:(17)  评论:(0)  加入收藏
binlog 基本认识 MySQL的二进制日志可以说是MySQL最重要的日志了,它记录了所有的DDL和DML(除了数据查询语句)语句,以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二...【详细内容】
2021-12-14  linux上的码农    Tags:mysql   点击:(13)  评论:(0)  加入收藏
为查询优化你的查询 大多数的MySQL服务器都开启了查询缓存。这是提高性最有效的方法之一,而且这是被MySQL的数据库引擎处理的。当有很多相同的查询被执行了多次的时候,这些查...【详细内容】
2021-12-09  元宇宙iwemeta    Tags:mysql   点击:(15)  评论:(0)  加入收藏
测试的目的和原因,公司有很多程序员,每个程序员对数据库和表结构都有自己的理解。而且每个程序员的理解往往是以效率考虑。既然都是为了效率考虑,那么我就来测试一下究竟哪种使...【详细内容】
2021-12-08  吴彬的分享    Tags:Mysql数据库   点击:(14)  评论:(0)  加入收藏
当你们考虑项目并发的时候,我在部署环境,当你们在纠结使用ArrayList还是LinkedArrayList的时候,我还是在部署环境。所以啊,技术不止境,我在部环境。今天这篇文章缕一下在同一台服...【详细内容】
2021-12-08  秃头码哥    Tags:MySQL数据库   点击:(16)  评论:(0)  加入收藏
对于数据分析来说,MySQL使用最多的是查询,比如对数据进行排序、分组、去重、汇总及字符串匹配等,如果查询的数据涉及多个表,还需要要对表进行连接,本文就来说说MySQL中常用的查询...【详细内容】
2021-12-06  笨鸟学数据分析    Tags:MySQL   点击:(19)  评论:(0)  加入收藏
在学习SQL语句之前,首先需要区分几个概念,我们常说的数据库是指数据库软件,例如MySQL、Oracle、SQL Server等,而本文提到的数据库是指数据库软件中的一个个用于存储数据的容器。...【详细内容】
2021-11-24  笨鸟学数据分析    Tags:SQL语句   点击:(23)  评论:(0)  加入收藏
概述以前参加过一个库存系统,由于其业务复杂性,搞了很多个应用来支撑。这样的话一份库存数据就有可能同时有多个应用来修改库存数据。比如说,有定时任务域xx.cron,和SystemA域...【详细内容】
2021-11-05  Java云海    Tags:分布式锁   点击:(31)  评论:(0)  加入收藏
MySQL的进阶查询 一、 按关键字排序 使用ORDERBY语句来实现排序排序可针对一个或多个字段ASC:升序,默认排序方式 【升序是从小到大】DESC:降序 【降序是从大到小】ORDER BY的...【详细内容】
2021-11-05  Java热点    Tags:SQL语句   点击:(27)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条