sql >> Databáze >  >> RDS >> Mysql

Může magento používat více slave MySQL?

S ohledem na vaše komentáře výše a za předpokladu, že máte správné nastavení replikace vašich databází.

Řešení:-

– Krok 1:

V Soubor

app/etc/config.xml

Najděte „core_read“ uzavírací značku

<resources>
    ....
    <core_read>
            <connection>
                <use>default_read</use>
            </connection>
        </core_read>
    ....
</resources>

Přidat Za uzavírací značku (tolik databází, které chcete použít) by to mělo vypadat takto:

<resources>
    ....
        <core_read>
            <connection>
                <use>default_read</use>
            </connection>
        </core_read>
        <slave_db_1>
            <connection>
                <use>slave_one_db</use>
            </connection>
        </slave_db_1>
        <slave_db_2>
            <connection>
                <use>slave_two_db</use>
            </connection>
        </slave_db_2>
    ....
</resources>

– Krok 2:

A přidejte nové připojení do apt/etc/local.xml za ("/default_setup> " uzavírací značka)

<resources>
    ....            
        <slave_one_db>
            <connection>
                <host><![CDATA[localhost]]></host>
                <username><![CDATA[slave_one_db_user]]></username>
                <password><![CDATA[slave_one_db_password]]></password>
                <dbname><![CDATA[slave_db_one_name]]></dbname>
                <initStatements><![CDATA[SET NAMES utf8]]></initStatements>
                <model><![CDATA[mysql4]]></model>
                <type><![CDATA[pdo_mysql]]></type>
                <pdoType><![CDATA[]]></pdoType>
                <active>1</active>
            </connection>
        </slave_one_db>
        <slave_two_db>
            <connection>
                <host><![CDATA[localhost]]></host>
                <username><![CDATA[slave_tow_db_user]]></username>
                <password><![CDATA[slave_tow_db_password]]></password>
                <dbname><![CDATA[slave_db_one_tow]]></dbname>
                <initStatements><![CDATA[SET NAMES utf8]]></initStatements>
                <model><![CDATA[mysql4]]></model>
                <type><![CDATA[pdo_mysql]]></type>
                <pdoType><![CDATA[]]></pdoType>
                <active>1</active>
            </connection>
        </slave_two_db>
    ....
</resources>

– Krok 3:

Zkopírujte soubor z " app/code/core/Mage/Core/Model/Resource.php " ==DO ==> " app/code/local/Mage/Core/Model/Resource.php "

1- Najděte chráněné $_mappedTableNames;

2- Přidejte tuto metodu níže:

public function getSlaveDb()
{
    $prefix = 'slave_db_'; // prefix for the slaves databased in the xml file
    $cookieExpireTime = 1209600; // 2 weeks Cookie ( database selection ) expire time
    $dbArray = array(1,2); // All slaves Db in-case the cookie has invalid value
    $slaveDb = array_rand( array_flip($dbArray),1 ); // How to alternate between databases ( in this demo i just use 2 database ) adjust the selection of the database to fit hoe many database you want to use !
    if(!isset($_COOKIE['read_db']) || !in_array($_COOKIE['read_db'],$dbArray)) // Check for the cookie values
    {
        setcookie("read_db", $slaveDb, time()+$cookieExpireTime); // set the current database to the user in cookie so next time user use same connection to database ! to avoid jumping or hopping on different databases in short time
    }else{
        $slaveDb = $_COOKIE['read_db']; // return the database selected if the user has it in the cookies
    }
    return $prefix.$slaveDb;
}

3- Upravte metodu " public function getConnection($name) " tak, aby vypadala níže:

public function getConnection($name)
{
    if($name =='core_read') // Only applied for READ Connections !!!
    {
        $name = $this->getSlaveDb(); // change the name of the connection to the one we get from our main method
    }
    //....... Leave the rest of the function as it is !!
}

To vám umožní použít tolik databází, které určíte v kódu XML a PHP pro připojení core_read a připojení default_setup pro všechna ostatní připojení v magentu ( core_write, core_setup )

Doufám, že to vyřeší váš problém.



  1. jak získat první nebo (jakýkoli) prvek ze seznamu LiveData v architektuře Android MVVM?

  2. jak mohu použít skutečný únikový řetězec mysql?

  3. Jak zabráním zaokrouhlování desetinného pole MySQL?

  4. Rozměry dimenzí:Podívejte se na nejběžnější typy dimenzionálních tabulek v Data Warehousing