mysql については読み書き分離アーキテクチャが多数あり、Baidu のほぼすべてが mysql_proxy を使用して実装しています。プロキシは Lua スクリプト言語に基づいて実装されているため、インターネット上の多くのネチズンは、このプロキシは効率的でなく不安定であり、運用環境での使用はお勧めできないと述べています。
amoeba は Alibaba によって開発されたプロジェクトであり、データベースの読み取りと書き込み (読み取りと書き込みの分離はその小さな機能にすぎません) Java に基づいて記述されているため、実行環境には jdk をインストールする必要があります;
関連チュートリアル: mysql ビデオ チュートリアル
事前準備作業:
1. マスターとスレーブの 2 つのデータベース、マスターとスレーブの同期;
master: 172.22.10.237:3306; メイン データベースは書き込み操作を担当します。
slave: 10.4.66.58:3306; Slave ライブラリは読み取り操作を担当します;
amoeba: 172.22.10.237:8066; メイン ライブラリが配置されているサーバーに amoeba をインストールしました。 3 番目のサーバーにインストールします;
すべてのサーバーのオペレーティング システムは centos7;
2. amoeba が配置されているサーバーに jdk を設定してインストールします;
jdk1.8 をインストールしました;
パスは次のとおりです: JAVA_HOME=/usr/local/java/jdk1.8.0_131
上記は必ずご自身で構築・設定してくださいマスターとスレーブは正常に動作しますjdk環境変数/etc/profile;##を追加してください
#アメーバをインストールするにはさまざまな方法があるため、ここではインストールに時間を無駄にしません。amoeba-mysql-3.0.5-RC-distribution のインストール パッケージをダウンロードし、直接解凍して使用します。解凍ディレクトリ: /usr/local/amoeba/
先ほど述べたように、 amoeba には読み書き分離以外の機能もありますが、読み書き分離機能のみを使用する場合は、conf/dbServers.xml conf/amoeba.xml と bin/launcher;
conf/ の設定だけで済みます。 dbServers.xml:
`<property name="port">3306</property> #设置Amoeba要连接的mysql数据库的端口,默认是3306 <property name="schema">testdb</property> #设置缺省的数据库,当连接amoeba时,操作表必须显式的指定数据库名,即采用dbname.tablename的方式,不支持 use dbname指定缺省库,因为操作会调度到各个后端dbserver <property name="user">test1</property> #设置amoeba连接后端数据库服务器的账号和密码,因此需要在所有后端数据库上创建该用户,并授权amoeba服务器可连接 <property name="password">111111</property> <property name="maxActive">500</property> #最大连接数,默认500 <property name="maxIdle">500</property> #最大空闲连接数 <property name="minIdle">1</property> #最新空闲连接数 <dbServer name="writedb" parent="abstractServer"> #设置一个后端可写的数据库,这里定义为writedb,这个名字可以任意命名,后面还会用到 <property name="ipAddress">172.22.10.237</property> #设置后端可写dbserver的ip <dbServer name="slave01" parent="abstractServer"> #设置后端可读数据库 <property name="ipAddress">10.4.66.58</property> <dbServer name="myslave" virtual="true"> #设置定义一个虚拟的dbserver,实际上相当于一个dbserver组,这里将可读的数据库ip统一放到一个组中,将这个组的名字命名为myslave <property name="loadbalance">1</property> #选择调度算法,1表示复制均衡,2表示权重,3表示HA, 这里选择1 <property name="poolNames">slave01</property> #myslave组成员`conf/amoeba.xml:
#启动脚本,需要配置jdk环境变量; #在注释后的第一行添加: JAVA_HOME=/usr/local/java/jdk1.8.0_131launcher は起動スクリプトです。JAVA_HOME が設定されていない場合は、/etc/profile で環境変数を設定しても、エラーが発生する可能性があります: jdk 環境変数が設定されていません;
設定ファイルもあります: jvm.properties
#占用内存配置文件 # -Xss参数有最小值要求,必须大于228才能启动JVM #修改: JVM_OPTIONS="-server -Xms1024m -Xmx1024m -Xss256k -XX:PermSize=16m -XX:MaxPermSize=96m"経験豊富 運用および保守の担当者は全員、jdk に関連するものは基本的にメモリに関連していることを知っています。アメーバも例外ではありません;今すぐ開始できます:
起動後、マシンの 8066 ポートが表示されます。 :
テスト:
マスター データベースを閉じても、引き続き読み取ることができます。 : select view コマンドを実行します。
または
スレーブ データベースを閉じても、次のように記述することができます: Update および inster コマンドを実行する;
以上がアメーバを使ってmysqlデータベースの読み書きを分離する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。