首頁 資料庫 mysql教程 MySql配置主从复制 读写分开

MySql配置主从复制 读写分开

Jun 07, 2016 pm 04:14 PM
mysql 複製 讀寫 配置

MySql配置主从复制 读写分离 ? mysql版本:5.6.13 OS:windows server 2008 Master 配置 ? my.ini配置文件中 主从复制需要通过二进制日志文件进行,须开启二进制日志功能并配置Server ID ? [mysqld]log-bin=mysql-binserver-id=1 server-id 为1-2 32 ? -1 ? 之

MySql配置主从复制 读写分离

?

mysql版本:5.6.13

OS:windows server 2008

Master 配置

?

my.ini配置文件中

主从复制需要通过二进制日志文件进行,须开启二进制日志功能并配置Server ID

?

[mysqld]
log-bin=mysql-bin
server-id=1
登入後複製

server-id 为1-232?-1? 之间,默认为0(拒绝所有slave

?

innodb引擎耐用性增强

innodb_flush_log_at_trx_commit=1?and?sync_binlog=1

?

For the greatest possible durability and consistency in a replication setup using?InnoDB?with transactions, you should use?innodb_flush_log_at_trx_commit=1?and?sync_binlog=1?in the master?my.cnf?file.

?

?slave 配置

server-id=2
登入後複製

防止服务器主机名修改

?relay-log=mysqld-relay-bin

?

master

创建具有复制权限的账户repl

GRANT REPLICATION SLAVE ON *.*
-> TO 'repl'@'remotehost.mydomain.com' IDENTIFIED BY 'slavepass';

?

<span><span><span>mysql> </span></span><strong  class="userinput"><code ><span><span>FLUSH TABLES WITH READ LOCK;</span></span></code></strong></span>
登入後複製

对于<span><span>InnoDB</span></span>表的注意?<span><span>FLUSH TABLES WITH READ LOCK</span></span>?<span><span>COMMIT</span></span>操作。

保留客户端发出?<span><span>FLUSH TABLES</span></span>语句运行,这样,读锁仍然有效。如果你退出客户端,该锁被释放。

?

?

?

使用?<span><span>SHOW MASTER STATUS</span></span>语句来确定当前的二进制日志文件的名称和位置:

?

<span><span><span>的mysql> </span></span><strong  class="userinput"><code ><span><span>SHOW MASTER STATUS;</span></span></code></strong></span><span><span>
<span>+ ------------------ + ---------- + -------------- + ---- -------------- +</span></span></span><span><span>
<span>|“文件”|“位置| Binlog_Do_DB | Binlog_Ignore_DB |</span></span></span><span><span>
<span>+ ------------------ + ---------- + -------------- + ---- -------------- +</span></span></span><span><span>
<span>MYSQL-bin.000003 | 73 |测试|说明书,MYSQL |</span></span></span><span><span>
<span>+ ------------------ + ---------- + -------------- + ---- -------------- +</span></span></span>
登入後複製

?

<span><span>文件</span></span>栏显示的日志文件的名称和<span><span>位置</span></span>显示在文件中的位置。在这个例子中,二进制日志文件是?<span><span>mysql-bin.000003的</span></span>位置是73。记录这些值。你需要它们,以后当你设立的奴隶。他们表示复制坐标奴隶从主应该开始处理新的更新。

?

如果主已经运行以前没有二进制日志启用,通过<span><span>SHOW MASTER STATUS</span></span>mysqldump的-主数据显示日志文件的名称和位置值将是空的。在这种情况下,你需要使用指定的奴隶的日志文件和位置后的值是空字符串(<span><span>''</span></span>)和<span><span>4</span></span>

?

你现在有你需要的信息,可以让从开始读取的二进制日志在正确的位置开始复制。

?

设置主从连接信息

?

mysql> <span><strong  class="userinput"><code >CHANGE MASTER TO</code></strong>
    ->     <strong  class="userinput"><code >MASTER_HOST='<em  class="replaceable"><code >master_host_name</code></em>',</code></strong>
    ->     <strong  class="userinput"><code >MASTER_USER='<em  class="replaceable"><code >replication_user_name</code></em>',</code></strong>
    ->     <strong  class="userinput"><code >MASTER_PASSWORD='<em  class="replaceable"><code >replication_password</code></em>',</code></strong>
    ->     <strong  class="userinput"><code >MASTER_LOG_FILE='<em  class="replaceable"><code >recorded_log_file_name</code></em>',</code></strong>
    ->     <strong  class="userinput"><code >MASTER_LOG_POS=<em  class="replaceable"><code >recorded_log_position</code></em>;</code></strong></span>
登入後複製

查看连接状态 show slave status\G;

?

?读写分离配置

windows设置PATH?

?

创建代理 222为Master 223为只读

?

<span><strong  class="userinput"><code >sc create "Proxy" DisplayName= "MySQL Proxy" start= "auto" binPath= "F:\tool\mysql-proxy-0.8.2-winx64-x86\bin\mysql-proxy-svc.exe 
--proxy-address=localhost:3306 --proxy-backend-addresses=10.133.10.222:3306 --proxy-read-only-backend-addresses=10.133.10.223:3306"
</code></strong></span>
登入後複製

?

 <strong  class="userinput"><code ><span>net start proxy</span></code></strong>
登入後複製
C:\> <strong  class="userinput"><code ><span>sc delete proxy</span></code></strong>
登入後複製

配置完之后测试,从服务器 stop slava

通过代理进行insert操作,在进行查询。然后start slave ,主从复制没有问题。

读写分离暂时还未测试

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PHP 的大數據結構處理技巧 PHP 的大數據結構處理技巧 May 08, 2024 am 10:24 AM

PHP 的大數據結構處理技巧

如何優化 PHP 中的 MySQL 查詢效能? 如何優化 PHP 中的 MySQL 查詢效能? Jun 03, 2024 pm 08:11 PM

如何優化 PHP 中的 MySQL 查詢效能?

如何在 PHP 中使用 MySQL 備份和還原? 如何在 PHP 中使用 MySQL 備份和還原? Jun 03, 2024 pm 12:19 PM

如何在 PHP 中使用 MySQL 備份和還原?

如何使用 PHP 插入資料到 MySQL 表? 如何使用 PHP 插入資料到 MySQL 表? Jun 02, 2024 pm 02:26 PM

如何使用 PHP 插入資料到 MySQL 表?

如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤 如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤 Dec 09, 2024 am 11:42 AM

如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤

如何在 PHP 中使用 MySQL 預存程序? 如何在 PHP 中使用 MySQL 預存程序? Jun 02, 2024 pm 02:13 PM

如何在 PHP 中使用 MySQL 預存程序?

如何使用 PHP 建立 MySQL 表? 如何使用 PHP 建立 MySQL 表? Jun 04, 2024 pm 01:57 PM

如何使用 PHP 建立 MySQL 表?

oracle資料庫和mysql的區別 oracle資料庫和mysql的區別 May 10, 2024 am 01:54 AM

oracle資料庫和mysql的區別

See all articles