欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

包含mysql怎么實(shí)現(xiàn)同步的詞條

如何設(shè)置MySQL同步

如何設(shè)置MySQL同步

成都創(chuàng)新互聯(lián)專注于成都網(wǎng)站建設(shè)、網(wǎng)站制作、網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站制作、網(wǎng)站開(kāi)發(fā)。公司秉持“客戶至上,用心服務(wù)”的宗旨,從客戶的利益和觀點(diǎn)出發(fā),讓客戶在網(wǎng)絡(luò)營(yíng)銷中找到自己的駐足之地。尊重和關(guān)懷每一位客戶,用嚴(yán)謹(jǐn)?shù)膽B(tài)度對(duì)待客戶,用專業(yè)的服務(wù)創(chuàng)造價(jià)值,成為客戶值得信賴的朋友,為客戶解除后顧之憂。

具體配置

1. 在主服務(wù)器上為從服務(wù)器建立一個(gè)用戶:

grant replication slave on *.* to '用戶名'@'主機(jī)' identified by '密碼'; (在MySQL 4.0.2以前,用 FILE 權(quán)限來(lái)代替 REPLICATION SLAVE)

如果打算在slave上執(zhí)行 LOAD TABLE FROM MASTER 或 LOAD DATA FROM MASTER 語(yǔ)句,那么必須給該帳戶授予附加權(quán)限:

授予全局 SUPER 和 RELOAD 權(quán)限。

授予對(duì)想要加載的所有表上的 SELECT 權(quán)限。在master上任何沒(méi)有 SELECT 權(quán)限的表都會(huì)被 LOAD DATA FROM MASTER 略過(guò)。

2. 編輯主服務(wù)器的配置文件:/etc/my.cnf

server-id = 1

log-bin

binlog-do-db=需要備份的數(shù)據(jù)庫(kù)名,如果備份多個(gè)數(shù)據(jù)庫(kù),重復(fù)設(shè)置這個(gè)選項(xiàng)即可

binlog-ignore-db=不需要備份的數(shù)據(jù)庫(kù)苦命,如果備份多個(gè)數(shù)據(jù)庫(kù),重復(fù)設(shè)置這個(gè)選項(xiàng)即可

3. 編輯從服務(wù)器的配置文件:/etc/my.cnf

server-id=2 (配置多個(gè)從服務(wù)器時(shí)依次設(shè)置id號(hào))

master-host=主機(jī)

master-user=用戶名

master-password=密碼

master-port=端口

replicate-do-db=需要備份的數(shù)據(jù)庫(kù)名,如果備份多個(gè)數(shù)據(jù)庫(kù),重復(fù)設(shè)置這個(gè)選項(xiàng)即可

記得先手動(dòng)同步一下主從服務(wù)器中要備份的數(shù)據(jù)庫(kù),然后重啟主,從服務(wù)器。

要驗(yàn)證主從設(shè)置是否已經(jīng)成功,可以登錄從服務(wù)器輸入如下命令:

mysql show slave statusG

得到的列表會(huì)有類似下面的數(shù)據(jù):

Slave_IO_State: Waiting for master to send event

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

如果后面兩個(gè)選項(xiàng)不全是Yes,那就說(shuō)明你前面某個(gè)步驟配置錯(cuò)了。

如果你的設(shè)置是正確的,嘗試在主服務(wù)器上插入若干條記錄,然后你再轉(zhuǎn)到從服務(wù)器,會(huì)發(fā)現(xiàn)相應(yīng)的新記錄已經(jīng)自動(dòng)同步過(guò)來(lái)了。

如果你的主從服務(wù)器已經(jīng)配置好了,那么你在應(yīng)用程序中,只要保證所有的insert/delete/update操作是在主服務(wù)器上進(jìn)行的,那么相應(yīng)的數(shù)據(jù)變化會(huì)自動(dòng)同步到從服務(wù)器上,這樣,我們就可以把select操作分擔(dān)到多臺(tái)從數(shù)據(jù)庫(kù)上,從而降低服務(wù)器的載荷。

如果你想使用復(fù)制數(shù)據(jù)文件的方式來(lái)備份數(shù)據(jù)庫(kù),只要在從服務(wù)器上的mysql命令行先鍵入slave stop;然后復(fù)制數(shù)據(jù)庫(kù)文件,復(fù)制好了,再在mysql命令行鍵入slave start;啟動(dòng)從服務(wù)器,這樣就即備份了數(shù)據(jù)有保證了數(shù)據(jù)完整性,而且整個(gè)過(guò)程中主服務(wù)器的mysql無(wú)需停止。

-----------------------------------------------------------------------------------

提示:如果修改了主服務(wù)器的配置,記得刪除從服務(wù)器上的master.info文件。否則從服務(wù)器使用的還是老配置,可能會(huì)導(dǎo)致錯(cuò)誤。

-----------------------------------------------------------------------------------

注意:關(guān)于要復(fù)制多個(gè)數(shù)據(jù)庫(kù)時(shí),binlog-do-db和replicate-do-db選項(xiàng)的設(shè)置,如果要備份多個(gè)數(shù)據(jù)庫(kù),只要重復(fù)設(shè)置相應(yīng)選項(xiàng)就可以了。

比如:

binlog-do-db=a

binlog-do-db=b

replicate-do-db=a

replicate-do-db=b

-----------------------------------------------------------------------------------

補(bǔ)充:

在從服務(wù)器上使用show slave status

Slave_IO_Running,為No,則說(shuō)明IO_THREAD沒(méi)有啟動(dòng),請(qǐng)執(zhí)行slave start [IO_THREAD]

Slave_SQL_Running為No則復(fù)制出錯(cuò),查看Last_error字段排除錯(cuò)誤后執(zhí)行slave start [SQL_THREAD]

查看Slave_IO_State字段

空 //復(fù)制沒(méi)有啟動(dòng)

Connecting to master//沒(méi)有連接上master

Waiting for master to send event//已經(jīng)連上

補(bǔ)充:可以使用LOAD DATA FROM MASTER語(yǔ)句來(lái)建立slave。但有約束條件:

數(shù)據(jù)表要全部是MyISAM表,必須有SUPER權(quán)限,master的復(fù)制用戶必須具備RELOAD和SUPER權(quán)限。

在master端執(zhí)行RESET MASTER清除已有的日志變更,

此時(shí)slave端會(huì)因?yàn)檎也坏絤aster日志無(wú)法啟動(dòng)IO_THREAD,請(qǐng)清空data目錄下

relay-log.info,hosname-relay-bin*等文件重新啟動(dòng)mysql

中繼日志文件默認(rèn)的文件為hostname-relay-bin.nnn和hostname-relay-bin.index??捎脧姆?wù)器的--

relay-log和--relay-log-index選項(xiàng)修改。在從服務(wù)器中還有一個(gè)relay-log.info中繼信息文件,可用

--relay-log-info-file啟動(dòng)選項(xiàng)修改文件名。

雙機(jī)互備則是兩個(gè)mysql同時(shí)配置為master及slave

主服務(wù)器上的相關(guān)命令:

show master status

show slave hosts

show logs

show binlog events

purge logs to 'log_name'

purge logs before 'date'

reset master(老版本flush master)

set sql_log_bin=

從服務(wù)器上的相關(guān)命令:

slave start

slave stop

SLAVE STOP IO_THREAD //此線程把master段的日志寫到本地

SLAVE start IO_THREAD

SLAVE STOP SQL_THREAD //此線程把寫到本地的日志應(yīng)用于數(shù)據(jù)庫(kù)

SLAVE start SQL_THREAD

reset slave

SET GLOBAL SQL_SLAVE_SKIP_COUNTER

load data from master

show slave status(SUPER,REPLICATION CLIENT)

CHANGE MASTER TO MASTER_HOST=, MASTER_PORT=,MASTER_USER=, MASTER_PASSWORD= //動(dòng)態(tài)改變master信息

PURGE MASTER [before 'date'] 刪除master端已同步過(guò)的日志

怎么實(shí)現(xiàn)兩臺(tái)服務(wù)器的mysql數(shù)據(jù)同步

這種架構(gòu)一般用在以下三類場(chǎng)景

1. 備份多臺(tái) Server 的數(shù)據(jù)到一臺(tái)如果按照數(shù)據(jù)切分方向來(lái)講,那就是垂直切分。比如圖 2,業(yè)務(wù) A、B、C、D 是之前拆分好的業(yè)務(wù),現(xiàn)在需要把這些拆分好的業(yè)務(wù)匯總起來(lái)備份,那這種需求也很適用于多源復(fù)制架構(gòu)。實(shí)現(xiàn)方法我大概描述下:業(yè)務(wù) A、B、C、D 分別位于 4 臺(tái) Server,每臺(tái) Server 分別有一個(gè)數(shù)據(jù)庫(kù)來(lái)隔離前端的業(yè)務(wù)數(shù)據(jù),那這樣,在從庫(kù)就能把四臺(tái)業(yè)務(wù)的數(shù)據(jù)全部匯總起來(lái),而不需要做額外的操作。那沒(méi)有多源復(fù)制之前,要實(shí)現(xiàn)這類需求,只能在匯總機(jī)器上搭建多個(gè) MySQL 實(shí)例,那這樣勢(shì)必會(huì)涉及到跨庫(kù)關(guān)聯(lián)的問(wèn)題,不但性能急劇下降,管理多個(gè)實(shí)例也沒(méi)有單臺(tái)來(lái)的容易。

2. 用來(lái)聚合前端多個(gè) Server 的分片數(shù)據(jù)。

同樣,按照數(shù)據(jù)切分方向來(lái)講,屬于水平切分。比如圖 3,按照年份拆分好的數(shù)據(jù),要做一個(gè)匯總數(shù)據(jù)展現(xiàn),那這種架構(gòu)也非常合適。實(shí)現(xiàn)方法稍微復(fù)雜些:比如所有 Server 共享同一數(shù)據(jù)庫(kù)和表,一般為了開(kāi)發(fā)極端透明,前端配置有分庫(kù)分表的中間件,比如愛(ài)可生的 DBLE。

3. 匯總并合并多個(gè) Server 的數(shù)據(jù)

第三類和第一種場(chǎng)景類似。不一樣的是不僅僅是數(shù)據(jù)需要匯總到目標(biāo)端,還得合并這些數(shù)據(jù),這就比第一種來(lái)的相對(duì)復(fù)雜些。比如圖 4,那這樣的需求,是不是也適合多源復(fù)制呢?答案是 YES。那具體怎么做呢?

怎么使Mysql數(shù)據(jù)同步

先假設(shè)有主機(jī) A 和 B ( Linux 系統(tǒng)),主機(jī) A 的 IP 分別是 1.2.3.4 (當(dāng)然,也可以是動(dòng)態(tài)的),主機(jī) B 的 IP 是 5.6.7.8 。兩個(gè)主機(jī)都裝上了 PHP+Mysql ,現(xiàn)在操作的是主機(jī) A 上的資料,如果另外一個(gè)主機(jī) B 想跟 A 的資料進(jìn)行同步,應(yīng)該怎么做呢?

OK,我們現(xiàn)在就動(dòng)手。

首先,如果要想兩個(gè)主機(jī)間的資料同步,一種方法就是主機(jī) A 往主機(jī) B 送資料,另外一種主法就是主機(jī) B 到主機(jī) A 上拿資料,因?yàn)?A 的 IP 是動(dòng)態(tài)的(假設(shè)),所以我們就得從主機(jī) A 往主機(jī) B 送資料。

在主機(jī) B 上創(chuàng)建一個(gè) Mysql 賬戶。

# GRANT ALL ON test.* TO user@% IDENTIFIED BY "password"; //創(chuàng)建用戶 user,可以從任何機(jī)器訪問(wèn)到主機(jī) B 上的 test 數(shù)據(jù)庫(kù)。

如果這里顯示錯(cuò)誤,先把 % 改為一個(gè) IP ,然后再利用 phpMyAdmin 把 IP 改為 % ,測(cè)試無(wú)誤后就可以寫 php 程序。

?

$link=mysql_pconnect("localhost","user","password");

mysql_pconnect("localhost","user","password"); //連接本機(jī)(主機(jī)A)的數(shù)據(jù)庫(kù)

mysql_select_db("test"); //選擇數(shù)據(jù)庫(kù)test

$re=mysql_query("select * from table order by id desc");

$num=mysql_numrows($re);

if (!empty($num)) {

$id=mysql_result($re,0,"id"); //獲得本機(jī)table表的最大ID

}

mysql_close($link); //關(guān)閉與本機(jī)數(shù)據(jù)庫(kù)的連接

$link=mysql_pconnect("5.6.7.8","test","test");

mysql_pconnect("5.6.7.8","test","test"); //連接主機(jī)B的數(shù)據(jù)庫(kù)

mysql_select_db("test"); //選擇數(shù)據(jù)庫(kù)test,此數(shù)據(jù)庫(kù)應(yīng)該與主機(jī)A上test數(shù)據(jù)庫(kù)的結(jié)構(gòu)一樣。

$re=mysql_query("select * from table order by id desc");

$num=mysql_numrows($re);

if (!empty($num)) {

$remote_id=mysql_result($re,0,"id"); //獲得主機(jī)Btable表的最大ID

}

if ($id$remote_id) {

$result_id=$id-$remote_id; //如果主機(jī)A中table的最大ID大于主機(jī)B中table表的最大ID,說(shuō)明兩個(gè)

} 的資料不同

mysql_close($link); //關(guān)閉主機(jī)B的數(shù)據(jù)庫(kù)連接

$link=mysql_pconnect("localhost","user","password");

mysql_pconnect("localhost","user","password");

mysql_select_db("test");

if (empty($result_id)) $result_id=0;

if (empty($remote_id)) $remote_id=0; //如果主機(jī)B中的table的最大ID為空(里面沒(méi)有資料),那么就等0

$re=mysql_query("select * from table limit $remote_id,$result_id"); //取出主機(jī)A中table表與主機(jī)B中table表里不同的資料

$num=mysql_numrows($re);

if (!empty($num)) {

for ($i=0;$i$num;$i++) {

$test[$i]=mysql_result($re,$i,"test"); //把不同的資料放入一個(gè)數(shù)組里

}

}

mysql_close($link); //關(guān)閉主機(jī)A的數(shù)據(jù)庫(kù)連接

$link=mysql_pconnect("5.6.7.8","user","password");

mysql_pconnect("5.6.7.8","user","pasword");

mysql_select_db("test");

for ($j=0;$j$i;$j++) { //這里的i等于在比較主機(jī)A與主機(jī)B上table表不同資料的數(shù)量

mysql_query("insert into table (test) values(\'$test[$j]\')");

}

mysql_close($link); //關(guān)閉主機(jī)B的數(shù)據(jù)庫(kù)連接

?

這時(shí)就初步實(shí)現(xiàn)了 A 主機(jī)和 B 主機(jī)數(shù)據(jù)的同步,但現(xiàn)在還需要人手動(dòng)每次去激活這個(gè)程序,有沒(méi)有辦法把它作為一個(gè)腳本一樣的,放在 crontab 里面指定時(shí)間自動(dòng)執(zhí)行呢?

在安裝 php 時(shí)會(huì)自動(dòng)生一個(gè)叫 php 的可執(zhí)行文件,一般在/你安裝的 php 目錄 /bin 下面,不過(guò)較底的版本好像沒(méi)有,如果沒(méi)有這個(gè)文件,你就得升級(jí)你的 php 。

#php -q test.php

php 原本是應(yīng)用在網(wǎng)頁(yè)應(yīng)用的﹐因此它會(huì)送出 HTML 的 Header﹐但是在此我們是要將 php 用作 Shell Script﹐"-q" 就是表示不要送出 Header 的意思.

最后編輯 /etc/crontab 里的文件,加上下面這一句。

0 0 * * * root /home/httpd/html/test //每天晚上零點(diǎn)執(zhí)/home/httpd/html/test文件(具體使用方法請(qǐng)查看cron的相關(guān)資料)

OK,到這里差不多就已完成 Mysql 數(shù)據(jù)的同步了,如果各位還有興趣的話,可以想一個(gè)連編輯、刪除都能同步的更好的辦法。

如何對(duì)MySQL數(shù)據(jù)庫(kù)中的數(shù)據(jù)進(jìn)行實(shí)時(shí)同步

如何對(duì)MySQL數(shù)據(jù)庫(kù)中的數(shù)據(jù)進(jìn)行實(shí)時(shí)同步

實(shí)現(xiàn)兩個(gè)Mysql數(shù)據(jù)庫(kù)之間同步同步原理:

MySQL 為了實(shí)現(xiàn)replication 必須打開(kāi)bin-log 項(xiàng),也是打開(kāi)二進(jìn)制的MySQL 日志記錄選項(xiàng)。MySQL 的bin log 二

進(jìn)制日志,可以記錄所有影響到數(shù)據(jù)庫(kù)表中存儲(chǔ)記錄內(nèi)容的sql 操作,如insert / update / delete 操作,而不記錄

select 這樣的操作。因此,我們可以通過(guò)二進(jìn)制日志把某一時(shí)間段內(nèi)丟失的數(shù)據(jù)可以恢復(fù)到數(shù)據(jù)庫(kù)中(如果二進(jìn)制日

志中記錄的日志項(xiàng),包涵數(shù)據(jù)庫(kù)表中所有數(shù)據(jù),那么, 就可以恢復(fù)本地?cái)?shù)據(jù)庫(kù)的全部數(shù)據(jù)了)。 而這個(gè)二進(jìn)制日志,

如果用作遠(yuǎn)程數(shù)據(jù)庫(kù)恢復(fù),那就是replication 了。這就是使用replication 而不用sync 的原因。這也是為什么要設(shè)

置bin-log = 這個(gè)選項(xiàng)的原因。

請(qǐng)教MySQL怎樣實(shí)現(xiàn)雙向同步

實(shí)現(xiàn)兩個(gè)Mysql數(shù)據(jù)庫(kù)之間同步同步原理:

MySQL 為了實(shí)現(xiàn)replication 必須打開(kāi)bin-log 項(xiàng),也是打開(kāi)二進(jìn)制的MySQL 日志記錄選項(xiàng)。MySQL 的bin log 二

進(jìn)制日志,可以記錄所有影響到數(shù)據(jù)庫(kù)表中存儲(chǔ)記錄內(nèi)容的sql 操作,如insert / update / delete 操作,而不記錄

select 這樣的操作。因此,我們可以通過(guò)二進(jìn)制日志把某一時(shí)間段內(nèi)丟失的數(shù)據(jù)可以恢復(fù)到數(shù)據(jù)庫(kù)中(如果二進(jìn)制日

志中記錄的日志項(xiàng),包涵數(shù)據(jù)庫(kù)表中所有數(shù)據(jù),那么, 就可以恢復(fù)本地?cái)?shù)據(jù)庫(kù)的全部數(shù)據(jù)了)。 而這個(gè)二進(jìn)制日志,

如果用作遠(yuǎn)程數(shù)據(jù)庫(kù)恢復(fù),那就是replication 了。這就是使用replication 而不用sync 的原因。這也是為什么要設(shè)

置bin-log = 這個(gè)選項(xiàng)的原因。

在同步過(guò)程中,最重要的同步參照物,就是同步使用那一個(gè)二進(jìn)制日志文件,從那一條記錄開(kāi)始同步。下面就介紹

下怎樣實(shí)現(xiàn)兩個(gè)Mysql數(shù)據(jù)庫(kù)之間的主從同步。

一、 概述

MySQL從3.23.15版本以后提供數(shù)據(jù)庫(kù)復(fù)制(replication)功能,利用該功能可以實(shí)現(xiàn)兩個(gè)數(shù)據(jù)庫(kù)同步、主從模式、

互相備份模式的功能。本文檔主要闡述了如何在linux系統(tǒng)中利用mysql的replication進(jìn)行雙機(jī)熱備的配置。

二、 環(huán)境

操作系統(tǒng):Linux 2.6.23.1-42.fc8 # SMP(不安裝XEN)

Mysql版本:5.0.45-4.fc8

設(shè)備環(huán)境:PC(或者虛擬機(jī))兩臺(tái)

三、 配置

數(shù)據(jù)庫(kù)同步復(fù)制功能的設(shè)置都在MySQL的配置文件中體現(xiàn),MySQL的配置文件(一般是my.cnf):在本環(huán)境下

為/etc/my.cnf。

3.1 設(shè)置環(huán)境:

IP的設(shè)置:

A主機(jī) IP:10.10.0.119

Mask:255.255.0.0

B主機(jī) IP:10.10.8.112

Mask:255.255.0.0

在IP設(shè)置完成以后,需要確定兩主機(jī)的防火墻確實(shí)已經(jīng)關(guān)閉??梢允褂妹顂ervice iptables status查看防火墻狀態(tài)

。如果防火墻狀態(tài)為仍在運(yùn)行。使用service iptables stop來(lái)停用防火墻。如果想啟動(dòng)關(guān)閉防火墻,可以使用setup命

令來(lái)禁用或定制。

最終以兩臺(tái)主機(jī)可以相互ping通為佳。

3.2 配置A主(master) B從(slave)模式

3.2.1 配置A 為master

1、增加一個(gè)用戶同步使用的帳號(hào):

GRANT FILE ON *.* TO ‘backup’@'10.10.8.112' IDENTIFIED BY ‘1234’;

GRANTREPLICATION SLAVE ON *.* TO ‘backup’@'10.10.8.112' IDENTIFIED BY ‘1234’;

賦予10.10.8.112也就是Slave機(jī)器有File權(quán)限,只賦予Slave機(jī)器有File權(quán)限還不行,還要給它REPLICATION SLAVE的權(quán)

限才可以。

2、增加一個(gè)數(shù)據(jù)庫(kù)作為同步數(shù)據(jù)庫(kù):

create databbse test;

3、創(chuàng)建一個(gè)表結(jié)構(gòu):

create table mytest (username varchar(20),password varchar(20));

4、修改配置文件:

修改A的/etc/my.cnf文件,在my.cnf配置項(xiàng)中加入下面配置:

server-id = 1 #Server標(biāo)識(shí)

log-bin

binlog-do-db=test #指定需要日志的數(shù)據(jù)庫(kù)

5、重起數(shù)據(jù)庫(kù)服務(wù):

service mysqld restart

查看server-id:

show variable like ‘server_id’;

文章標(biāo)題:包含mysql怎么實(shí)現(xiàn)同步的詞條
新聞來(lái)源:http://chinadenli.net/article30/heedso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄小程序開(kāi)發(fā)、品牌網(wǎng)站制作、企業(yè)建站、搜索引擎優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

綿陽(yáng)服務(wù)器托管