ホームページ >バックエンド開発 >PHPチュートリアル >マルチスレッドのマスター/スレーブ レプリケーションを構築するための mysql の新しいバージョン_PHP チュートリアル

マルチスレッドのマスター/スレーブ レプリケーションを構築するための mysql の新しいバージョン_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-12 08:55:571098ブラウズ

mySQLの新しいバージョンは、マルチスレッドマスタースレーブレプリケーションを構築します

one:最初にget

mysql-5.7.11-1.el6.x86_64.rpm-bundle.tar

tar xf mys ql- 5.7.11-1.el6.x86_64.rpm-bundle.tar

yum install -y mysql-community-client-5.7.11-1.el6.x86_64.rpm mysql-community-common-5.7 .11-1.el6 .x86_64.rpm mysql-community-libs-5.7.11- 1.el6.x86_64.rpm mysql-community-libs-compat-5.7.11-1.el6.x86_64.rpm mysql-community- server-5.7.11- 1.el6.x86_64.rpm

開始:
/etc/init.d/mysqld start
[root@vm10 mnt]# /etc/init.d/mysqld start
MySQL データベースの初期化: [ OK ]
パスワード検証プラグインのインストール: [ OK ]
mysqld の起動: [ OK ]

初期パスワードの取得:
grep '一時パスワード' /var/log/mysqld.log
mysql -p Enter を押した後に初期パスワードを入力してください

パスワードの変更:
ALTER USER root@localhost は「Redhat007!」で識別されます
パスワード規則: 大文字、小文字、数字、特殊文字を含む 8 文字以上である必要があります

次に、その中に使用されるデータベース xp1 を作成します後のテスト用
mysql> データベース xp1 を作成します。
その後、Add.sql が /mnt の下に作成され (後で使用するため)、コードは次のとおりです:



<ol style="margin:0 1px 0 0px;padding-left:40px;" start="1" class="dp-css"><li>CREATE TABLE usertb (<br /> </li><li>id serial,<br /></li><li>uname varchar(20),<br /></li><li>ucreatetime datetime ,<br /></li><li>age int(11)<br /></li><li>)<br /></li><li>ENGINE=MYISAM<br /></li><li>DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci<br /></li><li>AUTO_INCREMENT=1<br /></li><li>ROW_FORMAT=COMPACT;<br /></li><li><br /></li><li>delimiter $$<br /></li><li>SET AUTOCOMMIT = 0$$<br /></li><li><br /></li><li>create procedure test1()<br /></li><li>begin<br /></li><li>declare v_cnt decimal (10) default 0 ;<br /></li><li>dd:loop<br /></li><li>insert into usertb values<br /></li><li>(null,'用户1','2010-01-01 00:00:00',20),<br /></li><li>(null,'用户2','2010-01-01 00:00:00',20),<br /></li><li>(null,'用户3','2010-01-01 00:00:00',20),<br /></li><li>(null,'用户4','2010-01-01 00:00:00',20),<br /></li><li>(null,'用户5','2011-01-01 00:00:00',20),<br /></li><li>(null,'用户6','2011-01-01 00:00:00',20),<br /></li><li>(null,'用户7','2011-01-01 00:00:00',20),<br /></li><li>(null,'用户8','2012-01-01 00:00:00',20),<br /></li><li>(null,'用户9','2012-01-01 00:00:00',20),<br /></li><li>(null,'用户0','2012-01-01 00:00:00',20)<br /></li><li>;<br /></li><li>commit;<br /></li><li>set v_cnt = v_cnt+10 ;<br /></li><li>if v_cnt = 10000000 then leave dd;<br /></li><li>end if;<br /></li><li>end loop dd ;<br /></li><li>end;$$<br /></li><li><br /></li><li>delimiter ; </li></ol>
次に、新しく作成したデータベースでそのコードを実行します


コード内でストアド プロシージャをトリガーします
test1 を呼び出します。これが usertb テーブルに含まれます
1,000 万行のデータを挿入します
以下は、データが挿入されたことを示しています


コードを変更し、その中にテーブル usertb1 を作成し、続行しますトリガーして、そこに 1,000 万行のデータを書き込みます
(2 つのテーブルを作成する主な目的は、mysqldump と mysqlpump を作成することです。違いはより明らかです)
以下は、作成が成功したことを証明します


mysqldump と mysqlpump をテストします
mysqldump :


mysqlpump:time mysqlpump -p xp1 > mysqlpump で使用されるデフォルトのスレッド数は 2
time mysqlpump -pRedhat006! --default-Parallelism=4 db1 > 4 スレッド数は自分で変更できます

mysql A - - B をコピーします
設定環境: マスター: 172.25.254.10スレーブ: 172.25.254.11
最初にマスターホストで
vim /etc/my.cnf
server -id=1
log-bin=mysql-binbinlog-do -db=test
/etc/init.d/mysqld restart
mysql -pRedhat007!
次のコマンドを使用して、成功したかどうかを確認します

新しいテスト データベースの作成: データベース テストの作成;

認可:
mysql> 'Redhat007!' によって識別された xpp@'172.25.254.11' に *.* のレプリケーション スレーブを許可します;
クエリ OK、影響を受ける行は 0、警告は 1 件(0.40 秒)
/etc/init.d/mysqld restart

slave end: 172.25.254.11
vim /etc/my.cnf
server-id=2 マスターとは異なるだけです
次に、mysql の最新バージョンをインストールしますスレーブ上で
まずマスターが正常に認証されているかどうかを確認します
mysql -pRedhat007! -uxpp -h172.25.254.10 ログインできれば成功したことがわかります

mysql -pRedhat007!新しいテストデータベースを作成します。同期前に 2 つのデータベースの整合性が保たれている必要があります
次に、マスターを master_host='172.25.254.10'、master_user='xpp '、master_password='Redhat007!'、master_log_file='mysql-bin.000001'、master_log_pos=154; に変更します。

/etc/init.d/mysqld restart

マスター側:
MySQL の新機能の 1 つは、データベースのプライマリとバックアップの一貫性、障害回復、次の 2 行を vim /etc/my.cnf に追加して、gtid モードをオンにします

gtid-mode=on
enforce-gtid-consistency=on

/etc/init.d/mysqld restart。

次に、slave
vim /etc/my.cnf に移動し、次の内容を追加します
gtid-mode=on
enforce-gtid-consistency=on
slave-Parallel-type =LOGICAL_CLOCK
slave-Parallel-workers=16
master_info_repository =TABLE
relay_log_info_repository=TABLE
relay_log_recovery=ON

/etc/init.d/mysqld restart





















www.bkjia.com本当http://www.bkjia.com/PHPjc/1114327.html技術記事マルチスレッドのマスター/スレーブ レプリケーションを構築するための mysql の新しいバージョン 1: まず、mysql-5.7.11-1.el6.x86_64.rpm-bundle.tar tar xf mysql-5.7.11-1.el6.x86_64.rpm- を取得します。 Bundle.tar yum install -y mysql-community-cl...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。