AliSQL主从复制

MySQL内建的复制功能是构建大型,高性能应用程序的基础。将MySQL的数据分布到多个系统上去,这种分布的机制,是经过将mysql的某一台主机的数据复制到其它主机(slave)上,并从新执行一遍来实现。mysql

复制过程当中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循坏,这些日志能够记录发送到从服务器的更新。当一个从服务器c++

链接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,而后封锁并等待主服务器通知的更新。git

需注意的是:sql

在进行mysql复制时,全部对复制中的表的更新必须在主服务器上进行。不然必需要当心,以免用户对主服器上的表进行更新与对从服务器上的表所进行更新之间的冲突。数据库

源码安装AliSQL-AliSQL-5.6.32-9
能够在个人网盘下载包
连接:https://pan.baidu.com/s/1FDmGV2zVLI9NxfdpjVqK4g
提取码:tpuy
复制这段内容后打开百度网盘,操做更方便哦:vim

主从间的数据库不是实时同步,就算网络链接正常,也存在瞬间主从数据不一致的状况。
若是须要多主库的话,能够用环形配置,这样任意一个节点的修改均可以同步到全部节点因此也须要ntp(时间同步)centos

源码安装AliSQL
接下来咱们源码安装AliSQL
下载依赖包 解压服务器

wget http://repo.openfusion.net/centos7-x86_64//perl-Data-Dumper-2.154-1.of.el7.x86_64.rpm
rpm -ivh perl-Data-Dumper-2.154-1.of.el7.x86_64.rpm
yum -y install cmake bison git ncurses-devel gcc gcc-c++

解压AliSQL网络

unzip AliSQL-AliSQL-5.6.32-9.zip

建立一个mysql的组ide

groupadd mysql
useradd -g mysql mysql

建立mysql目录还有data目录

mkdir -p /data/server/mysql/data
cd /usr/local/src/AliSQL-AliSQL-5.6.32-9

编译指定路径为data server 目录下的mysql

cmake -DCMAKE_INSTALL_PREFIX=/data/server/mysql -DMYSQL_UNIX_ADDR=/data/server/mysql/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DMYSQL_DATADIR=/data/server/mysql/data -DMYSQL_TCP_PORT=3306 -DMYSQL_USER=mysql -DENABLE_DOWNLOADS=1
make && make install

注意修改mysql目录的属主和属组

chown -R mysql:mysql /data/server/mysql/data/
chown -R mysql:mysql /data/server/mysql/
cd /data/server/mysql

初始化数据库

scripts/mysql_install_db --defaults-file=./my.cnf --user=mysql

修改生成的文件属主和属组

chown -R mysql:mysql my.cnf

而后开启mysql服务

cd /data/server/mysql/support-files
./mysql.server start

开启以后进入交互环境

cd /data/server/mysql/bin
./mysql -u root -p

这里咱们准备两台机器所有安装AliSQL-AliSQL-5.6.32-9安装到/data/server下
主库机器ip:192.168.124.107 从库机器ip:192.168.124.108
master主库配置

vim  /data/server/

#修改内容
#解释:server-id服务的惟一标识(主从之间都必须不一样);log-bin启动二进制日志名称为mysql-bin

【mysqld】
server-id=1
log-bin=mysql-bin

保存退出

cd /data/server/mysql/support-files
./mysql.server start

一、master主库添加从库帐号
进入到bin目录启动mysql 进入到交互环境

cd /data/server/mysql/bin
./mysql -u root -p

新建用于主从同步的用户chaoge,容许登陆的从库是'192.168.124.108'

create user 'chaoge'@'192.168.124.108' identified by 'redhat';

给从库帐号受权,说明给chaoge从库复制的权限,在192.168.124.108机器上复制

grant replication slave on *.* to 'chaoge'@'192.168.124.108';

检查主库建立的复制帐号

select user,host from mysql.user;

检查受权帐号的权限

show grants for chaoge@'192.168.124.108';

检查主库的状态

show master status;

二、slave从库配置

vim /data/server/mysql/my.cnf

AliSQL主从复制

重启mysql数据库

cd /data/server/mysql/support-files
./mysql.server start

进入到mysql bin目录进入到交互环境

cd /data/server/mysql/bin
./mysql -u root -p

AliSQL主从复制

检查Slava从数据库的各项参数

AliSQL主从复制

配置复制的参数,Slave从库链接Master主库的配置

mysql > change master to master_host='192.168.124.108',
master_user='chaoge',
master_password='redhat',
master_log_file='mysql-bin.000001',
master_log_pos=120;

启动从库的同步开关,测试主从复制的状况

AliSQL主从复制

查看复制状态 看到
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
那么就成功了

AliSQL主从复制

相关文章
相关标签/搜索