Centos7+Mariadb集群-主从配置介绍

Centos7+Mariadb集群-主从配置介绍

近期一直在恶补Linux相关的知识,主要是就是学Linux下的基本日常应用服务器的配置及优化,今天我们主要介绍一下在Centos7下安装及配置Mysql 集群,说到集群,其实就是为了提高服务的高可用性。对于高可用的相关服务今天不是主要介绍内容,今天主要介绍MYSQL的主从配置。对在Linux下的其他服务的介绍及服务高可用负载均衡我们将会在后期的文章中介绍。开始今天的介绍:Centos7+Mysql主从配置。

环境介绍:

Hostname:A-S

IP:192.168.5.21

Role:Mysql 主

Hostname:B-S

IP:192.168.5.22

Role:Mysql 从

其实从Centos7下mysql已经被遗弃了,变为Mariadb了,当然功能及配置是一样的。比如我们在低版本下安装mysql都需要执行以下命令:

image

yum install -y mysql mysql-server

clip_image001

我们通过查看安装信息,mysql-server不可用的包

clip_image001[4]

我们最后看见安装陈公公给你了Mariadb的相关包信息

clip_image001[6]

Centos7中用MariaDB代替了mysql数据库。好吧!那我们来安装MariaDB数据库吧!

运行yum install MariaDB-server MariaDB-client命令安装 MariaDB

yuminstallmariadb-servermariadb-client

clip_image001[8]

clip_image001[10]

安装完成

clip_image001[12]

我们通过rpm查看安装的相关信息

clip_image001[14]

启动mariadb数据库

systemctlstartmariadb

clip_image001[16]

接着运行mysql_secure_installation配置MariaDB

我们可以根据自己的需求进行配置定义

clip_image001[18]

配置完成

clip_image001[20]

配置完成后,我们开始进入数据库

mysql�Curoot�Cp

clip_image001[22]

查看数据库

showdatabases;

clip_image001[24]

我们创建一个测试数据库

createdatabaseDB1;

clip_image001[26]

clip_image001[28]

最后我们使用工具进行连接mysql ,提示不允许该主机进行连接,因为mysql默认是不让任何主机进行连接

clip_image001[30]

我们可以根据自己的配置设置运行那些主机及用户进行mysql的连接;

如果我们需要配置任何主机都可以连接的话,可以使用一下命令

GRANTALLPRIVILEGESON*.*TO'root'@'%'IDENTIFIEDBY'youpassword'WITHGRANTOPTION;
flushprivileges;

如果任何主机连接不需要密码的话可以下面

GRANTALLPRIVILEGESON*.*TO'root'@'%'IDENTIFIEDBY''WITHGRANTOPTION;
flushprivileges;

我们下面简单的说几个日常的配置命令

许root用户在一个特定的IP进行远程登录,并具有所有库任何操作权限,具体操作如下: 在本机先使用root用户登录mysql: mysql -u root -p"youpassword" 进行授权操作: GRANT ALL PRIVILEGES ON *.* TO root@"192.168.x.x" IDENTIFIED BY "youpassword" WITH GRANT OPTION; 重载授权表: FLUSH PRIVILEGES; 退出mysql数据库: exit

允许root用户在一个特定的IP进行远程登录,并具有所有库特定操作权限,具体操作如下: 在本机先使用root用户登录mysql: mysql -u root -p"youpassword" 进行授权操作: GRANT select,insert,update,delete ON *.* TO root@"192.168.x.x" IDENTIFIED BY "youpassword"; 重载授权表: FLUSH PRIVILEGES; 退出mysql数据库: exit

具体就不多介绍了,继续下面的配置介绍

我们前面创建了一个数据库

createdatabasesDB1;
showdatabases;
useDB1;
showtables;

clip_image001[32]

我们接下来创建一个表

CREATETABLEinfo(idint(30)NOTNULL,namevarchar(30)NOTNULL,sexvarchar(30)NOTNULL,mailVARCHAR(255)NOTNULL,PRIMARYKEY(id));

clip_image001[34]

showtables;

clip_image001[36]

插入几条数据

insertintoinfo(name,sex,mail)values('lisi','boy','lisi@abc.com');
insertintoinfo(name,mail)values('xiaoli','girl','xiaoli@abc.com');

clip_image001[38]

select*frominfo;

clip_image001[40]

我们也可以通过工具进行查看

clip_image001[42]

mysql的安装及配置再次就介绍完了,最后我们简单的说一下,MYSQL数据库数据文件位置/var/lib/mysql/

clip_image001[44]

第一台数据库创建完后,我们就按照同样的方法安装及配置第二台Mysql服务器。再次就跳过了;方法同上完全一样;

image

image

注意:我们为了做主从,做第二台机器不需要创建表,只需要创建一个数据库即可(DB1),为了将Server1上的mysql还原到Server2上。

到目前为止,Server1和Server2的数据库均安装完成;

所以现在我们需要将数据库进行备份及还原到从服务器上。mysql的备份有很多方式,比如直接备份成一个.sql文件,或者备份成压缩文件,甚至我们也可以通过脚本进行备份。我们在此都说一下

我们首先查看数据库数据

clip_image001[46]

首先是备份

mysqldump-hlocalhost-uroot-pDbname>Dbname.sql
mysqldump-hlocalhost-uroot-pDB1>DB1.sql

clip_image001[48]

接下来我们在通过压缩的方式备份一下

mysqldump-hlocalhost-uroot-pDBName|gzip>DBName.sql.gz
mysqldump-hlocalhost-uroot-pDB1|gzip>DB1.sql.gz

clip_image001[50]

接下来我们通过语句删除数据库中的所有数据

deletefromdbo.info;

clip_image001[52]

接下来我们进行还原一下;

我们首先通过默认备份进行还原,其实还原和备份的命令就有两个字符的区别

1.符号方向是反的,备份是大于号,还原是小于号。2.备份使用的是mysqldump,还原使用的是mysql

mysql-hlocalhost-uroot-pDB1<DB1.sql

clip_image001[54]

还原后,我们查询数据库

clip_image001[56]

我们继续清空数据,然后使用压缩的格式进行还原;

clip_image001[58]

我们继续使用压缩的进行还原;

gunzip<DB12016-08-23.sql.gz|mysql-uroot-pDB1

clip_image001[60]

还原完成

clip_image001[62]

备份还原介绍完后,我们就需要将Server1的mysql备份数据给Server2拷贝一份及还原一份

scpDB1.sql
root@192.168.5.22:/

clip_image001[64]

接下来我们需要还原命令将数据库还原到Server2上即可

clip_image001[66]

前期工作准备好后,接下来就进入重点,mysql主从配置;

我们首先登陆到Mysql主服务器上,然后编辑mysql的配置文件

vim/etc/my.cnf

clip_image001[68]

我们要添加以下内容;

注:一定要加入到加到mysqld下面,如果加入的位置或者信息不对的话,执行show master status;结果为空;

#设置服务器ID,为1的表示为主服务器;如果服务器没有以下配置,添加,如果有就跳过。
server-id=1
#启动MySQ二进制日志系统,注意:如果原来的配置文件中已经有这一行,就不用再添加了。
log_bin=mysql-bin?
#需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行\
binlog-do-db=DB1
#不同步mysql系统数据库
binlog-ignore-db=mysql

clip_image001[70]

重启mysql服务

sysmtectlrestartmariadb

clip_image001[72]

进入mysql控制台

mysql-uroot-p123456

查看数据库主机的配置文件状态

showmasterstatus;

查看主服务器,出现以下类似信息;如果看不见以下结果或者为空的话,说明my.cnf配置文件配置的有问题,请检查即可。

注意:这里记住File的值:mysql-bin.000001和Position的值:245,后面会用到。

clip_image001[74]

有了主服务器的mysql主机配置后,我需要在从服务器上进行配置了

配置MySQL从服务器的my.cnf文件;区别就是server-id不一样

vi/etc/my.cnf#编辑配置文件,在[mysqld]部分添加下面内容
#设置服务器ID,为1的表示为主服务器,为2的表示为从服务器;如果服务器没有以下配置,添加,如果有就跳过。
server-id=2
#启动MySQ二进制日志系统,注意:如果原来的配置文件中已经有这一行,就不用再添加了。
log_bin=mysql-bin?
#需要同步的数据库名,如果有多个数据库,可重复此参数,每个数据库一行\
binlog-do-db=DB1
#不同步mysql系统数据库
binlog-ignore-db=mysql

clip_image001[76]

接下来配置slave,进入从服务器的mysql控制台配置下:

mysql-uroot-p#进入MySQL控制台
slavestop;#停止slave同步进程

clip_image001[78]

接下来通过以下命令来配置主从关系了;以下命令是在从服务器上操作的。

clip_image001[80]

changemastertomaster_host='主服务器',master_user='mysql用户名',master_password='mysql服务密码',master_log_file='File值',master_log_pos=Postion值;
changemastertomaster_host='192.168.5.21',master_user='root',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=254;
里面填写的信息是是在主服务器上执行showmasterstatus;的信息

clip_image001[82]

启动slave
slavestart;

clip_image001[85]

最后我们查看主从同步是否正常

showslavestatus;

clip_image001[87]

最后我们测试数据,给主服务器数据表添加数据

clip_image001[89]

然后在从服务器上进行查看

clip_image001[91]

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


linux下开机自启: 在/etc/init.d目录下新建文件elasticsearch 并敲入shell脚本: 注意, 前两行必须填写,且要注释掉。 第一行为shell前行代码,目的告诉系统使用shell。 第二行分别代表运行级别、启动优先权、关闭优先权,且后面添加开机服务会用到。 shell脚本
1、因为在centos7中/etc/rc.d/rc.local的权限被降低了,所以需要赋予其可执行权 chmod +x /etc/rc.d/rc.local 2、赋予脚本可执行权限假设/usr/local/script/autostart.sh是你的脚本路径,给予执行权限 chmod +x /usr
最简单的查看方法可以使用ls -ll、ls-lh命令进行查看,当使用ls -ll,会显示成字节大小,而ls- lh会以KB、MB等为单位进行显示,这样比较直观一些。 通过命令du -h –max-depth=1 *,可以查看当前目录下各文件、文件夹的大小,这个比较实用。 查询当前目录总大小可以使用d
ASP.NET Core应用程序发布linux在shell中运行是正常的。可一但shell关闭网站也就关闭了,所以要配置守护进程, 用的是Supervisor,本文主要记录配置的过程和过程遇到的问题 安装Supervisor&#160;1 yum install python-setuptools
设置时区(CentOS 7) 先执行命令timedatectl status|grep &#39;Time zone&#39;查看当前时区,如果不是时区(Asia/Shanghai),则需要先设置为中国时区,否则时区不同会存在时差。 #已经是Asia/Shanghai,则无需设置 [root@xia
vim&#160;/etc/sysconfig/network-scripts/ifcfg-eth0 BOOTPROTO=&quot;static&quot; ONBOOT=yes IPADDR=192.168.8.106 NETMASK=255.255.252.0 GATEWAY=192.168.
一、安装gcc依赖 由于 redis 是用 C 语言开发,安装之前必先确认是否安装 gcc 环境(gcc -v),如果没有安装,执行以下命令进行安装 [root@localhost local]# yum install -y gcc 二、下载并解压安装包 [root@localhost local
第一步 On CentOS/RHEL 6.*: $ sudo rpm -Uvh http://li.nux.ro/download/nux/dextop/el6/x86_64/nux-dextop-release-0-2.el6.nux.noarch.rpm On CentOS/RHEL 7: $
/// &lt;summary&gt; /// 取小写文件名后缀 /// &lt;/summary&gt; /// &lt;param name=&quot;name&quot;&gt;文件名&lt;/param&gt; /// &lt;returns&gt;返回小写后缀,不带“.”&lt;/ret
which nohup .bash_profile中并source加载 如果没有就安装吧 yum provides */nohup nohup npm run start &amp; nohup ./kibana &amp;
1.1 MySQL安装 1.1.1 下载wget命令 yum -y install wget 1.1.2 在线下载mysql安装包 wget https://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm 1.1.3 安装My
重启 reboot shutdown -r now init 6 关闭 init 0 shutdown -h now shutdown -h 20:25 #8点25关机查看内存 free CPU利用率 top 日期 date 设置时间 date 033017002015 #月日时间年 日历 cal
1、firewalld的基本使用 启动: systemctl start firewalld 关闭: systemctl stop firewalld 查看状态: systemctl status firewalld 开机禁用 : systemctl disable firewalld 开机启用 :
1 下载并安装MySQL官方的&#160;Yum Repository wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm 使用上面的命令就直接下载了安装用的Yum Repository,大概
CentOS6.x CentOS6中转用Upstrat代替以前的init.d/rcX.d的线性启动方式。 一、相关命令 通过initctl help可以查看相关命令 [root@localhost ~]# initctl help Job commands: start Start job. sto
1、使用命令:df -lk 找到已满磁盘 2、使用命令:du --max-depth=1 -h 查找大文件,删除
ifconfig:查看网卡信息 网卡配置文件位置: /etc/sysconfig/network-scripts/文件夹 nmtui:配置网卡 netstat -tlunp:查看端口信息 端口信息存储位置: /etc/services文件 route:查看路由信息 wget:下载网路文件,例如 wg
ps -ef:查看所有进程,&#160;ps -ef |grap firewalld 查看与firewalld相关的进程 which :查看进程:which firewalld kill 进程id:杀掉进程 kill 640,强制杀:kill -9 640 man:查看帮助,例如 man ps 查看
useradd:添加用户 useradd abc,默认添加一个abc组 vipw:查看系统中用户 groupadd:添加组groupadd ccna vigr:查看系统中的组 gpasswd:将用户abc添加到ccna组 gpasswd -a abc ccna groups abc:查看用户abc属