خوشه بندی RabbitMQ در CentOS 7

RabbitMQ یک کارگزار پیام منبع باز است که از AMQP ، STOMP و سایر فن آوری های ارتباطی پشتیبانی می کند. این نرم افزار به طور گسترده ای در برنامه های سازمانی و معماری های جدید خدمات میکرو استفاده می شود ، جایی که به عنوان یک کانال پیام ناهمزمان بین خدمات مختلف میکرو عمل می کند. در این راهنما توضیح داده می شود که چگونه می توانید RabbitMQ را روی چندین سرور CentOS 7 خوشه بندی کنید تا یک کارگزار پیام با دسترسی بالا تهیه کنید. در این آموزش ، در صورت عدم دسترسی سرور اصلی ، یک سرور به عنوان سرور اصلی عمل می کند و سرورهای دیگر به عنوان سرورهای آینه عمل می کنند.

پیش نیازها

دیوار آتش را پیکربندی کنید

فایروال CentOS ، ( firewalld) ، به طور پیش فرض هیچگونه ترافیک ورودی را مجاز نمی کند. برای اینکه RabbitMQ برای سایر سیستم های موجود در داخل و خارج از شبکه در دسترس باشد و به ما اجازه دسترسی به کنسول مدیریت را بدهد ، ابتدا باید برخی از درگاه ها را باز کنیم.

کنسول مدیریت رابط وب RabbitMQ بطور پیش فرض درگاه گوش می دهد 15672. ما می خواهیم کنسول مدیریت را به صورت عمومی در دسترس قرار دهیم تا بتوانیم از رایانه خود به آن دسترسی پیدا کنیم. بنابراین ما دستور خواهیم داد firewalldتا بندر را به طور دائم 15672در منطقه عمومی باز کنیم (که منطقه پیش فرض و فعال در نمونه Vultr است).

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

گره های RabbitMQ باید بتوانند با یکدیگر ارتباط برقرار کنند. ما می خواهیم پورت های لازم را باز کنیم ، اما فقط از طریق شبکه داخلی. ما نمی خواهیم کسی در اینترنت بتواند سرورهای ما را اداره یا ارتباط مستقیمی دهد. دستورات زیر فرض می کنند که سرورهای ما در 192.168.0.100/24زیر شبکه هستند.

سرویس اول سرویس epmdکشف همتا است که بطور پیش فرض در بندر گوش می دهد 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'

برای ارتباط بین اینترود و CLI ، RabbitMQ باید بتواند از طریق درگاه ارتباط برقرار کند 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 از طریق درگاهها ارتباط برقرار می کنند 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'

اگر برنامه های شما به پروتکل AMQP نیاز دارند ، شما نیز نیاز به باز کردن پورت ها 5671و 5672. در صورت نیاز به برقراری ارتباط با پروتکل دیگر ، می توانید اطلاعات لازم در مورد الزامات شبکه سازی RabbitMQ را در اسناد رسمی 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'

اکنون که firewalldپیکربندی شده است ، باید آن را راهنمایی کنیم تا دوباره پیکربندی را بارگیری کند.

sudo firewall-cmd --reload

مراحل مربوط به این بخش را در همه سرورها تکرار کنید.

نصب rabbitmqadmin

افزونه مدیریت با ابزاری Python همراه است rabbitmqadminکه پس از فعال شدن افزونه مدیریت ، به راحتی روی سیستم نصب می شود.

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

پیکربندی DNS

برای شناسایی سرورها هنگام خوشه بندی باید از نامهای میزبان سرور استفاده کنید. به طور پیش فرض ، سرورها ضبط DNS ندارند و اتصال خراب می شود. برای رفع سریع این مسئله ، /etc/hostsبا استفاده از ویرایشگر مورد علاقه خود ، نام میزبان اصلی و آینه را به پرونده اضافه کنید.

به عنوان مثال ، پرونده میزبان استاد شما ممکن است شبیه موارد زیر باشد. به دو رکورد آخر توجه کنید ، که به سرورها امکان می دهد یکدیگر را با نام میزبان خود مشخص کنند. حتماً آدرس IP را به دلخواه خود تغییر دهید.

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

گره ها را خوشه می زنند

پیش شرط وارد کردن اجازه می دهد گره ها به یکدیگر بپیوندند این است که کوکی ارلانگ همه گره ها یکسان هستند. به طور پیش فرض ، به هر گره یک کوکی ارلانگ منحصر به فرد اختصاص داده می شود ، بنابراین باید آن را در همه گره ها مجددا پیکربندی کنید.

دستور زیر کوکی ارلانگ را " WE<3COOKIES" تنظیم می کند ، اما احساس راحتی کنید که به دلخواه خود تغییر دهید. این کار را روی همه سرورها انجام دهید.

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

راه اندازی مجدد RabbitMQ در تمام سرورها برای اطمینان از بارگیری مجدد کوکی Erlang.

sudo systemctl restart rabbitmq-server.service

دستورات زیر را روی همه سرورها به جز در سرور اصلی اجرا کنید. این کار باعث می شود گره ها به سرور اصلی بپیوندند و یک خوشه تشکیل دهند.

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

با اجرای دستور زیر تأیید کنید که گره ها به خوشه پیوسته اند.

sudo rabbitmqctl cluster_status

تمام گره های شما در nodesو running_nodesبخش خروجی ظاهر می شوند . از این پس ، دیگر نیازی به تکرار مراحل روی هر سرور ندارید ، پیکربندی به صورت خودکار به گره های دیگر آینه می شود.

یک خط مشی در دسترس بالا ایجاد کنید

اکنون که ما یک خوشه گره RabbitMQ داریم ، می توانیم با تنظیم یک خط مشی جدید ، از صفحات در دسترس بالا و مبادله استفاده کنیم. این خط مشی را می توان از طریق کنسول مدیریت RabbitMQ یا با استفاده از رابط خط فرمان اضافه کرد.

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

لیست زیر توضیح می دهد که هر قسمت از دستور چیست.

  • -p "/": از این خط مشی در "/"vhost استفاده کنید (پیش فرض بعد از نصب)
  • --priority 1: ترتیب استفاده از خط مشی ها
  • --apply-to "all": می تواند باشد "queues"، "exchanges"یا"all"
  • ha: نامی که ما به سیاست خود می دهیم
  • ".*": عبارت معمولی که برای تصمیم گیری در مورد این خط مشی ها یا مبادلات استفاده می شود استفاده می شود. ".*"با هر چیزی مطابقت خواهد داشت
  • '{ "ha-mode": "exactly", "ha-params": 2, "ha-sync-mode": "automatic"}': نمایندگی JSON از خط مشی. این سند توصیف می کند که ما می خواهیم - دقیقاً 2 گره ای که داده ها به طور خودکار همزمان می شوند

به طور خلاصه ، این سیاست اطمینان حاصل خواهد کرد که ما همیشه 2 نسخه از داده ها را در صف یا مبادله خواهیم داشت تا زمانی که حداقل 2 گره داشته باشیم و در حال اجرا باشیم. اگر گره های بیشتری دارید می توانید مقدار را افزایش دهید ha-params. ( N/2 + 1) ، از گره ها سهم ( ) استفاده می شود. داشتن نسخه های بیشتر از داده های شما منجر به دیسک بالاتر ، i / o و استفاده خالص می شود که می تواند منجر به عملکرد تخریب شود.

اگر می خواهید داده ها را در تمام گره های خوشه آینه کنید ، می توانید از سند JSON زیر استفاده کنید.

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

اگر می خواهید داده ها را فقط به گره های خاص (مثلاً: node-1و node-2) آینه کنید ، می توانید از موارد زیر استفاده کنید.

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

می توانید عبارت معمولی را برای اختصاص خط مشی های مختلف در صف های مختلف تغییر دهید. بگویید ما سه گره زیر داریم:

  • خرگوش @ استاد
  • خرگوش @ مشتری-هکتار
  • خرگوش @ product-ha

سپس می توانیم دو خط مشی ایجاد كنیم كه منجر به آن می شود كه صف هایی كه اسمی را شروع می كنند با "مشتری" شروع می شود تا rabbit@client-haگره آینه شود و تمام صف هایی كه دارای یك نام هستند كه با "محصول" شروع می شوند تا به rabbit@product-haگره آینه شوند .

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

یک نکته کوچک در اینجا: صف های اختصاصی هرگز در RabbitMQ آینه یا دوام نمی شوند ، حتی اگر این سیاست با چنین صف هایی مطابقت داشته باشد. پس از قطع مشتری ، صف های اختصاصی به طور خودکار از بین می روند و به همین ترتیب ، تکرار مجدد آن به سرور دیگر فایده ای ندارد. اگر سرور خراب شود ، مشتری از آن جدا می شود و صف به طور خودکار از بین می رود. نمونه های آینه ای نیز از بین می روند.

آزمایش تنظیمات

به منظور آزمایش تنظیمات خوشه ای می توانیم یک صف جدید را با استفاده از رابط خط فرمان از طریق کنسول مدیریت ایجاد کنیم.

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

این کار یک صف ماندگار در /vhost پیش فرض با نام ایجاد می کند my-ha-queue.

دستور زیر را اجرا کنید و در خروجی تأیید کنید که صف سیاست "ha" ما اختصاص داده شده است و دارای پید روی استاد و گره آینه است.

sudo rabbitmqctl list_queues name policy state pid slave_pids

اکنون می توانیم پیامی را از گره master منتشر کرده و RabbitMQ را روی گره اصلی متوقف کنیم.

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

اکنون با اتصال به گره آینه ، آن را به عقب برگردانید.

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

سرانجام ، می توانیم گره اصلی خود را مجدداً راه اندازی کنیم.

sudo systemctl start rabbitmq-server.service

کاربر مهمان را حذف کنید

همانطور که قبلاً ذکر شد ، RabbitMQ بطور خودکار یک کاربر مهمان با یک رمز عبور پیش فرض مهمان ایجاد می کند. این کار بد خواهد بود که این کاربر پیش فرض را روی یک سیستم در معرض دید عموم بگذارید.

sudo rabbitmqctl delete_user guest


Leave a Comment

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

تنظیم RethinkDB Cluster On CentOS 7

تنظیم RethinkDB Cluster On CentOS 7

مقدمه RethinkDB یک پایگاه داده NoSQL است که داده ها را به عنوان اسناد JSON ذخیره می کند. این یک زبان پرس و جو بسیار بصری است و از ویژگی های آن معمولا در دسترس است

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

Vtiger CRM یک نرم افزار محبوب مدیریت ارتباط با مشتری است که می تواند به بنگاهها در رشد فروش ، ارائه خدمات به مشتری و افزایش سود کمک کند. من

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

با استفاده از یک سیستم متفاوت؟ Couch CMS یک سیستم مدیریت محتوای منبع ساده و انعطاف پذیر ، آزاد و منبع باز (CMS) است که به طراحان وب اجازه می دهد تا طراحی کنند.

نحوه نصب SonarQube در CentOS 7

نحوه نصب SonarQube در CentOS 7

با استفاده از یک سیستم متفاوت؟ SonarQube یک ابزار منبع باز برای توسعه سیستم با کیفیت است. در جاوا نوشته شده است و چندین پایگاه داده را پشتیبانی می کند. فراهم می کند

نصب Netdata در CentOS 7

نصب Netdata در CentOS 7

با استفاده از یک سیستم متفاوت؟ Netdata یک ستاره در حال افزایش در زمینه نظارت بر معیارهای سیستم در زمان واقعی است. در مقایسه با سایر ابزارهای مشابه ، Netdata:

نحوه فعال سازی پشتیبانی HTTP / 2 در DirectAdmin (CentOS)

نحوه فعال سازی پشتیبانی HTTP / 2 در DirectAdmin (CentOS)

HTTP / 2 جدیدترین نسخه پروتکل HTTP است که از SPDY مستقر است. توسعه آن توسط Google آغاز شده است و HTTP / 2 تا حد زیادی بر اساس پایگاه کد است

نحوه نصب سرور Starbound در CentOS 7

نحوه نصب سرور Starbound در CentOS 7

با استفاده از یک سیستم متفاوت؟ در این آموزش ، Ill در مورد نحوه راه اندازی یک سرور Starbound در CentOS 7 توضیح می دهد. پیش نیازها: شما باید این بازی را روی خود داشته باشید

یک سرور چند نفره SA-MP San Andreas را در CentOS 6 تنظیم کنید

یک سرور چند نفره SA-MP San Andreas را در CentOS 6 تنظیم کنید

به یکی دیگر از آموزش های Vultr خوش آمدید. در اینجا ، نحوه نصب و اجرای سرور SAMP را یاد خواهید گرفت. این راهنما برای CentOS 6 نوشته شده است. پیش نیازهای مورد نیاز شما

Elgg را روی CentOS 7 نصب کنید

Elgg را روی CentOS 7 نصب کنید

با استفاده از یک سیستم متفاوت؟ Elgg یک موتور شبکه ای منبع باز است که امکان ایجاد محیط های اجتماعی از جمله شبکه های اجتماعی دانشگاه را فراهم می کند

نحوه نصب سرور RStudio در CentOS 7

نحوه نصب سرور RStudio در CentOS 7

RStudio Server نسخه وب RStudio است که مجموعه ای از ابزارهایی است که برای تسهیل کار برنامه نویسی با استفاده از زبان برنامه نویسی R طراحی شده است. در سه

نصب Bolt CMS در CentOS 7

نصب Bolt CMS در CentOS 7

Bolt یک CMS منبع باز است که به زبان PHP نوشته شده است. کد منبع Bolts در GitHub میزبانی شده است. این راهنما نحوه نصب Bolt CMS را در CentOS 7 Vult تازه نشان می دهد

نحوه نصب Elasticsearch در سرور Vultr CentOS 7

نحوه نصب Elasticsearch در سرور Vultr CentOS 7

Elasticsearch یک موتور جستجوی کامل و متن تحلیلی متن کامل است. به لطف تطبیق پذیری ، مقیاس پذیری و سهولت استفاده ، Elasticsearch گسترده تر است

Kubernetes With Kubeadm را در CentOS 7 مستقر کنید

Kubernetes With Kubeadm را در CentOS 7 مستقر کنید

بررسی اجمالی این مقاله به شما کمک می کند تا در هر زمان خوشه ای از Kubernetes را جمع کنید و با kubeadm در حال اجرا باشید. در این راهنما از دو سرور استفاده می شود

راه اندازی Sails.js برای توسعه در CentOS 7

راه اندازی Sails.js برای توسعه در CentOS 7

با استفاده از یک سیستم متفاوت؟ مقدمه Sails.js یک چارچوب MVC ��رای Node.js است ، شبیه به Ruby on Rails. این امر برای ایجاد برنامه های مدرن ver

پیکربندی BGP با استفاده از Quagga در Vultr (CentOS 7)

پیکربندی BGP با استفاده از Quagga در Vultr (CentOS 7)

Vultrs عملکرد IP فضای شما را امکان پذیر می سازد تا آزادی بی سابقه ای در اختصاص منابع IP شخصی شما به سرورهای cloud Vultr داشته باشید. ما کلی

نحوه نصب PufferPanel (کنترل پنل کنکوری رایگان) در CentOS 7

نحوه نصب PufferPanel (کنترل پنل کنکوری رایگان) در CentOS 7

مقدمه در این آموزش ، PufferPanel را در Vultr VPS ما نصب کنید. PufferPanel یک پانل کنترل با منبع آزاد و بصورت رایگان برای مدیریت شما است

ابزارهای نظارت بهتر برای اوبونتو و CentOS

ابزارهای نظارت بهتر برای اوبونتو و CentOS

معرفی سیستم های لینوکس به طور پیش فرض مانند top ، df و du با ابزارهای نظارتی ارسال می شوند که به نظارت بر فرایندها و فضای دیسک کمک می کنند. با این حال ، اغلب اوقات ، آنها به صورت طاقت فرسا هستند

دستگاه های خود را با استفاده از LibreNMS در CentOS 7 نظارت کنید

دستگاه های خود را با استفاده از LibreNMS در CentOS 7 نظارت کنید

با استفاده از یک سیستم متفاوت؟ LibreNMS یک سیستم نظارت بر شبکه منبع باز کاملاً برجسته است. از SNMP برای به دست آوردن داده ها از دستگاه های مختلف استفاده می کند. یک نوع

نحوه نصب Gitea در CentOS 7

نحوه نصب Gitea در CentOS 7

با استفاده از یک سیستم متفاوت؟ Gitea یک منبع کنترل جایگزین متن باز و خود میزبان است که توسط Git ساخته شده است. Gitea در Golang نوشته شده و هست

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

با استفاده از یک سیستم متفاوت؟ Anchor CMS یک سیستم مدیریت محتوا (CMS) بسیار ساده و بسیار سبک ، بسیار آزاد و آزاد است.

اشتراک NFS را در Debian تنظیم کنید

اشتراک NFS را در Debian تنظیم کنید

NFS یک سیستم فایل مبتنی بر شبکه است که به رایانه ها اجازه می دهد تا از طریق شبکه رایانه ای به فایلها دسترسی پیدا کنند. این راهنما توضیح می دهد که چگونه می توانید پوشه ها را روی NF قرار دهید

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

نحوه نصب Matomo Analytics در Fedora 28

نحوه نصب Matomo Analytics در Fedora 28

با استفاده از یک سیستم متفاوت؟ Matomo (سابقا پیویک) یک بستر تحلیلی منبع باز است ، یک جایگزین باز برای Google Analytics. منبع Matomo میزبان o

یک سرور TeamTalk را در لینوکس تنظیم کنید

یک سرور TeamTalk را در لینوکس تنظیم کنید

TeamTalk یک سیستم کنفرانس است که به کاربران امکان می دهد مکالمات صوتی / تصویری با کیفیت بالا ، چت متنی ، انتقال فایل ها و صفحه های به اشتراک بگذارند. من

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

Vultr یک ویژگی را فراهم می کند که به شما امکان می دهد با ایجاد یک نمونه جدید ، کلیدهای SSH را از قبل نصب کنید. این اجازه می دهد تا به کاربر root دسترسی داشته باشید ، با این حال ، th

نحوه نصب انجمن NodeBB در FreeBSD 12

نحوه نصب انجمن NodeBB در FreeBSD 12

با استفاده از یک سیستم متفاوت؟ NodeBB یک نرم افزار انجمن مبتنی بر Node.js است. از سوکت های وب برای تعامل فوری و اعلامیه های زمان واقعی استفاده می کند. NodeB

نصب و راه اندازی ZNC در اوبونتو

نصب و راه اندازی ZNC در اوبونتو

ZNC یک پیشرانه پیشرفته شبکه IRC است که تمام وقت بهم متصل می شود تا مشتری IRC بتواند بدون از دست دادن جلسه گپ قطع یا وصل شود.

نحوه نصب Ranger Terminal File Manager در لینوکس

نحوه نصب Ranger Terminal File Manager در لینوکس

رنجر یک مدیر فایل مبتنی بر خط فرمان است که دارای کلیدهای اتصال VI است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد