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

本文目錄一覽:

一台linux服務器怎麼安裝多個mysql數據庫並配置主從

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

2、yum安裝lrzsz和cmake

yum -y install lrzsz;

yum -y install cmake;

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

Linux下指定mysql數據庫數據配置主主同步的實例

一、

概念:

數據庫同步

(主從同步

主數據庫寫的同時

往從服務器寫數據)

數據庫同步

(主主同步

兩台數據庫服務器互相寫數據)

二、

舉例

主主數據庫同步服務器配置

數據庫服務器(A)

主數據庫

IP:192.168.1.134

數據庫服務器(B)

主數據庫

IP:192.168.1.138

兩台服務器同步的用戶名為:

bravedu

密碼:

brave123

一、主數據庫操作設置(A):

創建同步用戶名

允許連接的

用戶IP地址

(非本機IP)

複製代碼

代碼如下:

grant

replication

slave

on

*.*

to

‘bravedu’@’192.168.1.%’

identified

by

‘brave123’;

flush

privileges;

更改mysql配置文件

複製代碼

代碼如下:

[mysqld]

server-id

=

1

log-bin=/www/mysql/binlog/binlog

(路徑要根據自己的安裝設置)

binlog-do-db

=

dbname

(要同步的數據庫名)

binlog-ignore-db=mysql

#相對應主從數據庫同步不同的地方

複製代碼

代碼如下:

log-slave-updates

sync_binlog=1

auto_increment_offset=1

auto_increment_increment=2

replicate-do-db

=

dbname

replicate-ignore-db

=

mysql,information_schema

重啟mysql服務器

查看主數據庫同步狀態

IP:

***.134

複製代碼

代碼如下:

mysqlflush

tables

with

read

lock;

mysqlshow

master

status\G

***************************

1.

row

***************************

File:

mysql-bin.000001

(這裡注意

設置從服務器的時候要用)

Position:

106

(這裡注意設置從服務器的時候要用)

Binlog_Do_DB:

dbname

Binlog_Ignore_DB:

mysql

1

row

in

set

(0.00

sec)

mysqlunlock

tables;

*****主服務器到目前位置設置完畢*******

二、從數據庫操作設置(B):

創建同步用戶名

複製代碼

代碼如下:

grant

replication

slave

on

*.*

to

‘bravedu’@’192.168.1.%’

identified

by

‘brave123’;

flush

privileges;

更改mysql配置文件

複製代碼

代碼如下:

[mysqld]

server-id

=

2

log-bin=/www/mysql/binlog/binlog

(路徑要根據自己的安裝設置)

binlog-do-db

=

dbname

(要同步的數據庫名)

binlog-ignore-db=

mysql,information_schema

#相對於主從同步不同的地方

binlog-do-db

=

dbname

binlog-ignore-db=mysql

log-slave-updates

sync_binlog=1

auto_increment_offset=2

auto_increment_increment=2

重啟mysql服務器

查看主數據庫同步狀態

IP:

***.138

複製代碼

代碼如下:

mysqlflush

tables

with

read

lock;

mysqlshow

master

status\G

***************************

1.

row

***************************

File:

mysql-bin.000005

(這裡注意

設置從服務器的時候要用)

Position:

106

(這裡注意設置從服務器的時候要用)

Binlog_Do_DB:

dbname

Binlog_Ignore_DB:

mysql

1

row

in

set

(0.00

sec)

mysqlunlock

tables;

指定主主數據庫服務器同步指令

註:IP為主服務器的IP,用戶名,密碼,log_file,log_post

服務器互相統一

可能這塊操作

需要先

解除鎖表、停止數據庫狀態、在運行後

在啟動狀態

複製代碼

代碼如下:

mysql

stop

slave;

#設置192.168.1.138數據庫服務器配置

那麼host

配置文件信息

就是

134的信息

mysql

change

master

to

master_host=’192.168.1.134′,

master_user=’bravedu’,

master_password=’brave123′,

master_log_file=’mysql-bin.000005′,

master_log_pos=106;

#設置192.168.1.134

數據庫服務器配置

那麼host

等配置文件信息

就是

134的信息

mysql

change

master

to

master_host=’192.168.1.138′,

master_user=’bravedu’,

master_password=’brave123′,

master_log_file=’mysql-bin.000001′,

master_log_pos=106;

mysql

start

slave;

mysql

unlock

tables;

查看主數據庫同步狀態

會出來很多信息

但是主要看這兩個狀態就行了

如果都是

yes

就可以了

複製代碼

代碼如下:

mysqlshow

slave

status\G;

Slave_IO_Running:

Yes

Slave_SQL_Running:

Yes

至此,主主數據庫同步成功配置完成。

如何設置mysql主從同步時間間隔 linux

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庫上導入新的數據即可。

如何設置linux系統服務器的slave master

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 命令看日誌情況

如何在linux下安裝mysql數據庫並配置

在linux下安裝mysql數據庫並配置的流程比較繁瑣,需要耐心調試,具體方法和步驟如下:

1.查找以前是否安裝有mysql,使用下面命令:

rpm -qa|grep -i mysql

如果顯示有如下包則說明已安裝mysql

mysql-4.1.12-3.RHEL4.1

mysqlclient10-3.23.58-4.RHEL4.1

2.如果已安裝,則需要刪除已安裝的數據庫,使用以下命令來刪除數據庫

刪除命令:rpm -e –nodeps 包名

( rpm -ev mysql-4.1.12-3.RHEL4.1 )

刪除老版本mysql的開發頭文件和庫

命令:rm -fr /usr/lib/mysql

rm -fr /usr/include/mysql

注意:卸載後/var/lib/mysql中的數據及/etc/my.cnf不會刪除,如果確定沒用後就手工刪除

rm -f /etc/my.cnf

rm -fr /var/lib/mysql

3.下載mysql的rpm包

可以通過wget下載具體的地址因為不能用鏈接請大家去官網去找

(1)MySQL-server-5.6.10-1.rhel5.x86_64.rpm:MySQL服務器;

(2)MySQL-client-5.6.10-1.rhel5.x86_64.rpm:MySQL客戶端;

(3)MySQL-devel-5.6.10-1.rhel5.x86_64.rpm:Mysql開發依賴包。

下載後放到Liunx服務器中。

4.安裝MySQL Server的rpm包

rpm -ivh MySQL-server-5.6.21-1.linux_glibc2.5.x86_64.rpm

安裝完成後會生成root用戶的隨機密碼,請使用「cat /root/.mysql_secret」或類似命令進行查看。

5.安裝MySQL客戶端

rpm -ivh MySQL-client-5.6.21-1.linux_glibc2.5.x86_64.rpm

6.安裝MySQL開發依賴包

rpm -ivh MySQL-devel-5.6.21-1.linux_glibc2.5.x86_64.rpm

7.啟動msyql

安裝完成後mysql是沒有啟動的,運行mysql命令會提示如下錯誤:

ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’ (2)

可使用如下命令啟動MySQL:

service mysql start

或者使用如下命令:

/etc/init.d/mysql start

可使用SET PASSWORD命令修改root用戶的密碼,參考如下:SET PASSWORD = PASSWORD(‘root123456’);

8.登錄MySQL

使用mysql命令登錄MySQL服務器,運行MySQL的命令時,會提示需要設置root用戶密碼。

9.設置開機自啟動

/etc/init.d/mysql start

設置完成後重啟系統,使用natstat –nat命令可看到MySQL的3306端口。

10.至此已經安裝好了mysql數據庫,當然現在我們的數據庫還不支持遠程連接,遠程連接會出現以下代碼:1130,ERROR 1130: Host 192.168.0.10 is not allowed to connect to this MySQL server,可以通過以下以下來解決。

11.改表法:在本機登入mysql後,更改「mysql」數據庫里的「user」表裡的「host」項,從」localhost」改為’%’。

mysql

mysqluse mysql;

mysqlselect ‘host’ from user where user=’root

12.到此為止,mysql數據庫在linux中安裝完畢。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/254915.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-15 12:14
下一篇 2024-12-15 12:14

相關推薦

  • 如何修改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

發表回復

登錄後才能評論