- A+
所属分类:未分类
主库:172.31.28.5
从库:172.31.17.79
主从库都需要这样安装
下载安装包
wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz tar zxvf mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz mv mysql-5.7.18-linux-glibc2.5-x86_64 mysql
添加用户组
groupadd mysql useradd -g mysql my4840
创建数据目录
mkdir -p /data/mysql4840
给数据目录赋权
chown -R my4840:mysql /data/mysql4840
初始化数据库
[root@ip-172-31-28-5 mysql]# ./bin/mysqld --user=my4840 --basedir=/usr/local/mysql --datadir=/data/mysql4840/data --initialize 2018-05-28T09:40:38.480254Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2018-05-28T09:40:38.731882Z 0 [Warning] InnoDB: New log files created, LSN=45790 2018-05-28T09:40:38.773896Z 0 [Warning] InnoDB: Creating foreign key constraint system tables. 2018-05-28T09:40:38.833075Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: 2e038ca2-625b-11e8-a2f4-0240eb101cc2. 2018-05-28T09:40:38.834853Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened. 2018-05-28T09:40:38.835227Z 1 [Note] A temporary password is generated for root@localhost: )x0UI9Ulqp<a
初始化的密码需要记住哈
下来将mysql服务添加到系统中
[root@ip-172-31-28-5 mysql]# cp support-files/mysql.server /etc/init.d/mysqld [root@ip-172-31-28-5 mysql]# ldconfig [root@ip-172-31-28-5 mysql]# echo "PATH=$PATH:/usr/local/mysql/bin" > /etc/profile.d/mysql.sh [root@ip-172-31-28-5 mysql]# source /etc/profile.d/mysql.sh [root@ip-172-31-28-5 mysql]# chkconfig mysqld on
增加mysql配置文件
vi /etc/my.cnf
[mysqld] basedir=/usr/local/mysql #mysql路径 datadir=/data/mysql4840/data #mysql数据目录 socket=/tmp/mysql4840.sock user=my4840 server_id=100 #MySQLid 同一个网段的id不能重复,配置主从的时候也不能一样 port=4840 pid_file=/data/mysql4840/data/mysql.pid
启动数据库
[root@ip-172-31-28-5 mysql]# service mysqld start Starting MySQL.Logging to '/data/mysql4840/data/ip-172-31-28-5.err'. SUCCESS!
修改密码
[root@ip-172-31-28-5 mysql]# mysql -uroot -peu,vraDH-2G% -P 4840 -h127.0.0.1 mysql: [Warning] Using a password on the command line interface can be insecure. Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 3 Server version: 5.7.18 Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> set password='123456'; Query OK, 0 rows affected (0.00 sec) mysql> FLUSH PRIVILEGES; Query OK, 0 rows affected (0.00 sec) mysql> exit Bye
主库
添加开启binlog
[xubo-iri@ip-172-31-28-5 ~]$ more /etc/my.cnf
[mysqld]
basedir=/usr/local/mysql #mysql路径
datadir=/data/mysql4840/data #mysql数据目录
socket=/tmp/mysql4840.sock
user=my4840
server_id=100 #MySQLid 后面2个从服务器需设置不同
port=4840
pid_file=/data/mysql4840/data/mysql.pid
log-bin=mysql-bin
重启服务
service mysqld restart
查看binlog是否开启
[root@ip-172-31-28-5 xubo-iri]# mysql -uroot -p123456 -P 4840 -h127.0.0.1
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.7.18-log MySQL Community Server (GPL)
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> show variables like '%log_bin%';
+---------------------------------+--------------------------------------+
| Variable_name | Value |
+---------------------------------+--------------------------------------+
| log_bin | ON |
| log_bin_basename | /data/mysql4840/data/mysql-bin |
| log_bin_index | /data/mysql4840/data/mysql-bin.index |
| log_bin_trust_function_creators | OFF |
| log_bin_use_v1_row_events | OFF |
| sql_log_bin | ON |
+---------------------------------+--------------------------------------+
6 rows in set (0.00 sec)
重建主从复制账户
mysql> GRANT REPLICATION SLAVE ON *.* TO'replica'@'172.31.17.79' IDENTIFIED BY '11111111111111111'; mysql> FLUSH PRIVILEGES; mysql> use mysql mysql> select user,authentication_string,host from user; +-----------+-------------------------------------------+--------------+ | user | authentication_string | host | +-----------+-------------------------------------------+--------------+ | root | *C1EE34FAC5D8004DBE7A95DC607992DFDFDFD | localhost | | mysql.sys | *THISISNOTAVALIDPASSWORDTHATCFDFDSF | localhost | | replica | *C2853DFA82C3BA0597A50A1ECDFDSFSDF | 172.31.17.79 | +-----------+-------------------------------------------+--------------+
查看master状态
mysql> show master status\G *************************** 1. row *************************** File: mysql-bin.000001 Position: 154 Binlog_Do_DB: Binlog_Ignore_DB: Executed_Gtid_Set: 1 row in set (0.00 sec)
从库
配置文件如下:
[root@ip-172-31-17-79 mysql]# vi /etc/my.cnf
[mysqld] basedir=/usr/local/mysql #mysql路径 datadir=/data/mysql4840/data #mysql数据目录 socket=/tmp/mysql4840.sock user=my4840 server_id=101 #MySQLid 同一个网段的id不能重复,配置主从的时候也不能一样 port=4840 pid_file=/data/mysql4840/data/mysql.pid read_only = 1 master_info_repository=TABLE relay_log_info_repository=TABLE
登录到mysql
mysql -uroot -p123456 -P 4840 -h127.0.0.1
设置主信息
mysql> stop slave; Query OK, 0 rows affected, 1 warning (0.00 sec) mysql> change master to -> master_host='172.31.28.5', -> master_user='replica', -> master_password='0ff4f09e02111111', -> master_port=4840, -> master_log_file='mysql-bin.000001', -> master_log_pos=154; Query OK, 0 rows affected, 2 warnings (0.02 sec) mysql> start slave; Query OK, 0 rows affected (0.00 sec) mysql> show slave status \G *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 172.31.28.5 Master_User: replica Master_Port: 4840 Connect_Retry: 60 Master_Log_File: mysql-bin.000001 Read_Master_Log_Pos: 154 Relay_Log_File: ip-172-31-17-79-relay-bin.000002 Relay_Log_Pos: 320 Relay_Master_Log_File: mysql-bin.000001 Slave_IO_Running: Yes Slave_SQL_Running: Yes Replicate_Do_DB: Replicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: Last_Errno: 0 Last_Error: Skip_Counter: 0 Exec_Master_Log_Pos: 154 Relay_Log_Space: 537 Until_Condition: None Until_Log_File: Until_Log_Pos: 0 Master_SSL_Allowed: No Master_SSL_CA_File: Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher: Master_SSL_Key: Seconds_Behind_Master: 0 Master_SSL_Verify_Server_Cert: No Last_IO_Errno: 0 Last_IO_Error: Last_SQL_Errno: 0 Last_SQL_Error: Replicate_Ignore_Server_Ids: Master_Server_Id: 100 Master_UUID: 3c63b807-625d-11e8-8f21-0240eb101cc2 Master_Info_File: mysql.slave_master_info SQL_Delay: 0 SQL_Remaining_Delay: NULL Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates Master_Retry_Count: 86400 Master_Bind: Last_IO_Error_Timestamp: Last_SQL_Error_Timestamp: Master_SSL_Crl: Master_SSL_Crlpath: Retrieved_Gtid_Set: Executed_Gtid_Set: Auto_Position: 0 Replicate_Rewrite_DB: Channel_Name: Master_TLS_Version: 1 row in set (0.00 sec)
好,到此结束,我们测试一下:
主库上创建一个库,如下:
mysql> create database hello; Query OK, 1 row affected (0.00 sec)
我们再看看从库,如下:
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| hello |
| mysql |
| performance_schema |
| sys |
+--------------------+
5 rows in set (0.00 sec)
好,ok了
另外就是配置文件的说明,可以单独同步某一个库甚至表,也可以不同步某一个库,如下:
#作为主机的配置
binlog-do-db=hello #要给从机同步的库
binlog-ignore-db=mysql #不给从机同步的库(多个写多行)
- 安卓客户端下载
- 微信扫一扫
- 微信公众号
- 微信公众号扫一扫