热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MySQL集群搭建(主从)

一、说明主从集群,这里按照一主一从来配置操作系统:CentOS7.4Mysql5.7.24主库1.1.1.1从库1.1.1.2二、Mysql安装CentOS下安装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账号下完成

su 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数据库

su appadmin
# 启动
service mysqld start
# 停止
service mysqld stop
# 重启
service mysqld restart
# 查看状态
service mysqld status

10,配置环境变量

在root账号下

sudo su
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

修改配置文件

vi /etc/my.cnf

配置内容如下

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

推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
author-avatar
跑车世界Y
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有