數據庫--一主多從
阿新 • • 發佈:2018-11-27
RoCE mysqld ica host 初始 localhost use ati 數據庫 多實列及其一主多從
創建存放數據庫信息的目錄
[root@db200 ~]# mkdir /data/330{7..9} –p
創建存放配置文件的文件
[root@db01 ~]# touch /data/330{7..9}/my.cnf
編輯3307配置文件
[root@db01 ~]# vim /data/3307/my.cnf [mysqld] basedir=/application/mysql datadir=/data/3307/data socket=/data/3307/mysql.sock log_error=/data/3307/mysql.log log-bin=/data/3307/mysql-bin server_id=7 port=3307 [client] socket=/data/3307/mysql.sock //指定了3307數據庫的sock的文件
編輯3308配置文件
[root@db01 ~]# vim /data/3307/my.cnf
[mysqld]
basedir=/application/mysql
datadir=/data/3308/data
socket=/data/3308/mysql.sock
log_error=/data/3308/mysql.log
log-bin=/data/3308/mysql-bin
server_id=8
port=3308
[client]
socket=/data/3308/mysql.sock
編輯3309配置文件
[root@db01 ~]# vim /data/3309/my.cnf [mysqld] basedir=/application/mysql datadir=/data/3309/data socket=/data/3309/mysql.sock log_error=/data/3309/mysql.log log-bin=/data/3309/mysql-bin server_id=9 port=3309 [client] socket=/data/3309/mysql.sock
初始化3307數據庫
[root@db01 ~]#/application/mysql/scripts/mysql_install_db \
--user=mysql \
--defaults-file=/data/3307/my.cnf \
--basedir=/application/mysql --datadir=/data/3307/data
初始化3308數據庫
[root@db01 ~]#/application/mysql/scripts/mysql_install_db \ --user=mysql \ --defaults-file=/data/3308/my.cnf \ --basedir=/application/mysql --datadir=/data/3308/data
初始化3309數據庫
[root@db01 ~]#/application/mysql/scripts/mysql_install_db \
--user=mysql \
--defaults-file=/data/3309/my.cnf \
--basedir=/application/mysql --datadir=/data/3309/data
修改權限
[root@db01]# chown -R mysql.mysql /data/330*
啟動實列
[root@db01]# mysqld_safe --defaults-file=/data/3307/my.cnf &
[root@db01]# mysqld_safe --defaults-file=/data/3308/my.cnf &
[root@db01]# mysqld_safe --defaults-file=/data/3309/my.cnf &
登陸數據庫
[root@db01]# mysql -S /data/3307/mysql.sock -e "show variables like ‘server_id‘"
[root@db01]# mysql -S /data/3308/mysql.sock -e "show variables like ‘server_id‘"
[root@db01]# mysql -S /data/3309/mysql.sock -e "show variables like ‘server_id‘"
以上實列配置(一主多從)
以3307做為主庫
[root@db01]# mysql -S /data/3307/mysql.sock -e "show variables like ‘server_id‘" //登陸主庫
數據庫的主庫的授權
grant replication slave on *.* to slave@‘localhost‘ identified by ‘123‘;
查看數據庫的狀態
mysql> show master status;
要提取出file值和position值從庫使用。
導出主庫的內容
mysqldump -uroot -p3307 -S /data/3307/mysql.sock -A >/root/3307.sql
從庫的配置 (3308和3309做為從庫)
導入主庫的內容,主從庫的內容實現高度一致
mysql -uroot -p3308 -S /data/3308/mysql.sock </root/3307.sql
登陸從庫
mysql -S /data/3308/mysql.sock -e "show variables like ‘server_id‘"
從庫的設置
mysql> change master to
-> master_host=‘localhost‘,
-> master_port=3307,
-> master_user=‘slave‘,
-> master_password=‘123‘,
-> master_log_file=‘mysql-bin.000008‘, // 一定要和主庫的授權表信息表示一致
-> master_log_pos=521; // 一定要和主庫的授權表信息表示一致
狀態值查看
mysql> start slave;
mysql> show slave status\G;
主從配置成功
導入主庫的內容,主從庫的內容實現高度一致
mysql -uroot -p3309 -S /data/3309/mysql.sock </root/3307.sql
登陸從庫
mysql -S /data/3309/mysql.sock -e "show variables like ‘server_id‘"
從庫的設置
mysql> change master to
-> master_host=‘localhost‘,
-> master_port=3307,
-> master_user=‘slave‘,
-> master_password=‘123‘,
-> master_log_file=‘mysql-bin.000008‘, // 一定要和主庫的授權表信息表示一致
-> master_log_pos=521; // 一定要和主庫的授權表信息表示一致
狀態值查看
mysql> start slave;
mysql> show slave status\G;
主從配置成功
數據庫--一主多從