Mamy dość duże doświadczenie w zakresie klastrów MySQL - a Percona wielokrotnie z nami współpracowała, przekraczając granice skomplikowanych konfiguracji.
Czy Magento ma wbudowaną obsługę niewolników tylko do odczytu
Magento jest natywnie zdolny do dzielenia odczytów / zapisów na różne serwery baz danych (z wyjątkiem kilku uszkodzonych wydań, np. EE 1.11) - pozwalając na przesunięcie select
obciążenia na dodatkowy (lub więcej) serwer (y); i przesyłanie wszystkich update/write
zapytań do jednego wzorca.
Kiedy powinienem to zrobić
To jest bardziej odpowiednie pytanie. Dzięki dedykowanym systemom operacyjnym Magento, takim jak MageStack - coraz częściej stosowane są wbudowane zaawansowane techniki buforowania po stronie serwera, które są dostępne i łatwe w użyciu (takie jak buforowanie frontonu Varnish i buforowanie back-endu Redis).
Historycznie Magento nigdy nie był związany MySQL - a raczej PHP. Jednak w miarę częstszego korzystania z Varnish i Full Page Caching (FPC) obciążenie związane z powtarzaniem zadań (ładowanie kategorii / produktów, częste wyszukiwanie) jest nagle absorbowane, a PHP staje się mniej obciążający. W rzeczywistości naprawdę dopiero zaczyna się generowanie treści lub ukończenie scenariuszy niemożliwych do buforowania (dodanie do koszyka, realizacja zamówienia itp.); w celu wyjaśnienia celowo ignorujemy obciążenie administracyjne .
Zawsze utrzymywaliśmy, że MySQL nie jest przedmiotem zainteresowania większości sprzedawców detalicznych, co widać zarówno tutaj, jak i tutaj . Ale jeśli jesteś w regionie przetwarzania setek zamówień na godzinę, a nie pojedynczych lub podwójnych cyfr - wkrótce stanie się obszarem do optymalizacji.
Ostatecznie dla mniejszych sklepów (<25 000 unikalnych odwiedzających dziennie)
Twoje wysiłki byłyby znacznie lepiej skoncentrowane na po prostu znalezieniu odpowiedniego hosta, który może zasugerować odpowiedni sprzęt do przesunięcia i który skonfigurował maszynę w najbardziej optymalny sposób dla twojego sklepu . Nie marnuj czasu na konfiguracje Master / Slave lub Master / Master - które nie przyniosą korzyści w zakresie wydajności i ostatecznie będą wymagały ciągłej uwagi i zaawansowanej wiedzy na temat MySQL.
Ostatecznie zmiana rozmiaru i wybór sprzętu będzie odgrywać większą rolę niż optymalizacja MySQL.
Ale dla większych sklepów
Gdy sklep zaczyna się rozwijać, konwersja lub obciążenie transakcyjne stają się coraz większym obciążeniem w związku z powtarzającym się zadaniem wykonania skomplikowanych inserts
i updates
. Dodanie każdego nowego zamówienia spowoduje zmniejszenie zapasów w katalogu, wywołania zwrotne z bramek płatności i aktualizacje z systemów EPOS / ERP. Połącz to z powiązanym czyszczeniem pamięci podręcznej odpowiednich produktów / kategorii, a wkrótce zobaczysz, że obciążenie MySQL wzrośnie nieproporcjonalnie.
Multi-master nigdy nie jest rozwiązaniem, które zalecamy lub uważamy za realną opcję, ale Master / Slave może przynieść korzyści (podkreślamy, w sklepach o rozmiarach Enterprise) poprzez przesunięcie obciążenia odczytu do węzłów drugorzędnych / trzeciorzędnych.
Ale nadal chcę to zrobić
Najpierw skonfiguruj swoich niewolników. Jesteśmy wielkimi zwolennikami tych narzędzi Percona i oddziałów MySQL - mają one narzędzie idealne do robienia gorących kopie zapasowe istniejących DB - innobackupex. Jest dobry napisać tutaj .
Na mistrzu
Zastąp $ TIMESTAMP lub kartę zakończoną.
mysql
> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'$slaveip' IDENTIFIED BY '$slavepass';
> quit;
innobackupex --user=username --password=password /path/to/backupdir
innobackupex --user=username --password=password /
--apply-log /path/to/backupdir/$TIMESTAMP/
rsync -avprP -e ssh /path/to/backupdir/$TIMESTAMP TheSlave:/path/to/mysql/
scp /etc/mysql/my.cnf TheSlave:/etc/mysql/my.cnf
Na niewolniku
/etc/init.d/mysql stop
mv /path/to/mysql/datadir /path/to/mysql/datadir_bak
mv /path/to/mysql/$TIMESTAMP /path/to/mysql/datadir
chown -R mysql:mysql /path/to/mysql/datadir
sed -i 's#server-id=1#server-id=2#g' /etc/mysql/my.cnf
/etc/init.d/mysql start
cat /var/lib/mysql/xtrabackup_binlog_info
> TheMaster-bin.000001 481
mysql
> CHANGE MASTER TO MASTER_HOST='$masterip', MASTER_USER='repl', MASTER_PASSWORD='$slavepass', MASTER_LOG_FILE='TheMaster-bin.000001', MASTER_LOG_POS=481;
> START SLAVE;
Potem, kiedy twój slave zacznie działać, w praktyce potrzeba tylko kilku dodatkowych wierszy kodu.
W ./app/etc/local.xml
<default_read>
<connection>
<use/>
<host><![CDATA[host]]></host>
<username><![CDATA[username]]></username>
<password><![CDATA[password]]></password>
<dbname><![CDATA[dbname]]></dbname>
<type>pdo_mysql</type>
<model>mysql4</model>
<initStatements>SET NAMES utf8</initStatements>
<active>1</active>
</connection>
</default_read>
Źródła