部署环境情况#
Mysql安装#
1
2
3
4
5
6
7
| # 192.168.2.10 主服务器,Ubuntu20
# 192.168.2.11 备服务器,Ubuntu18
# 主备服务器分别使用以下命令安装mysql
apt update
apt install mysql-server
# 初始化Msql,按提示操作,具体可以参考文末说明。
mysql_secure_installation
|
Msql升级#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
| # 开始以为安装的mysql版本一致,结果Ubuntu20安装的为Mysql8,Ubuntu18安装的为Mysql5.6,后面配置同步导致字符集不一致出错,故添加Ubuntu18升级Mysql版本方法如下
# 下载Mysql的apt源
wget https://dev.mysql.com/get/mysql-apt-config_0.8.22-1_all.deb
# 如果在Ubuntu18下运行此命令出现"https://dev.mysql.com/get/mysql-apt-config_0.8.22-1_all.deb: Scheme missing.",是因为wget命令没有配置到系统变量无法直接使用,可以用下面命令执行
/usr/bin/wget https://dev.mysql.com/get/mysql-apt-config_0.8.22-1_all.deb
# 安装源
dpkg -i mysql-apt-config_0.8.22-1_all.deb
# 在configuring mysql-apt-config中通过方向键和Enter选择MySQL Server & Cluster (Currently selected: mysql-8.0),然后选择Ok,在密码强度界面按自己意愿选择。安装时出现"*** mysqld.cnf (Y/I/N/O/D/Z) [default=N] ?",可以输入Y保留当前配置文件。
# 升级Mysql
apt update
apt install mysql-server
# 最后可以登录Mysql查看版本
|
非root用户登录Msql报错处理#
1
2
3
4
5
| # 附遇到的另一个问题,非root用户登录Mysql提示"Access denied for user '用户名'@'localhost'",主要是因为在Ubuntu上安装MySQL时,对于root用户,可以设置空密码。
# 通过以下命令修改数据库root密码,再退出数据库命令行,即可使用普通系统用户登录。
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
# 此处修改密码时,如果在之前选择的是强密码,可能会报错密码强度不足,需要使用大小写字母+数字+符号形式的密码!
|
配置主从同步#
主库配置(192.168.2.10)#
停止Mysql服务#
修改Mysql配置#
1
| nano /etc/mysql/mysql.conf.d/mysqld.cnf
|
在[mysqld]下添加
1
2
3
4
5
6
| # 设置服务id,主从不能一致
server-id=1
# 开启binlog
log-bin=mysql-bin
# 设置需要同步的数据库
binlog-do-db=test1
|
启动Mysql#
登录数据库,创建主备复制专用账号#
此处命令中的"192.168.2.11"为备库地址,如使用现有账号进行主备复制,则可以忽略创建步骤,“BY"后的密码可以自行指定。
1
| CREATE USER 'sync_test'@'192.168.2.11' IDENTIFIED WITH mysql_native_password BY 'sync_test';
|
授予账号访问权限,sync_test为上一步创建账号,如上一步未创建,可替换为现有账号。
1
| GRANT REPLICATION SLAVE ON *.* TO 'sync_test'@'192.168.2.11';
|
刷新权限
记录日志文件名及位点(File和Position)
从库配置(192.168.2.11)#
停止Mysql服务#
修改Mysql配置#
1
| nano /etc/mysql/mysql.conf.d/mysqld.cnf
|
在[mysqld]下添加
1
2
3
4
5
6
| # 设置服务id,主从不能一致
server-id=2
# 开启binlog
log-bin=mysql-bin
# 设置需要同步的数据库
replicate_wild_do_table=test1.%
|
启动Mysql#
登录数据库,配置同步#
停止同步
配置指向主库,其中master_host为主库地址,master_user、master_password为主备复制专用账号,master_log_file为主库查询到的日志文件名,master_log_pos为主库查询到的位点
1
| CHANGE MASTER TO master_host='192.168.2.10', master_user='sync_test', master_password='sync_test', master_log_file='mysql-bin.000002',master_log_pos=157;
|
启动同步
查看同步状态,如果Slave_IO_Running及Slave_SQL_Running均显示为YES,则同步成功,可以往主库插入一条数据看从库是否也同时插入了一条,若没有,再次使用以下命令查看是否有报错需要处理!
配置互为主从#
将以上主从颠倒再次配置一次即可。
注:Mysql配置文件只需添加相关配置,无需删除内容,防止之前配置的主从失效!
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
| mysql_secure_installation 交互说明
Enter current password for root (enter for none):<–初次运行直接回车
Set root password? [Y/n] <– 是否设置root用户密码,输入y并回车或直接回车
New password: <– 设置root用户的密码
Re-enter new password: <– 再输入一次你设置的密码
Remove anonymous users? [Y/n] <– 是否删除匿名用户,生产环境建议删除,所以直接回车
Disallow root login remotely? [Y/n] <–是否禁止root远程登录,根据自己的需求选择Y/n并回车,建议禁止
Remove test database and access to it? [Y/n] <– 是否删除test数据库,直接回车
Reload privilege tables now? [Y/n] <– 是否重新加载权限表,直接回车
|