給女朋友講講mysql的主從搭建

一、安裝mysql

官網(wǎng)下載:https://dev.mysql.com/downloads/mysql/
可選擇要安裝的版本,本次使用的是mysql5.7版本
準(zhǔn)備兩臺(tái)主機(jī)

10.27.3.123(主節(jié)點(diǎn))
10.27.3.124(從節(jié)點(diǎn))

1.解壓安裝包并移動(dòng)至指定位置

tar -zxvf mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz

mv mysql-5.7.28-linux-glibc2.12-x86_64 /usr/local/mysql

2.添加mysql用戶并賦予權(quán)限

# 添加用戶組
groupadd mysql
# 添加mysql用戶
useradd -r -g mysql mysql
# 進(jìn)入mysql目錄
cd /usr/local/mysql/
# 賦予mysql用戶權(quán)限
chown -R mysql:mysql ./

3.配置mysql
將mysql/support-files下的mysql.server 復(fù)制到 /etc/init.d/下并自定義為mysql

cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql

修改該服務(wù)

vim /etc/init.d/mysql

需要修改的內(nèi)容

basedir=/usr/local/mysql
datadir=/usr/local/mysql/data

配置mysql的my.cnf配置文件

vim /etc/my.cnf

修改配置內(nèi)容如下

[mysqld]
datadir=/usr/local/mysql/data
basedir=/usr/local/mysql
port=3306
character-set-server=utf8
# 不區(qū)分大小寫
lower_case_table_names=1
default_storage_engine=InnoDB
socket=/var/lib/mysql/mysql.sock
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
# Settings user and group are ignored when systemd is used.
# If you need to run mysqld under a different user or group,
# customize your systemd unit file for mariadb according to the
# instructions in http://fedoraproject.org/wiki/Systemd

[mysqld_safe]
log-error=/var/log/mysql/mysql.log
pid-file=/var/run/mysql/mysql.pid
#
# include all files from the config directory
#
!includedir /etc/my.cnf.d

4.初始化數(shù)據(jù)庫

cd /usr/local/mysql/bin

./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

初始化完成會(huì)生成默認(rèn)的密碼在執(zhí)行記錄中,注意復(fù)制出來

image.png

5.啟動(dòng)mysql服務(wù)

service mysql start

可能會(huì)報(bào)錯(cuò)

[root@localhost bin]# service mysql start
Starting MySQL.Logging to '/var/log/mysql/mysql.log'.
2021-07-09T02:57:23.974548Z mysqld_safe Directory '/var/lib/mysql' for UNIX socket file don't exists.
 ERROR! The server quit without updating PID file (/usr/local/mysql/data/localhost.localdomain.pid).

提示很明顯,我們配置的路徑不存在,創(chuàng)建對應(yīng)的文件夾目錄并賦予mysql用戶權(quán)限

mkdir /var/log/mysql

chown -R mysql /var/log/mysql/

重新啟動(dòng)mysql服務(wù)

[root@localhost bin]# service mysql start
Starting MySQL. SUCCESS! 

查看mysql服務(wù)狀態(tài)

[root@localhost var]# service mysql status
 SUCCESS! MySQL running (14369)

6.登錄mysql 并修改默認(rèn)密碼
需要用到我們剛剛初始化數(shù)據(jù)庫生成的密碼

[root@localhost var]# mysql -uroot -p
-bash: mysql: command not found

如果提示命令不存在,建立軟連接

ln -s /usr/local/mysql/bin/mysql /usr/bin

再次執(zhí)行登錄

[root@localhost var]# mysql -uroot -p
Enter password: 
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

發(fā)現(xiàn)了一個(gè)熟悉的東西,mysql.sock,連接localhost通常通過一個(gè)Unix域套接字文件進(jìn)行,一般是/tmp/mysql.sock
查看本機(jī)是否有mysql.sock

[root@localhost var]# find / -name mysql.sock
/var/lib/mysql/mysql.sock

建立軟連接

ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock

再次登錄,成功!

[root@localhost var]# mysql -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.28

Copyright (c) 2000, 2019, 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>

修改密碼

mysql> set password=password('123456');
Query OK, 0 rows affected, 1 warning (0.00 sec)

配置mysql開機(jī)自啟

[root@localhost var]# chmod 755 /etc/init.d/mysql
[root@localhost var]# chkconfig --add mysql
[root@localhost var]# chkconfig --level 345 mysql on

開啟mysql遠(yuǎn)程訪問,否則無法遠(yuǎn)程連接mysql

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root用戶的密碼,自行修改';

flush privileges;

至此mysql安裝完成,兩臺(tái)機(jī)器都需要安裝!

二、主從搭建

搭建兩臺(tái)MySQL服務(wù)器(一主一從),一臺(tái)作為主服務(wù)器,一臺(tái)作為從服務(wù)器,主服務(wù)器進(jìn)行寫操作,從服務(wù)器進(jìn)行讀操作。
1.配置master節(jié)點(diǎn)
修改my.cnf配置文件

vim /etc/my.cnf

在[mysqld]中添加如下配置

# 要給從機(jī)同步的庫(如果不寫,默認(rèn)全部同步,可不配置)
binlog-do-db=db01
# 不給從機(jī)同步的庫(多個(gè)寫多行,可不配置)
binlog-ignore-db=mysql
binlog-ignore-db=information_schema
binlog-ignore-db=performance_schema
binlog-ignore-db=sys
# 自動(dòng)清理 7 天前的log文件,可根據(jù)需要修改(可不配置)
expire_logs_days=7
# 啟用二進(jìn)制日志
log-bin=master-bin
# 服務(wù)器唯一ID,一般取IP最后一段
server-id=123
# 指定索引文件的位置
log_bin_index=master-bin.index

配置修改完后重啟主節(jié)點(diǎn)

2.配置slave節(jié)點(diǎn)
修改my.cnf配置文件

vim /etc/my.cnf

在[mysqld]中添加如下配置

# 服務(wù)器唯一id
server-id=124
#加上以下參數(shù)可以避免更新不及時(shí),SLAVE 重啟后導(dǎo)致的主從復(fù)制出錯(cuò)
read_only=1
master_info_repository=TABLE
relay_log_info_repository=TABLE
relay-log = slave-relay-bin
#主服務(wù)器I/O日志讀取、記錄及存放
relay-log-index = slave-relay-bin.index

配置修改完后重啟從節(jié)點(diǎn)

3.加入主節(jié)點(diǎn)
在主節(jié)點(diǎn)機(jī)器上登錄mysql,查看狀態(tài)

mysql> show master status;
+-------------------+----------+--------------+------------------+-------------------+
| File              | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------+----------+--------------+------------------+-------------------+
| master-bin.000001 |      154 |              |                  |                   |
+-------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

這里查看到的信息即是主服務(wù)器準(zhǔn)許接入的信息,我們要在從服務(wù)器MySQL語句中執(zhí)行接入語句需要用到主服務(wù)器允許接入?yún)?shù),這里的fileposition非常重要。

接下來在slave從節(jié)點(diǎn)上執(zhí)行下述命令,命令解釋如下

change master to master_host='主服務(wù)器ip地址',
master_port=3306,master_user='鏈接主服務(wù)器賬戶',
master_password='鏈接主服務(wù)器角色賬戶密碼',
master_log_file='主服務(wù)器file參數(shù)',
master_log_pos=主服務(wù)器positon參數(shù)

mysql> change master to master_host='10.27.3.123',master_port=3306,master_user='root',master_password='hatech1618!@#',master_log_file='master-bin.000001',master_log_pos=154;
Query OK, 0 rows affected, 2 warnings (0.01 sec)

啟動(dòng)slave從節(jié)點(diǎn)

start slave;

查看從節(jié)點(diǎn)狀態(tài)

show slave status\G
image.png

代表slave從節(jié)點(diǎn)運(yùn)行正常,主從復(fù)制搭建完畢。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容