MySQL集群搭建(主从)
时间:2020-05-28
本文章向大家介绍MySQL集群搭建(主从),主要包括MySQL集群搭建(主从)使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
Mysql 主从集群
一、说明
主从集群,这里按照一主一从来配置
-
操作系统:CentOS 7.4
-
Mysql 5.7.24
-
主库 1.1.1.1 从库1.1.1.2
二、Mysql安装
CentOS下安装mysql已经是每一个程序员必备的知识了。我们迅速安装一下。
1,卸载mariadb
由于centos默认安装了mariadb,需要先卸载掉
# start 卸载mariadb
rpm -qa|grep mariadb
rpm -e --nodeps mariadb-libs-5.5.64-1.el7.x86_64
rm /etc/my.cnf
# end 卸载mariadb
2,解压mysql
cp mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz /usr/local/mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz
cd /usr/local
tar -zxvf mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz
3,创建mysql用户
groupadd appadmin
useradd -g appadmin appadmin
passwd appadmin
4,创建mysql数据文件夹&修改文件夹归属&赋权
mkdir /usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/data
chown -R appadmin:appadmin /usr/local/mysql-5.7.24-linux-glibc2.12-x86_64
chmod -R 755 /usr/local/mysql-5.7.24-linux-glibc2.12-x86_64
5,配置文件
在root账号下进行配置文件操作
vi /etc/my.cnf
增加配置内容
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
#skip-name-resolve
#设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=/usr/local/mysql-5.7.24-linux-glibc2.12-x86_64
# 设置mysql数据库的数据的存放目录
datadir=/usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
lower_case_table_names=1
max_allowed_packet=16M
增加完配置文件,记得修改文件归属
chown appadmin:appadmin /etc/my.cnf
6,初始化数据库
数据库属于appadmin,在appadmin账号下完成
/usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/bin/mysql_install_db --user=appadmin --basedir=/usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/ --datadir=/usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/data/
7,设置service启动
设置开机启动需要root权限,先切换到root账号下
sudo su
在root下配置service
cd /usr/local/mysql-5.7.24-linux-glibc2.12-x86_64
cp ./support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
8,设置开机自启动
设置开机自启动,也需要在root账号下完成
chkconfig --level 35 mysqld on
chmod +x /etc/rc.d/init.d/mysqld
chkconfig --add mysqld
9,启停mysql数据库
# 启动
service mysqld start
# 停止
service mysqld stop
# 重启
service mysqld restart
# 查看状态
service mysqld status
10,配置环境变量
在root账号下
vi /etc/profile
增加如下配置
export PATH=$PATH:/usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/bin
刷新配置
source /etc/profile
增加软连接
ln -s /usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/bin/mysql /usr/bin/mysql
11,设置root密码
回到appadmin账号下
查看临时密码
cat /root/.mysql_secret
使用临时密码进入mysql
mysql -uroot -p
设置密码
set PASSWORD = PASSWORD('密码');
flush privileges;
设置mysql访问主机,这一步根据实际情况来设置,我这里先设置为所有IP可访问
use mysql;
update user set host='%' where user='root';
至此,MySQL单台安装已完成
三、集群配置
两台MySQL都按照上面的说明,安装完成,就可以开始集群配置了。
1,主节点配置
切换到用户 appadmin下
在主库上创建从库复制账号密码
mysql -uroot -p
# 输入密码
use mysql
create user 'rep'@'1.1.1.2' identified by 'rep';
select user,host from mysql.user;
grant replication slave on *.* to 'rep'@'1.1.1.2'identified by 'rep';
exit;
退出MySQL,创建log-bin文件夹
mkdir /usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/log-bin
修改配置文件
vi /etc/my.cnf
增加如下配置内容
# 这里的server-id,是自定义的,我自定义为了1
server-id=1
# 这个就是上面刚刚创建的 文件夹
log-bin=/usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/log-bin/mysql-bin
binlog-format=mixed
binlog-ignore-db=mysql
重启MySQL即可
service mysqld restart
2,从节点配置
切换到appadmin账户下
创建文件夹
mkdir /usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/log-bin
修改配置文件
mkdir /usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/log-bin
配置内容如下
server-id=2
relay-log=/usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/log-bin/relay-bin
relay-log-index=/usr/local/mysql-5.7.24-linux-glibc2.12-x86_64/log-bin/relay-bin.index
重启MySQL
service mysqld restart
进入MySQL
mysql -uroot -p
use mysql
change master to master_host='1.1.1.1',master_port=3306,master_user='rep',master_password='rep',master_log_file='mysql-bin.000001',master_log_pos=0;
# 开始复制
start slave;
查看复制状态
show slave status \G
如果出现这两行内容,那么说明主从配置已完成
slave_io_running:yes
Slave_SQL_Running:yes
3,一些错误问题的解决
slave_io_running:no解决办法
首先在主库上查询
show master status \G
然后在从库上修改MASTER_LOG_FILE
# 停止复制
stop slave;
# 修改 MASTER_LOG_FILE
CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000003', MASTER_LOG_POS=0;
# 开始复制
start slave;
# 查看复制状态
show slave status \G
Slave_SQL_Running:no 解决办法
stop slave;
SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
start slave;
show slave status \G
原文地址:https://www.cnblogs.com/x-j-p/p/12980262.html
- ASP.NET MVC扩展库
- centos7.2部署vnc服务记录
- nginx访问报错:Too many open files accept:
- iptables之NAT端口转发设置
- 使用Combres 库 ASP.NET 网站优化
- jQuery和asp.net mvc相关资源链接
- JavaScriptSerializer 序列化json 时间格式
- Nginx反向代理+负载均衡简单实现(https方式)
- 在网页中给Flash加上超级链接
- ASP.NET MVC HandleErrorAttribute 和 远程链接
- javascript实现数字转大写金额的函数
- 如何在GridView的Footer内显示总计?
- 自定义WCF的配置文件
- Centos中动态扩容lvm逻辑卷的操作记录
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- Android 高仿微信朋友圈拍照上传功能
- android的ListView点击item使item展开的做法的实现代码
- Android NavigationView头部设置监听事件
- android如何取得本地通讯录的头像的原图的实现代码
- 取消Android Studio项目与SVN关联的方法
- Android编程实现获取当前系统语言及地区并更改语言的方法
- Android Studio绑定下拉框数据详解
- python中的socket实现ftp客户端和服务器收发文件及md5加密文件
- Android XRecyclerView实现多条目加载
- python3安装OCR识别库tesserocr过程图解
- Android studio 3.0上进行多渠道打包遇到的问题小结(超简洁版)
- Python自动重新加载模块详解(autoreload module)
- python自动脚本的pyautogui入门学习
- Android手机号码输入框(满11位自动跳到下个输入框)实例代码
- Android实现简单实用的搜索框