linux下配置mysql主從的簡單介紹

  • 1、linux mysql5.1.73怎麼做主從複製
  • 2、如何設置mysql主從同步時間間隔 linux
  • 3、一台linux服務器怎麼安裝多個mysql數據庫並配置主從

首先,我們大概羅列一下主從複製的基本步驟,(MySQL主從首先需要在各自服務器配置好)。1.複製數據庫。mysqldump–master-data–single-transaction-R–databases[db_name]|gzip-9-|pvall-db-with-master-data.sql.gz注意:innodb用–single-transaction,myisam需要用–lock-all-tables。2.複製,導入數據。pvnewdb.sql3.主服務器上,修改my.cnf文件,添加新庫到binlog-do-db參數,重啟mysql。4.在導出的newdb.sql裡面查找當前的日誌文件以及位置(changemasterto…)然後讓slave服務器執行到這個位置。startslaveuntilMASTER_LOG_FILE=”mysql-bin.000001″,MASTER_LOG_POS=1222220;其中MASTER_LOG_FILE以及MASTER_LOG_POS在導出的數據庫newdb.sql頂部位置查找。4.導入新庫到從服務器上。mysql

linux下配置mysql主從同步的步驟

一、主機環境

主機:

master操作系統:rhel6.0

IP:172.16.0.100

MySQL版本:5.1.47

從機:

slave操作系統:rhel6.0

IP:172.16.0.200

MySQL版本:5.1.47

二、創建數據庫

分別登錄master機和slave機的mysql:mysql –u root –p

創建數據庫:create database repl;

三、master機和slave機的相關配置

1、修改master機器中mysql配置文件my.cnf,該文件在/etc目錄下

在[mysqld]配置段添加如下字段

server-id=1

log-bin=mysql-bin

binlog-do-db=repl //需要同步的數據庫,如果沒有本行,即表示同步所有的數據庫

binlog-ignore-db=mysql //被忽略的數據庫

在master機上為slave機添加一同步帳號

grant replication slave on *.* to ‘replication’@’172.16.0.200’ identified by ‘123456’;

重啟master機的mysql服務:service mysqld restart

用show master status 命令看日誌情況

mysqlshow master status;

+—————–+————+——————-+———————–+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+—————–+————+——————-+———————–+

| log.000003 | 98 | repl | mysql |

+—————–+————+——————-+———————–+

1 row in set (0.00 sec)

2、修改slave機中mysql配置文件

同樣在[mysqld]字段下添加如下內容

server-id=2

master-host=172.16.0.100

master-user=repl

master-password=123456

master-port=3306

master-connect-retry=60

replicate-do-db=repl //同步的數據庫,不寫本行 表示 同步所有數據庫

然後重啟slave機的mysql

在slave機中進入mysql

mysqlstart slave;

mysqlshow slave status\G;

如果Slave_IO_Running、Slave_SQL_Running狀態為Yes則表明設置成功。

這時 再執行show slave status\G

顯示如下:

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.1.222

Master_User: repl

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: log.000003

Read_Master_Log_Pos: 98

Relay_Log_File: mysqld-relay-bin.000002

Relay_Log_Pos: 229

Relay_Master_Log_File: log.000003

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: 98

Relay_Log_Space: 229

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

1 row in set (0.00 sec)

Slave_IO_Running: Yes Slave_SQL_Running: Yes

信息中如上兩行都為Yes,說明配置成功。

五、測試主從服務器是否能同步

在主服務器上面新建一個表,必須在repl數據下

mysql use repl

Database changed

mysql create table test(id int,name char(10));

Query OK, 0 rows affected (0.00 sec)

mysql insert into test values(1,’zaq’);

Query OK, 1 row affected (0.00 sec)

mysql insert into test values(1,’xsw’);

Query OK, 1 row affected (0.00 sec)

mysql select * from test;

+——+——+

| id | name |

+——-+——+

| 1 | zaq |

| 1 | xsw |

+——-+——+

2 rows in set (0.00 sec)

在從服務器查看是否同步過來

mysql use repl;

Database changed

mysql select * from test;

+——+——+

| id | name |

+——+——+

| 1 | zaq |

| 1 | xsw |

+——+——+

2 rows in set (0.00 sec)

說明已經配置成功。

四、出現的問題

1. 當在執行start slave這條命令時,系統提示

ERROR 1200 (HY000): The server is not configured as slave; fix in config file or with CHANGE MASTER TO,

執行show slave status;又提示Empty set (0.00 sec)

原因:slave已經默認開啟,要先關閉再開啟

執行 slave stop;

再執行

change master to master_host=’172.16.0.200′,master_user=’repl’,master_password=’123456′, master_log_file=’log.000003′ ,master_log_pos=98;

2、出現錯誤提示 :Slave_IO_Running:NO

mysql的error日誌中信息:

Slave I/O: error connecting to master ‘replication@172.16.0.100:3306’ – retry-time: 60 retries: 86400, Error_code: 1045

解決方法

1.在主mysql中創建slave遠程連接訪問時候的登錄密碼一定要設置對。

2.停止slave上的mysqld服務,從服務器上刪除掉所有的二進制日誌文件,包括一個數據目錄下的master.info文件和hostname-relay-bin開頭的文件,然後啟動slave上的mysqld服務。

master.info::記錄了Mysql主服務器上的日誌文件和記錄位置、連接的密碼。

3.slave上Slave_SQL_Running: No ,提示某個表定義不正確

解決方法:

清空drop掉master和slave上的已經存在所有表,然後從master庫上導入新的數據即可。

1、關閉Liunx系統的防火牆,如果忘了,你下面的測試連接必定會失敗,切記,切記,切記。

2、yum安裝lrzsz和cmake

yum -y install lrzsz;

yum -y install cmake;

首先熟悉MySql數據庫,很多人都是直接安裝原生版的MySql數據庫(就是官網上下載的數據庫安裝包),也有人用的是MySql的衍生版數據庫,如percona,我用的就是這種,下面我會分別說明原生版和衍生版MySql數據庫的安裝和主從配置。

原創文章,作者:J4YAH,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/126633.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
J4YAH的頭像J4YAH
上一篇 2024-10-03 23:09
下一篇 2024-10-03 23:09

相關推薦

  • 如何修改mysql的端口號

    本文將介紹如何修改mysql的端口號,方便開發者根據實際需求配置對應端口號。 一、為什麼需要修改mysql端口號 默認情況下,mysql使用的端口號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • Python簡單數學計算

    本文將從多個方面介紹Python的簡單數學計算,包括基礎運算符、函數、庫以及實際應用場景。 一、基礎運算符 Python提供了基礎的算術運算符,包括加(+)、減(-)、乘(*)、除…

    編程 2025-04-29
  • Python滿天星代碼:讓編程變得更加簡單

    本文將從多個方面詳細闡述Python滿天星代碼,為大家介紹它的優點以及如何在編程中使用。無論是剛剛接觸編程還是資深程序員,都能從中獲得一定的收穫。 一、簡介 Python滿天星代碼…

    編程 2025-04-29
  • Python海龜代碼簡單畫圖

    本文將介紹如何使用Python的海龜庫進行簡單畫圖,並提供相關示例代碼。 一、基礎用法 使用Python的海龜庫,我們可以控制一個小海龜在窗口中移動,並利用它的“畫筆”在窗口中繪製…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL數據庫 在使用Python操作MySQL之前,我們需要先連接MySQL數據庫。在Python中,我…

    編程 2025-04-29
  • MySQL遞歸函數的用法

    本文將從多個方面對MySQL遞歸函數的用法做詳細的闡述,包括函數的定義、使用方法、示例及注意事項。 一、遞歸函數的定義 遞歸函數是指在函數內部調用自身的函數。MySQL提供了CRE…

    編程 2025-04-29
  • Python櫻花樹代碼簡單

    本文將對Python櫻花樹代碼進行詳細的闡述和講解,幫助讀者更好地理解該代碼的實現方法。 一、簡介 櫻花樹是一種圖形效果,它的實現方法比較簡單。Python中可以通過turtle這…

    編程 2025-04-28
  • MySQL bigint與long的區別

    本文將從數據類型定義、存儲空間、數據範圍、計算效率、應用場景五個方面詳細闡述MySQL bigint與long的區別。 一、數據類型定義 bigint在MySQL中是一種有符號的整…

    編程 2025-04-28
  • Python大神作品:讓編程變得更加簡單

    Python作為一種高級的解釋性編程語言,一直被廣泛地運用於各個領域,從Web開發、遊戲開發到人工智能,Python都扮演着重要的角色。Python的代碼簡潔明了,易於閱讀和維護,…

    編程 2025-04-28
  • MySQL左連接索引不生效問題解決

    在MySQL數據庫中,經常會使用左連接查詢操作,但是左連接查詢中索引不生效的情況也比較常見。本文將從多個方面探討MySQL左連接索引不生效問題,並給出相應的解決方法。 一、索引的作…

    編程 2025-04-28

發表回復

登錄後才能評論