Klastrovanie RabbitMQ na CentOS 7

RabbitMQ je sprostredkovateľ správ s otvoreným zdrojom, ktorý podporuje AMQP, STOMP a ďalšie komunikačné technológie. Je široko používaný v podnikových aplikáciách a moderných mikroslužbách, kde funguje ako asynchrónny kanál správ medzi rôznymi mikroslužbami. Táto príručka popisuje, ako môžete klastrovať RabbitMQ na viacerých serveroch CentOS 7, aby ste vytvorili sprostredkovateľa správ s vysokou dostupnosťou. V tomto návode bude jeden server fungovať ako hlavný server a ostatné servery budú fungovať ako zrkadlové servery v prípade, že hlavný server nebude dostupný.

Predpoklady

Nakonfigurujte bránu firewall

CentOS firewall, ( firewalld), štandardne nepovoľuje žiadnu prichádzajúcu komunikáciu. Aby sme sprístupnili RabbitMQ pre iné systémy v sieti aj mimo nej a umožnili nám prístup k riadiacej konzole, musíme najprv otvoriť niektoré porty.

Konzola na správu webového rozhrania RabbitMQ štandardne počúva na porte 15672. Radi by sme spravovaciu konzolu sprístupnili verejnosti, aby sme k nej mali prístup z nášho počítača. Dáme preto pokyn firewalldna trvalé otvorenie portu 15672vo verejnej zóne (čo je predvolená a aktívna zóna na inštancii Vultr).

sudo firewall-cmd --zone=public --add-port=15672/tcp --permanent

Uzly RabbitMQ musia byť schopné navzájom komunikovať. Radi by sme otvorili potrebné porty, ale len cez internú sieť. Nechceme, aby ktokoľvek na internete mohol spravovať alebo priamo kontaktovať naše servery. Nasledujúce príkazy predpokladajú, že naše servery sú v 192.168.0.100/24podsieti.

Prvou službou je epmdpeer discovery služba, ktorá štandardne počúva na porte 4369.

sudo firewall-cmd --permanent --zone=public --add-rich-rule='
  rule family="ipv4"
  source address="192.168.0.100/24"
  port protocol="tcp" port="4369" accept'

Pre komunikáciu internode a CLI musí byť RabbitMQ schopný komunikovať cez port 25672.

sudo firewall-cmd --permanent --zone=public --add-rich-rule='
  rule family="ipv4"
  source address="192.168.0.100/24"
  port protocol="tcp" port="25672" accept'

Nástroje CLI komunikujú cez rozsah portov 35672-35682.

sudo firewall-cmd --permanent --zone=public --add-rich-rule='
  rule family="ipv4"
  source address="192.168.0.100/24"
  port protocol="tcp" port="35672-35682" accept'

Ak vaše aplikácie potrebujú protokol AMQP, budete tiež musieť otvoriť porty 5671a 5672. Ak potrebujete byť schopní komunikovať cez iný protokol, potrebné informácie o sieťových požiadavkách RabbitMQ nájdete v oficiálnej dokumentácii RabbitMQ .

sudo firewall-cmd --permanent --zone=public --add-rich-rule='
  rule family="ipv4"
  source address="192.168.0.100/24"
  port protocol="tcp" port="5672" accept'

sudo firewall-cmd --permanent --zone=public --add-rich-rule='
  rule family="ipv4"
  source address="192.168.0.100/24"
  port protocol="tcp" port="5671" accept'

Teraz firewalldje to nakonfigurované, musíme mu dať pokyn, aby znova načítal konfiguráciu.

sudo firewall-cmd --reload

Opakujte kroky z tejto časti na všetkých serveroch.

Inštalácia rabbitmqadmin

Doplnok na správu sa dodáva s nástrojom Python, rabbitmqadminktorý sa dá ľahko nainštalovať do systému, keď je povolený doplnok na správu.

sudo wget http://localhost:15672/cli/rabbitmqadmin
sudo mv rabbitmqadmin /usr/local/bin/
sudo chmod +x /usr/local/bin/rabbitmqadmin

Nakonfigurujte DNS

Na identifikáciu serverov pri klastrovaní musíte použiť názvy hostiteľov servera. V predvolenom nastavení nemajú servery priradený žiadny záznam DNS a spojenie zlyhá. Ak to chcete rýchlo prekonať, pridajte do /etc/hostssúboru názov hlavného a zrkadlového hostiteľa pomocou svojho obľúbeného editora.

Napríklad súbor hostiteľov vášho mastera môže vyzerať takto. Všimnite si posledné dva záznamy, ktoré umožňujú serverom navzájom sa identifikovať podľa názvu hostiteľa. Nezabudnite zmeniť adresy IP na svoje vlastné.

127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6

127.0.0.1 guest
::1       guest

127.0.0.1 YOUR_MASTER_SERVER_HOST_NAME
::1       YOUR_MASTER_SERVER_HOST_NAME


192.168.0.101 YOUR_MASTER_SERVER_HOST_NAME
192.168.0.102 YOUR_MIRROR_SERVER_HOST_NAME

Zhlukujte uzly

Predpokladom importu, aby sa uzly mohli navzájom spojiť, je, že súbor cookie Erlang všetkých uzlov je identický. V predvolenom nastavení bude každému uzlu priradený jedinečný súbor cookie Erlang, takže ho musíte prekonfigurovať na všetkých uzloch.

Nasledujúci príkaz nastaví súbor cookie Erlang na " WE<3COOKIES", ale môžete to zmeniť podľa svojich predstáv. Urobte to na všetkých serveroch.

sudo sh -c "echo 'WE<3COOKIES' > /var/lib/rabbitmq/.erlang.cookie"

Reštartujte RabbitMQ na všetkých serveroch, aby ste sa uistili, že súbor cookie Erlang je správne znovu načítaný.

sudo systemctl restart rabbitmq-server.service

Vykonajte nasledujúce príkazy na všetkých serveroch okrem hlavného servera. To umožní uzlom pripojiť sa k hlavnému serveru a vytvoriť klaster.

sudo rabbitmqctl stop_app
sudo rabbitmqctl join_cluster "rabbit@<YOUR_MASTER_SERVER_HOST_NAME>"
sudo rabbitmqctl start_app

Skontrolujte, či sa uzly pripojili ku klastru spustením nasledujúceho príkazu.

sudo rabbitmqctl cluster_status

Všetky vaše uzlov sa objaví v nodesa running_nodesčasť výstupu. Odteraz už nemusíte opakovať kroky na každom serveri, konfigurácia sa automaticky premietne do ostatných uzlov.

Vytvorte politiku vysokej dostupnosti

Teraz, keď máme klaster uzlov RabbitMQ, môžeme to použiť na vytváranie frontov a výmen s vysokou dostupnosťou nastavením novej politiky. Túto politiku je možné pridať prostredníctvom riadiacej konzoly RabbitMQ alebo pomocou rozhrania príkazového riadka.

sudo rabbitmqctl set_policy -p "/" --priority 1 --apply-to "all" ha ".*" '{ "ha-mode": "exactly", "ha-params": 2, "ha-sync-mode": "automatic"}'

Nasledujúci zoznam vysvetlí, čo znamenajú jednotlivé časti príkazu.

  • -p "/": Použite túto zásadu na "/"vhost (predvolená hodnota po inštalácii)
  • --priority 1: Poradie, v ktorom sa majú uplatňovať zásady
  • --apply-to "all": Môže byť "queues", "exchanges"alebo"all"
  • ha: Názov, ktorý dávame našej politike
  • ".*": Regulárny výraz, ktorý sa používa na rozhodovanie o tom, na ktoré fronty alebo burzy sa táto politika použije. ".*"bude zodpovedať čomukoľvek
  • '{ "ha-mode": "exactly", "ha-params": 2, "ha-sync-mode": "automatic"}': Reprezentácia politiky vo formáte JSON. Tento dokument popisuje, že chceme – presne 2 uzly, na ktorých sa dáta automaticky synchronizujú

Stručne povedané, táto politika zaistí, že budeme mať vždy 2 kópie údajov vo fronte alebo výmene, pokiaľ budeme mať v prevádzke aspoň 2 uzly. Ak máte viac uzlov, môžete zvýšiť hodnotu ha-params. Odporúča sa kvórum ( N/2 + 1), uzlov. Viac kópií údajov by malo za následok vyššie využitie disku, I/O a siete, čo by mohlo viesť k zníženiu výkonu.

Ak by ste chceli zrkadliť údaje do všetkých uzlov v klastri, môžete použiť nasledujúci dokument JSON.

'{ "ha-mode": "all", "ha-sync-mode": "automatic"}'

Ak by ste chceli zrkadliť údaje iba do konkrétnych uzlov (napríklad: node-1a node-2), môžete použiť nasledujúce.

'{ "ha-mode": "nodes", "ha-params" :["rabbit@node-1", "rabbit@node-2"], "ha-sync-mode": "automatic"}'

Regulárny výraz môžete zmeniť a priradiť rôzne politiky rôznym frontom. Povedzme, že máme nasledujúce tri uzly:

  • králik@majster
  • králik@klient-ha
  • králik@produkt-ha

Potom môžeme vytvoriť dve politiky, ktorých výsledkom budú fronty s názvom, ktorý začína na „klient“, ktorý sa má zrkadliť do rabbit@client-hauzla, a všetky fronty, ktoré majú názov začínajúci na „produkt“, budú zrkadlené do rabbit@product-hauzla.

sudo rabbitmqctl set_policy -p "/" --priority 1 --apply-to "queues" ha-client "client.*" '{ "ha-mode": "nodes", "ha-params": ["rabbit@master", "rabbit@client-ha"], "ha-sync-mode": "automatic"}
sudo rabbitmqctl set_policy -p "/" --priority 1 --apply-to "queues" ha-product "product.*" '{ "ha-mode": "nodes", "ha-params": ["rabbit@master", "rabbit@product-ha"], "ha-sync-mode": "automatic"}

Tu je malá poznámka: exkluzívne fronty nie sú v RabbitMQ nikdy zrkadlené ani trvalé, aj keď táto politika zodpovedá takýmto frontom. Exkluzívne fronty sa automaticky zničia, keď sa klient odpojí, a preto by bolo zbytočné ho replikovať na iný server. Ak by server zlyhal, klient by sa od neho odpojil a fronta by sa automaticky zničila. Zrkadlové inštancie by boli tiež zničené.

Testovanie nastavenia

Aby sme otestovali klastrové nastavenie, môžeme vytvoriť nový front pomocou rozhrania príkazového riadka prostredníctvom riadiacej konzoly.

sudo rabbitmqadmin declare queue --vhost "/" name=my-ha-queue durable=true

Tým sa vytvorí trvalý front na predvolenom /vhoste s názvom my-ha-queue.

Spustite nasledujúci príkaz a na výstupe overte, či má front priradenú našu politiku 'ha' a má pid na hlavnom a zrkadlovom uzle.

sudo rabbitmqctl list_queues name policy state pid slave_pids

Teraz môžeme publikovať správu do frontu z hlavného uzla a zastaviť RabbitMQ na hlavnom uzle.

sudo rabbitmqadmin -u user_name -p password  publish routing_key=my-ha-queue payload="hello world"
sudo systemctl rabbitmqctl shutdown

Teraz ho získajte späť pripojením k zrkadlovému uzlu.

 sudo rabbitmqadmin -H MIRROR_NODE_IP_OR_DNS -u user_name -p password get queue=my-ha-queue

Nakoniec môžeme reštartovať náš hlavný uzol.

sudo systemctl start rabbitmq-server.service

Odstrániť hosťujúceho používateľa

Ako už bolo spomenuté, RabbitMQ automaticky vytvorí hosťa s predvoleným heslom hosťa. Bolo by zlou praxou ponechať tohto predvoleného používateľa na verejne prístupnom systéme.

sudo rabbitmqctl delete_user guest

Install Plesk on CentOS 7

Install Plesk on CentOS 7

Using a Different System? Plesk is a proprietary web host control panel that allows users to administer their personal and/or clients websites, databases

Ako nainštalovať Squid Proxy na CentOS

Ako nainštalovať Squid Proxy na CentOS

Squid je populárny bezplatný linuxový program, ktorý vám umožňuje vytvoriť webový proxy server na presmerovanie. V tejto príručke uvidíte, ako nainštalovať Squid na CentOS, aby vás zmenil

Ako nainštalovať Lighttpd (LLMP Stack) na CentOS 6

Ako nainštalovať Lighttpd (LLMP Stack) na CentOS 6

Úvod Lighttpd je fork Apache, ktorého cieľom je byť oveľa menej náročný na zdroje. Je ľahký, odtiaľ jeho názov, a jeho použitie je celkom jednoduché. Installin

Konfigurácia statickej siete a IPv6 na CentOS 7

Konfigurácia statickej siete a IPv6 na CentOS 7

VULTR nedávno vykonal zmeny na ich konci a všetko by teraz malo fungovať dobre po vybalení so zapnutým NetworkManagerom. Ak chcete deaktivovať

Úprava Icinga2 na použitie modelu Master/Client na CentOS 6 alebo CentOS 7

Úprava Icinga2 na použitie modelu Master/Client na CentOS 6 alebo CentOS 7

Icinga2 je výkonný monitorovací systém a pri použití v modeli master-client môže nahradiť potrebu monitorovacích kontrol založených na NRPE. Hlavný klient

Ako nainštalovať Apache Cassandra 3.11.x na CentOS 7

Ako nainštalovať Apache Cassandra 3.11.x na CentOS 7

Používate iný systém? Apache Cassandra je bezplatný a otvorený systém správy databáz NoSQL, ktorý je navrhnutý tak, aby poskytoval škálovateľnosť, vysokú

Ako nainštalovať Microweber na CentOS 7

Ako nainštalovať Microweber na CentOS 7

Používate iný systém? Microweber je open source drag and drop CMS a online obchod. Zdrojový kód Microweber je umiestnený na GitHub. Tento návod vám to ukáže

Ako nainštalovať Mattermost 4.1 na CentOS 7

Ako nainštalovať Mattermost 4.1 na CentOS 7

Používate iný systém? Mattermost je open source, samostatne hosťovaná alternatíva k službe posielania správ Slack SAAS. Inými slovami, s Mattermostom môžete cca

Vytvorenie siete serverov Minecraft pomocou BungeeCord na Debian 8, Debian 9 alebo CentOS 7

Vytvorenie siete serverov Minecraft pomocou BungeeCord na Debian 8, Debian 9 alebo CentOS 7

Čo budete potrebovať Vultr VPS s aspoň 1 GB RAM. Prístup SSH (s oprávneniami root/administrátor). Krok 1: Inštalácia BungeeCord Najprv veci

Umožňuje šifrovanie na Plesku

Umožňuje šifrovanie na Plesku

Ovládací panel Plesk obsahuje veľmi peknú integráciu pre Lets Encrypt. Lets Encrypt je jedným z mála poskytovateľov SSL, ktorí rozdávajú kompletné certifikáty

Umožňuje šifrovanie na cPanel

Umožňuje šifrovanie na cPanel

Lets Encrypt je certifikačná autorita, ktorá sa venuje bezplatnému poskytovaniu certifikátov SSL. cPanel vytvoril úhľadnú integráciu, takže vy a váš klient

Ako nainštalovať Concrete5 na CentOS 7

Ako nainštalovať Concrete5 na CentOS 7

Používate iný systém? Concrete5 je open source CMS, ktorý ponúka mnoho charakteristických a užitočných funkcií, ktoré pomáhajú redaktorom jednoducho vytvárať obsah

Ako nainštalovať revíznu tabuľu na CentOS 7

Ako nainštalovať revíznu tabuľu na CentOS 7

Používate iný systém? Review Board je bezplatný a otvorený zdrojový nástroj na kontrolu zdrojového kódu, dokumentácie, obrázkov a mnohých ďalších. Je to webový softvér

Nastavte overenie HTTP pomocou Nginx na CentOS 7

Nastavte overenie HTTP pomocou Nginx na CentOS 7

V tejto príručke sa dozviete, ako nastaviť HTTP autentifikáciu pre webový server Nginx spustený na CentOS 7. Požiadavky Na začiatok budete potrebovať

Ako nainštalovať YOURLS na CentOS 7

Ako nainštalovať YOURLS na CentOS 7

YOURLS (Your Own URL Shortener) je open source aplikácia na skrátenie adresy URL a analýzu údajov. V tomto článku sa budeme zaoberať procesom inštalácie

Ako nainštalovať a nakonfigurovať ArangoDB na CentOS 7

Ako nainštalovať a nakonfigurovať ArangoDB na CentOS 7

Používate iný systém? Úvod ArangoDB je open source databáza NoSQL s flexibilným dátovým modelom pre dokumenty, grafy a hodnoty kľúča. to je

Použitie Etckeeper na kontrolu verzií /etc

Použitie Etckeeper na kontrolu verzií /etc

Úvod Adresár /etc/ hrá rozhodujúcu úlohu v spôsobe fungovania systému Linux. Dôvodom je skutočnosť, že takmer každá konfigurácia systému

Prečo by ste mali používať SSHFS? Ako pripojiť vzdialený súborový systém s SSHFS na CentOS 6

Prečo by ste mali používať SSHFS? Ako pripojiť vzdialený súborový systém s SSHFS na CentOS 6

Mnoho systémových administrátorov spravuje veľké množstvo serverov. Keď je potrebné pristupovať k súborom cez rôzne servery, prihlásenie do každého z nich samostatne ca

Nastavenie servera Half Life 2 na CentOS 6

Nastavenie servera Half Life 2 na CentOS 6

Tento tutoriál sa bude zaoberať procesom inštalácie herného servera Half Life 2 na systém CentOS 6. Krok 1: Inštalácia predpokladov Aby ste mohli nastaviť ou

Ako nainštalovať Laravel GitScrum na CentOS 7

Ako nainštalovať Laravel GitScrum na CentOS 7

Laravel GitScrum alebo GitScrum je nástroj na zvýšenie produktivity s otvoreným zdrojom určený na pomoc vývojovým tímom implementovať metodiku Scrum podobným spôsobom.

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Umelá inteligencia nie je v budúcnosti, je tu priamo v súčasnosti V tomto blogu si prečítajte, ako aplikácie umelej inteligencie ovplyvnili rôzne sektory.

Útoky DDOS: Stručný prehľad

Útoky DDOS: Stručný prehľad

Ste aj vy obeťou DDOS útokov a máte zmätok ohľadom metód prevencie? Ak chcete vyriešiť svoje otázky, prečítajte si tento článok.

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Možno ste už počuli, že hackeri zarábajú veľa peňazí, ale premýšľali ste niekedy nad tým, ako môžu zarábať také peniaze? poďme diskutovať.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Chcete vidieť revolučné vynálezy od Google a ako tieto vynálezy zmenili život každého dnešného človeka? Potom si prečítajte na blogu a pozrite si vynálezy spoločnosti Google.

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Koncept samoriadených áut vyraziť na cesty s pomocou umelej inteligencie je snom, ktorý máme už nejaký čas. Ale napriek niekoľkým prísľubom ich nikde nevidno. Prečítajte si tento blog a dozviete sa viac…

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Ako sa veda vyvíja rýchlym tempom a preberá veľa nášho úsilia, zvyšuje sa aj riziko, že sa vystavíme nevysvetliteľnej singularite. Prečítajte si, čo pre nás môže znamenať singularita.

Vývoj ukladania dát – Infografika

Vývoj ukladania dát – Infografika

Spôsoby ukladania údajov sa môžu vyvíjať už od zrodu údajov. Tento blog sa zaoberá vývojom ukladania údajov na základe infografiky.

Funkcionality vrstiev referenčnej architektúry veľkých dát

Funkcionality vrstiev referenčnej architektúry veľkých dát

Prečítajte si blog, aby ste čo najjednoduchším spôsobom spoznali rôzne vrstvy architektúry veľkých dát a ich funkcie.

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

V tomto digitálnom svete sa inteligentné domáce zariadenia stali kľúčovou súčasťou života. Tu je niekoľko úžasných výhod inteligentných domácich zariadení o tom, ako robia náš život, ktorý stojí za to žiť, a ktorý zjednodušujú.

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Spoločnosť Apple nedávno vydala doplnkovú aktualizáciu macOS Catalina 10.15.4 na opravu problémov, ale zdá sa, že táto aktualizácia spôsobuje ďalšie problémy, ktoré vedú k blokovaniu počítačov Mac. Prečítajte si tento článok a dozviete sa viac