Heim  >  Artikel  >  Datenbank  >  So verwenden Sie Amoeba, um das Lesen und Schreiben einer MySQL-Datenbank zu trennen

So verwenden Sie Amoeba, um das Lesen und Schreiben einer MySQL-Datenbank zu trennen

little bottle
little bottlenach vorne
2019-05-07 09:08:312102Durchsuche

Es gibt viele Lese-/Schreib-Trennarchitekturen für MySQL. Fast alle verwenden MySQL_Proxy, um es zu implementieren. Da der Proxy auf der Grundlage der Lua-Skriptsprache implementiert ist, sagten viele Internetnutzer, dass der Proxy nicht effizient und instabil sei und nicht für die Verwendung in einer Produktionsumgebung empfohlen werde.
Amoeba ist ein von Alibaba entwickeltes Projekt, das das Lesen von Datenbanken trennt und Schreiben (lesen Sie, dass die Schreibtrennung nur eine kleine Funktion davon ist). Da es auf Java basiert, muss die laufende Umgebung jdk installieren.

Verwandte Tutorials: MySQL-Video-Tutorial

Vorbereitende Arbeiten:
Zwei Datenbanken, eine Master- und eine Slave-Synchronisation; die Hauptdatenbank ist für die Schreibvorgänge verantwortlich; >Slave: 10.4.66.58:3306; Slave Die Bibliothek ist für Lesevorgänge verantwortlich.
Amoeba: 172.22.10.237:8066; Natürlich können Sie es auch installieren auf dem dritten Server;
Alle Server-Betriebssysteme sind Centos7;
Ich habe jdk1.8 installiert; /usr/local/java/jdk1.8.0_131

Stellen Sie sicher, dass Sie das oben Genannte selbst erstellen und konfigurieren. Fügen Sie die JDK-Umgebungsvariable hinzu: /etc/profile;

Es gibt viele Möglichkeiten, Amoeba zu installieren. Laden Sie hier das Installationspaket von amoeba-mysql-3.0.5-RC herunter und entpacken Sie es direkt zur Verwendung. usr/local/amoeba/


Offensichtlich befindet sich die Konfigurationsdatei in conf und das Startprogramm in bin;

Wie gerade erwähnt, hat Amoeba mehr Funktionen als die Lese- und Schreibtrennung, aber wenn Sie nur die Lese- und Schreibtrennungsfunktion verwenden, müssen Sie nur diese wenigen Dateien konfigurieren: conf/dbServers.xml conf/amoeba.xml und bin/launcher; :

`<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组成员`
So verwenden Sie Amoeba, um das Lesen und Schreiben einer MySQL-Datenbank zu trennenconf/amoeba.xml:

       #启动脚本,需要配置jdk环境变量;
        #在注释后的第一行添加:
        JAVA_HOME=/usr/local/java/jdk1.8.0_131

Launcher ist das Startskript, wenn JAVA_HOME nicht konfiguriert ist, auch wenn Sie Umgebungsvariablen in /etc/profile konfigurieren, erhalten Sie möglicherweise eine Fehlermeldung : JDK-Umgebungsvariablen sind nicht konfiguriert;
Es gibt auch eine Konfigurationsdatei: jvm.properties

  #占用内存配置文件
        # -Xss参数有最小值要求,必须大于228才能启动JVM
        #修改:
            JVM_OPTIONS="-server -Xms1024m -Xmx1024m -Xss256k -XX:PermSize=16m -XX:MaxPermSize=96m"

Erfahrene Jeder in Betrieb und Wartung weiß, dass alles, was mit JDK zu tun hat, im Wesentlichen mit der Speicheroptimierung zusammenhängt, und Amoeba schon Keine Ausnahme;

kann jetzt gestartet werden:


Nach dem Start sehen Sie den 8066-Port der Maschine:

So verwenden Sie Amoeba, um das Lesen und Schreiben einer MySQL-Datenbank zu trennen

Zu diesem Zeitpunkt müssen Sie nur den 8066-Port der Maschinen-IP übergeben und einfach das in der Konfigurationsdatei festgelegte Konto und Passwort verwenden, um eine Verbindung zur Datenbank herzustellen geht zum Master und die gelesenen Daten werden vom Slave gelesen;
Schließen Sie die Master-Datenbank und sie können weiterhin gelesen werden: Führen Sie den Befehl „select view“ aus Schließen Sie die Slave-Datenbank. Sie können weiterhin schreiben: Führen Sie die Befehle update und inster aus

Das obige ist der detaillierte Inhalt vonSo verwenden Sie Amoeba, um das Lesen und Schreiben einer MySQL-Datenbank zu trennen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:51cto.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen