Cluster RabbitMQ på CentOS 7

RabbitMQ är en meddelandemäklare med öppen källkod som stöder AMQP, STOMP och andra kommunikationsteknologier. Det används ofta i företagsapplikationer och moderna mikrotjänstarkitekturer där det fungerar som en asynkron meddelandekanal mellan olika mikrotjänster. Den här guiden kommer att beskriva hur du kan klustera RabbitMQ på flera CentOS 7-servrar för att bilda en meddelandeförmedlare med hög tillgänglighet. I den här handledningen kommer en server att fungera som en huvudserver och de andra servrarna kommer att fungera som spegelservrar om huvudservern blir otillgänglig.

Förutsättningar

Konfigurera brandväggen

CentOS-brandväggen, ( firewalld), tillåter inte någon inkommande trafik som standard. För att göra RabbitMQ tillgängligt för andra system i och utanför nätverket, och för att vi ska kunna komma åt hanteringskonsolen, måste vi först öppna några portar.

RabbitMQs webbgränssnittshanteringskonsol lyssnar som standard på port 15672. Vi vill göra hanteringskonsolen allmänt tillgänglig så att vi kan komma åt den från vår dator. Vi kommer därför att instruera firewalldatt permanent öppna porten 15672i den offentliga zonen (vilket är standardzonen och den aktiva zonen på en Vultr-instans).

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

RabbitMQ-noderna måste kunna kommunicera med varandra. Vi skulle vilja öppna de nödvändiga portarna, men bara över det interna nätverket. Vi vill inte att någon på internet ska kunna administrera eller direkt kontakta våra servrar. Följande kommandon förutsätter att våra servrar finns på 192.168.0.100/24undernätet.

Den första tjänsten är epmdpeer discovery-tjänsten som lyssnar som standard på port 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'

För internod- och CLI-kommunikation måste RabbitMQ kunna kommunicera över 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'

CLI - verktygen kommunicerar över portarnas intervall 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'

Om dina applikationer behöver AMQP-protokollet måste du också öppna portar 5671och 5672. Om du behöver kunna kommunicera över ett annat protokoll kan du hitta nödvändig information om nätverkskraven för RabbitMQ i den officiella RabbitMQ-dokumentationen .

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'

Nu det firewalldär konfigurerat måste vi instruera det att ladda om konfigurationen.

sudo firewall-cmd --reload

Upprepa stegen från det här avsnittet på alla servrar.

Installera rabbitmqadmin

Hanteringspluginen kommer med ett Python-verktyg som heter rabbitmqadminsom enkelt kan installeras på systemet när hanteringspluginen är aktiverad.

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

Konfigurera DNS

Du måste använda serverns värdnamn för att identifiera servrarna vid klustring. Som standard har servrarna ingen DNS-post tilldelad och anslutningen kommer att misslyckas. För att snabbt övervinna detta, lägg till huvud- och spegelvärdnamnet till /etc/hostsfilen med din favoritredigerare.

Till exempel kan din master's hosts-fil se ut så här. Lägg märke till de två sista posterna, som tillåter servrarna att identifiera varandra med sitt värdnamn. Se till att ändra IP-adresserna till dina egna.

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

Klustra noderna

En importförutsättning för att tillåta noder att ansluta sig till varandra är att Erlang-cookien för alla noder är identisk. Som standard kommer varje nod att tilldelas en unik Erlang-cookie, så du måste konfigurera om den på alla noder.

Följande kommando kommer att ställa in Erlang-kakan till " WE<3COOKIES", men ändra gärna detta efter eget tycke. Gör detta på alla servrar.

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

Starta om RabbitMQ på alla servrar för att se till att Erlang-cookien laddas om ordentligt.

sudo systemctl restart rabbitmq-server.service

Utför följande kommandon på alla servrar utom på huvudservern. Detta kommer att låta noderna gå med i huvudservern och bilda ett kluster.

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

Verifiera att noderna har anslutit sig till klustret genom att köra följande kommando.

sudo rabbitmqctl cluster_status

Alla dina noder visas i nodesoch running_nodesdelen av produktionen. Från och med nu behöver du inte längre upprepa steg på varje server, konfigurationen kommer automatiskt att speglas till de andra noderna.

Skapa en policy för hög tillgänglighet

Nu när vi har ett kluster av RabbitMQ-noder kan vi använda detta för att skapa köer och utbyten med hög tillgänglighet genom att sätta upp en ny policy. Denna policy kan läggas till via RabbitMQ Management Console eller med hjälp av kommandoradsgränssnittet.

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

Följande lista kommer att förklara vad varje del av kommandot betyder.

  • -p "/": Använd denna policy på "/"vhost (standard efter installation)
  • --priority 1: Ordningen i vilken policyer ska tillämpas
  • --apply-to "all": Kan vara "queues", "exchanges"eller"all"
  • ha: Namnet vi ger vår policy
  • ".*": Det reguljära uttrycket som används för att bestämma vilka köer eller utbyten denna policy ska tillämpas på. ".*"kommer att matcha vad som helst
  • '{ "ha-mode": "exactly", "ha-params": 2, "ha-sync-mode": "automatic"}': JSON-representationen av policyn. Detta dokument beskriver att vi vill ha - exakt 2 noder på vilka data automatiskt synkroniseras

Kort sagt kommer denna policy att säkerställa att vi alltid kommer att ha 2 kopior av data på en kö eller växel så länge vi har minst 2 noder igång. Om du har fler noder kan du öka värdet på ha-params. Ett kvorum, ( N/2 + 1), av noder rekommenderas. Att ha fler kopior av dina data skulle resultera i högre disk-, i/o- och nätanvändning vilket kan resultera i försämrad prestanda.

Om du vill spegla data till alla noder i klustret kan du använda följande JSON-dokument.

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

Om du bara vill spegla data till specifika noder (till exempel: node-1och node-2), kan du använda följande.

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

Du kan ändra det reguljära uttrycket för att tilldela olika principer till olika köer. Säg att vi har följande tre noder:

  • kanin@mästare
  • kanin@klient-ha
  • kanin@produkt-ha

Vi kan sedan skapa två policyer som kommer att resultera i att köer som har ett namn som börjar med "klient" speglas till rabbit@client-hanoden och att alla köer som har ett namn som börjar med "produkt" speglas till rabbit@product-hanoden.

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"}

En liten anmärkning här: exklusiva köer är aldrig speglade eller hållbara i RabbitMQ, även om denna policy skulle matcha sådana köer. Exklusiva köer förstörs automatiskt när en klient kopplar från och som sådan skulle det inte vara till någon nytta att replikera den till en annan server. Om servern skulle misslyckas, skulle klienten koppla från den och kön skulle förstöras automatiskt. Speglade instanser skulle också förstöras.

Testar inställningen

För att testa den klustrade inställningen kan vi skapa en ny kö med hjälp av kommandoradsgränssnittet via hanteringskonsolen.

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

Detta kommer att skapa en varaktig kö på standard /vhost med namnet my-ha-queue.

Kör följande kommando och verifiera i utgången att kön har vår 'ha'-policy tilldelad och har pid's på mastern och på en spegelnod.

sudo rabbitmqctl list_queues name policy state pid slave_pids

Vi kan nu publicera ett meddelande till kön från masternoden och stoppa RabbitMQ på masternoden.

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

Få det nu tillbaka genom att ansluta till spegelnoden.

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

Slutligen kan vi starta om vår huvudnod.

sudo systemctl start rabbitmq-server.service

Ta bort gästanvändaren

Som nämnts tidigare skapar RabbitMQ automatiskt en gästanvändare med ett standard gästlösenord. Det skulle vara dålig praxis att lämna denna standardanvändare på ett offentligt exponerat system.

sudo rabbitmqctl delete_user guest

Installera Plesk på CentOS 7

Installera Plesk på CentOS 7

Använder du ett annat system? Plesk är en egen kontrollpanel för webbhotell som tillåter användare att administrera sina personliga och/eller klienters webbplatser, databaser

Hur man installerar Squid Proxy på CentOS

Hur man installerar Squid Proxy på CentOS

Squid är ett populärt, gratis Linux-program som låter dig skapa en webbproxy för vidarebefordran. I den här guiden ser du hur du installerar Squid på CentOS för att förvandla dig

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Inledning Lighttpd är en apachegaffel som syftar till att vara mycket mindre resurskrävande. Den är lätt, därav namnet, och är ganska enkel att använda. Installera

Konfigurera statiskt nätverk och IPv6 på CentOS 7

Konfigurera statiskt nätverk och IPv6 på CentOS 7

VULTR har nyligen gjort ändringar på deras sida, och allt borde nu fungera bra direkt när NetworkManager är aktiverat. Om du vill inaktivera

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Icinga2 är ett kraftfullt övervakningssystem, och när det används i en master-klient-modell kan det ersätta behovet av NRPE-baserade övervakningskontroller. Master-klienten

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Använder du ett annat system? Apache Cassandra är ett gratis NoSQL-databashanteringssystem med öppen källkod som är designat för att ge skalbarhet, hög

Hur man installerar Microweber på CentOS 7

Hur man installerar Microweber på CentOS 7

Använder du ett annat system? Microweber är en öppen källkod för dra och släpp CMS och onlinebutik. Microweber källkod finns på GitHub. Denna guide kommer att visa dig

Hur man installerar Vanilla Forum på CentOS 7

Hur man installerar Vanilla Forum på CentOS 7

Använder du ett annat system? Vanilla forum är en open source forumapplikation skriven i PHP. Det är en helt anpassningsbar, enkel att använda och stöder externa

Hur man installerar Mattermost 4.1 på CentOS 7

Hur man installerar Mattermost 4.1 på CentOS 7

Använder du ett annat system? Mattermost är ett alternativ med öppen källkod, självvärd till meddelandetjänsten Slack SAAS. Med andra ord, med Mattermost, du ca

Skapa ett nätverk av Minecraft-servrar med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Skapa ett nätverk av Minecraft-servrar med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Vad du behöver En Vultr VPS med minst 1 GB RAM. SSH-åtkomst (med root-/administrativa privilegier). Steg 1: Installera BungeeCord Först till kvarn

Låt oss kryptera på Plesk

Låt oss kryptera på Plesk

Plesks kontrollpanel har en mycket trevlig integration för Lets Encrypt. Lets Encrypt är en av de enda SSL-leverantörerna som ger ut certifikat fullständigt

Låter kryptera på cPanel

Låter kryptera på cPanel

Lets Encrypt är en certifikatmyndighet dedikerad till att tillhandahålla SSL-certifikat gratis. cPanel har byggt en snygg integration så att du och din klient

Hur man installerar Concrete5 på CentOS 7

Hur man installerar Concrete5 på CentOS 7

Använder du ett annat system? Concrete5 är ett CMS med öppen källkod som erbjuder många distinkta och användbara funktioner för att hjälpa redaktörer att producera innehåll enkelt och

Hur man installerar Review Board på CentOS 7

Hur man installerar Review Board på CentOS 7

Använder du ett annat system? Review Board är ett gratis och öppen källkodsverktyg för att granska källkod, dokumentation, bilder och många fler. Det är webbaserad mjukvara

Ställ in HTTP-autentisering med Nginx på CentOS 7

Ställ in HTTP-autentisering med Nginx på CentOS 7

I den här guiden lär du dig hur du ställer in HTTP-autentisering för en Nginx-webbserver som körs på CentOS 7. Krav För att komma igång behöver du

Hur man installerar YOURLS på CentOS 7

Hur man installerar YOURLS på CentOS 7

YOURLS (Your Own URL Shortener) är ett webbadressförkortnings- och dataanalysprogram med öppen källkod. I den här artikeln kommer vi att täcka installationsprocessen

Hur man installerar och konfigurerar ArangoDB på CentOS 7

Hur man installerar och konfigurerar ArangoDB på CentOS 7

Använder du ett annat system? Inledning ArangoDB är en NoSQL-databas med öppen källkod med en flexibel datamodell för dokument, grafer och nyckel-värden. Det är

Använda Etckeeper för versionskontroll av /etc

Använda Etckeeper för versionskontroll av /etc

Inledning Katalogen /etc/ spelar en avgörande roll för hur ett Linux-system fungerar. Anledningen till detta är att nästan varje systemkonfiguration

Varför ska du använda SSHFS? Hur man monterar ett fjärrfilsystem med SSHFS på CentOS 6

Varför ska du använda SSHFS? Hur man monterar ett fjärrfilsystem med SSHFS på CentOS 6

Många systemadministratörer hanterar stora mängder servrar. När filer behöver nås över olika servrar, logga in på var och en individuellt ca

Konfigurera en Half Life 2-server på CentOS 6

Konfigurera en Half Life 2-server på CentOS 6

Denna handledning kommer att täcka processen att installera en Half Life 2-spelserver på CentOS 6 System. Steg 1: Installera förutsättningarna För att ställa in ou

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Artificiell intelligens är inte i framtiden, det är här i nuet I den här bloggen Läs hur Artificiell intelligens-applikationer har påverkat olika sektorer.

DDOS-attacker: En kort översikt

DDOS-attacker: En kort översikt

Är du också ett offer för DDOS-attacker och förvirrad över de förebyggande metoderna? Läs den här artikeln för att lösa dina frågor.

Har du någonsin undrat hur hackare tjänar pengar?

Har du någonsin undrat hur hackare tjänar pengar?

Du kanske har hört att hackare tjänar mycket pengar, men har du någonsin undrat hur de tjänar den typen av pengar? låt oss diskutera.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Vill du se revolutionerande uppfinningar av Google och hur dessa uppfinningar förändrade livet för varje människa idag? Läs sedan till bloggen för att se uppfinningar av Google.

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Konceptet med att självkörande bilar ska ut på vägarna med hjälp av artificiell intelligens är en dröm vi har ett tag nu. Men trots flera löften finns de ingenstans att se. Läs den här bloggen för att lära dig mer...

Technological Singularity: A Distant Future of Human Civilization?

Technological Singularity: A Distant Future of Human Civilization?

När vetenskapen utvecklas i snabb takt och tar över en hel del av våra ansträngningar, ökar också riskerna för att utsätta oss för en oförklarlig singularitet. Läs, vad singularitet kan betyda för oss.

Utveckling av datalagring – Infographic

Utveckling av datalagring – Infographic

Lagringsmetoderna för data har utvecklats kan vara sedan födelsen av data. Den här bloggen tar upp utvecklingen av datalagring på basis av en infografik.

Funktioner för Big Data Reference Architecture Layers

Funktioner för Big Data Reference Architecture Layers

Läs bloggen för att känna till olika lager i Big Data Architecture och deras funktionaliteter på enklaste sätt.

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

I denna digitala värld har smarta hemenheter blivit en avgörande del av livet. Här är några fantastiska fördelar med smarta hemenheter om hur de gör vårt liv värt att leva och enklare.

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

Nyligen släppte Apple macOS Catalina 10.15.4, en tilläggsuppdatering för att åtgärda problem, men det verkar som om uppdateringen orsakar fler problem som leder till att mac-datorer blir murade. Läs den här artikeln för att lära dig mer