Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Tworzenie wysoce dostępnej bazy danych dla Moodle przy użyciu replikacji MySQL

Moodle to system zarządzania nauką o otwartym kodzie źródłowym, powszechnie używany przez szkoły i uniwersytety na całym świecie. Projekt rozpoczął się w 2002 roku przez Martina Dougiamasa i ma na celu zapewnienie uczniom, nauczycielom i edukatorom bezpiecznej, solidnej, otwartej i bezpłatnej platformy dla środowisk edukacyjnych.

Samo oprogramowanie jest napisane w PHP i obsługuje różne RDBMS, takie jak:Oracle, MySQL, PostgreSQL, MariaDB itp.

W tym blogu omówimy, jak uczynić bazę danych Moodle elastyczną przy użyciu replikacji MySQL, która jest potrzebna do obsługi wdrożenia Moodle o wysokiej dostępności. Wdrożymy za pośrednictwem ClusterControl konfigurację bazy danych składającą się z replikacji MySQL typu master/slave, obsługiwanej przez nadmiarowe systemy równoważenia obciążenia bazy danych.

Architektura

Replikacja MySQL jest popularnym sposobem uzyskania nadmiarowości bazy danych. Ważne jest, aby upewnić się, że wszystkie zapisy są wysyłane do urządzenia nadrzędnego, podczas gdy odczyty mogą być równoważone obciążeniem między urządzeniami podrzędnymi. W tym celu użyjemy ProxySQL, który jest opartym na bazie danych load balancerem, który zajmuje się rozdzielaniem ruchu zapisu i wysyłaniem go do mastera. Ponieważ rola master może zostać przeniesiona na inny serwer, na przykład w przypadku awarii bazy danych, ProxySQL może śledzić nowy master i upewnić się, że ruch zapisu jest odpowiednio kierowany. VirtualIP jest zarządzany przez Keepalive, aby zapewnić jeden odporny punkt końcowy bazy danych dla wszystkich serwerów aplikacji Moodle.

Monitorowanie i zarządzanie awaryjne

Na powyższym schemacie proponujemy dwie repliki podporządkowane głównej bazie danych. W przypadku awarii mastera jedna z replik zostanie awansowana do nowego mastera. Nadal pozostanie replika do obsługi takich czynności, jak odczyty, kopie zapasowe, raportowanie itp.

Połączenie aplikacji wykorzystuje VIP (wirtualny adres IP) w ciągu połączenia z bazą danych, więc jeśli coś stanie się po stronie bazy danych, zminimalizuje to wpływ aplikacji i nie będzie potrzeby ponownej konfiguracji wszystko. ClusterControl to komponent, który monitoruje bazy danych i automatyzuje przełączanie awaryjne, na przykład promując jedną z replik do nowego mastera i odzyskując uszkodzony serwer bazy danych.

Konfiguracja bazy danych

Wykorzystamy ClusterControl do wdrożenia naszej konfiguracji bazy danych.

Po pierwsze, musisz mieć dedykowany serwer do konfiguracji ClusterControl. Instalacja jest bardzo łatwa, wystarczy pobrać install-cc z repozytorium kilkudziesięciu, nadać plikowi uprawnienia do wykonywania i uruchomić go. Jak pokazano poniżej:  

$ wget http://www.severalnines.com/downloads/cmon/install-cc

$ chmod +x install-cc

$ sudo ./install-cc   # omit sudo if you run as root

Powyższy skrypt można uruchomić w dowolnym wariancie Linuksa. Wdroży wszystko, co jest wymagane przez ClusterControl.

Gdy ClusterControl będzie już uruchomiony i uruchomiony, wybierz przycisk Wdróż na pulpicie nawigacyjnym ClusterControl.

 

Wyświetli się nowa strona z kilkoma opcjami. Wybierzemy pierwszą opcję wdrożenia dla naszej konfiguracji replikacji MySQL.

Musisz mieć dostęp do docelowego serwera bazy danych przez SSH. Nie zapomnij włączyć SSH bez hasła i dać użytkownikowi dostęp sudo. Zdefiniuj nazwę klastra i kliknij Kontynuuj, jak pokazano poniżej:

Na następnej stronie należy wybrać dostawcę bazy danych, wersję bazy danych, którą chcesz zainstalować, hasło roota, port serwera, jeśli chcesz mieć niestandardowe lub określone porty, oraz katalog danych MySQL.

Po uzupełnieniu wszystkich informacji możesz przejść do kolejnego kroku, którym jest strona Zdefiniuj topologię. Proszę podać adres IP serwera bazy danych, w tym przypadku, ponieważ konfigurujemy replikację MyQL z 1 Masterem i 2 replikami.

Wdrożenie uruchomi teraz zadanie „Utwórz klaster”, po prostu trzeba poczekać, aż praca się zakończy.

Konfiguracja ProxySQL

Po wdrożeniu bazy danych możesz przejść przez Load Balancer z menu klastra. Przejdź do Zarządzaj -> Load Balancer. Zostanie to pokazane poniżej:

Wdrożenie ProxySQL wymaga podania pewnych informacji, takich jak adres IP, gdzie chcesz zainstalować ProxySQL, hasło do administrowania i monitorowania użytkowników oraz włączyć równoważenie obciążenia instancji. Następnie po prostu kliknij Wdróż. Aby uzyskać wysoką dostępność, potrzebujesz co najmniej 2 systemów równoważenia obciążenia zainstalowanych przed bazą danych.

Konfiguracja zachowana

Usługa Keepalived służy do zapewnienia wysokiej dostępności systemu równoważenia obciążenia. Konfiguracja jest naprawdę prosta, nadal na stronie Load Balancer znajduje się zakładka Keepalved, jak pokazano poniżej:

Wybierz rodzaj wdrożenia load balancera, w tym przypadku używamy ProxySQL, wybierz usługę ProxySQL dla podtrzymania aktywności. Wpisz wirtualny adres IP i interfejs sieciowy. Następnie wystarczy kliknąć Wdróż Keepalved, automatycznie uruchomi nowe zadanie w celu skonfigurowania usługi.

Konfiguracja aplikacji

Zanim skonfigurujesz aplikację moodle, musisz przygotować poświadczenia użytkownika i samą bazę danych. Aby uzyskać dane uwierzytelniające, przejdź do:Zarządzaj -> Schematy i użytkownicy.

Musisz podać pewne informacje, np.:nazwę użytkownika, hasło, nazwę hosta i przywilej. Następnie po prostu kliknij Utwórz użytkownika. Umożliwia to utworzenie użytkownika dla aplikacji moodle:

W celu utworzenia bazy danych możesz wybrać kartę Utwórz bazę danych na tym samym stronę jako Użytkownicy.

Kolejnym krokiem jest skonfigurowanie poświadczeń po stronie ProxySQL, możesz zaimportować poświadczenia, które utworzyłeś w ProxySQL. Możesz przejść do węzła ProxySQL, wybrać zakładkę Użytkownicy, po prawej stronie znajduje się przycisk Importuj użytkownika.

Wyszukaj użytkownika moodle_application, a następnie wybierz użytkownika. Na następnej stronie musisz zdefiniować domyślną grupę hostów dla użytkownika, a następnie zaimportować użytkowników.

Powtórz kroki importowania użytkowników na innym węźle ProxySQL lub możesz użyć instancji synchronizacji w menu ProxySQL.

Musisz pobrać aplikację moodle z oficjalnej strony moodle (odp. https ://download.moodle.org/), najnowsza wersja w momencie pisania tego bloga to 3.9.1. Zapewniają dwa rodzaje skompresowanych plików, skompresowany zip i zip tar. Pobierz plik zip i umieść go na serwerach aplikacji. Sprawdź wymagania dotyczące oprogramowania moodle, tj.:Serwer WWW, biblioteka PHP.

Wypakuj pliki zip do katalogu temp, utwórz katalog /var/www/html/moodle, skopiuj rozpakowany katalog do folderu. Nie zapomnij dać uprawnienia 0755 do katalogu. Następnie możesz uzyskać dostęp do przeglądarki internetowej w celu następnej konfiguracji. Wybierz język, jak pokazano poniżej:

Wybierz sterownik bazy danych dla konfiguracji MySQL, jak poniżej:

Musisz wypełnić pewne informacje o poświadczeniach bazy danych, które wprowadziłeś wcześniej, przykład:nazwa użytkownika, hasło, host, baza danych, port. Nazwa hosta powinna być twoim wirtualnym adresem IP, a port to port ProxySQL, czyli 6032.

Host bazy danych to Twój wirtualny adres IP. Po wypełnieniu pól kliknij Dalej i gotowe.

Budowanie wysoce dostępnej bazy danych dla Moodle za pomocą ClusterControl jest bardzo łatwe i proste. Możesz zbudować własną bazę danych, która będzie wspierać 99,99% dostępności usług.


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jaka jest różnica między utf8_general_ci a utf8_unicode_ci?

  2. Jak wstawić wiele wartości pól wyboru do tabeli?

  3. Próba uzyskania własności nie-obiektowej - CodeIgniter

  4. Jak działa funkcja LOAD_FILE() w MySQL

  5. Jak uzyskać resztę za pomocą MOD() w PostgreSQL, MS SQL Server i MySQL?