توسعه دهنده نرم افزار
مدل های Communication در معماری میکروسرویس (قسمت دوم)
به طور معمول، queue ها از پروتکل های اختصاصی خود استفاده می کنند که پشتیبانی بین پلتفرمی و بین زبانی (cross-language) را ارائه نمی دهند. با گسترش روزافزون معماری های توزیع شده ونیاز به ارتباطات بین پلتفرمی و بین زبانی ، امروزه queue ها پروتکلهای استاندارد میان پلتفرمی و زبانی را نیز پیادهسازی کرده اند. پروتکلهای استانداردی که معمولاً برای این منظور استفاده میشوند عبارتند از
- پروتکل Advanced Message Queuing Protocol (AMQP)
یک پروتکل متنباز پیامگرا است که از پیامهای ناهمزمان پشتیبانی می کند علاوه براین صفبندی با قابلیت اطمینان بالا ، الگو publish-subscribe مبتنی بر موضوع، مسیریابی انعطافپذیر، پیاده سازی تراکنشها و امنیت ارتباط را فراهم میکند. AMQP قابلیت اطمینان، مقیاس پذیری و قابلیت همکاری را بین پلتفرم ها و ابزار های مختلف رافراهم می کند.
- پروتکل Simple/Streaming Text Oriented Messaging Protocol (STOMP)
یک پروتکل ساده مبتنی بر متن است که برای انتقال داده ها بین برنامه های کاربردی توسعه یافته در زبان ها و پلتفرم های مختلف استفاده می شود. این پروتکل از مفهوم صف و موضوع (topic) استفاده نمی کند و پیام ها را با یک رشته متنی به مقصد ارسال می کند. این پروتکل زمانی قابل استفاده است که نیاز به یک برنامه ساده صف بندی پیام بدون نیاز به صف باشد.
- پروتکل Message Queuing Telemetry Transport (MQTT)
این پروتکل الگو publish-subscribe را بدون استفاده از صف ارائه میکند. پیاده سازی جمع و جور و کم حجم آن را برای سیستمهای تعبیهشده، برنامههای مبتنی بر اینترنت اشیا (IoT) مناسب میکند. به عنوان مثال، Broker های مبتنی بر MQTT میتوانند هزاران اتصال همزمان از دستگاه های گوناگون را پشتیبانی کنند. MQTT برای ارسال پیام ها از یک بسته باینری فشرده (compact binary packet) استفاده می نماید که آن را برای برنامههایی مانند بهروزرسانی حسگرها، بهروزرسانیهای قیمت سهام، اعلانهای موبایل و غیره مناسب میکند.
ابزارهای message queuing زیادی توسط کمپانی ها و انجمن های متن باز ارائه شده اند که برخی از آنها عبارتند از :
- IBM MQ
- Java Message Service (JMS)،
- Apache ActiveMQ،
- Rabbit MQ
- Apache Kafka،
- Apache RocketMQ،
- Amazon Simple Queue Service،
- JBoss messaging
متداول ترین Broker هایی که امروزه برای ارتباطات ناهمزمان در معماری میکروسرویس استفاده می شوند Apache Kafka و Rabbit MQ می باشند .درادامه می خواهیم ارتباط ناهمزمان با استفاده از Rabbit MQ را بررسی نماییم
ارتباط ناهمزمان با Rabbit MQ Message Broker
واسطههای پیام بهعنوان میانافزار بین میکروسرویسها استفاده میشوند که در آن یک میکروسرویس میتواند پیامهای خود را به یک کارگزار ارسال/تحویل (انتشار) کند، و سایر خدمات خرد که میتوانند به کارگزار متصل شوند و پیامها را دریافت یا مشترک شوند. هدف اصلی کارگزار پیام، ایجاد جدایی بین تولیدکننده پیام و مصرف کننده پیام است. بنابراین، با یک کارگزار، تولید کننده پیام از جنبه های مرتبط با ارتباطات رها می شود و روی کار اصلی تمرکز می کند.کارگزار مسئول انتقال مطمئن پیام به گیرنده است. سرویس پیام جاوا محبوب ترین API ناهمزمان جاوا است. اما محدودیت JMS این است که فقط از زبان جاوا پشتیبانی می کند و بنابراین برای برقراری ارتباط با برنامه های غیر جاوا ناکافی می شود. یکی دیگر از کارگزاران پیام محبوب و سنتی RabbitMQ است. RabbitMQ توسط Rabbit Technologies Ltd توسعه یافته است که توسط SpringSource، بخشی از VMware خریداری شده است.پروژه RabbitMQ به بخشی از نرم افزار Pivotal تبدیل شد و در سال 2013 منتشر شد. هدف اولیه RabbitMQ ارائه یک واسطه پیام قابل همکاری بود. پشتیبانی از سیستم های چند زبانه و متقابل را فراهم می کند. برخلاف صفهای پیام قبلی، مانند صف IBM یا JMS یا صف پیام مایکروسافت، RabbitMQ یک واسطه پیام متنباز، بیطرف و بیطرف به زبان است. RabbitMQ در Erlang توسعه یافته است. RabbitMQ روی بسیاری از سیستم عامل ها و در محیط های ابری اجرا می شود. طیف گسترده ای از ابزارهای توسعه دهنده را برای اکثر زبان های محبوب فراهم می کند
کارگزار RabbitMQ اولین کارگزاری بود که پروتکل AMQP را پیاده سازی کرد.پروتکل AMQP شامل دو جنبه هست :
- مجموعه ای از قابلیت های پیام رسانی (درسطح برنامه و در سطح سرویس سرور) که به نام مدل AMQ شناخته می شوند. مدل AMQ شامل مجموعهای از مؤلفهها است که پیامها را در یک سرور هدایت و ذخیره میکند و همچنین مجموعهای از قوانینی که ارتباط معنا دار این مؤلفهها با یکدیگر را فراهم می کند. دقیقاً، این بخش از پروتکل، معماری سطح بالاتری را برای کارگزاران پیام ارائه می دهد.
- یک پروتکل در سطح شبکه به نام AMQP که کلاینت با استفاده از آن می تواند با کارگزار پیام تعامل داشته باشد
مدل AMQ
اجزای اصلی مدل AMQ عبارتند از
- پیام ها (Messages)
پیام یک بسته اطلاعاتی است که از دو بخش، هدر (header) و بدنه تشکیل شده است.
- تولیدکنندگان پیام (Message producers)
تولیدکنندگان پیام برنامههایی هستند که پیامها را ایجاد کرده و به کارگزار ارسال میکنند. یک تولیدکننده پیام پیامهای خود را همراه با کلید مسیریابی (routing key) منتشر میکند، که این کلید جهت مسیریابی مصرف کننده پیام توسط مؤلفه تبادل (exchange) استفاده میشود. کلید مسیریابی یکی از اجزا پیام است. درواقع کلید مسیریابی یک آدرس مجازی به مؤلفه تبادل (exchange) می دهد که توسط آن پیام را به سمت مصرف کننده صحیح هدایت کند
- مصرف کنندگان پیام (Message consumers)
برنامه هایی هستند که به صف (queue ) موجود در کارگزار متصل می شوند و پیام های خود را دریافت می کنند.
- کارگزاران/سرورهای پیام (Message Brokers/Servers)
پیامهای منتشر شده توسط تولیدکننده پیام را بصورت ناهمزمان در اختیار مصرفکنندگان مورد نظر قرارمی دهند. کارگزار دو جزء کلیدی دارد
- مولفه Exchange
مولفه تبادل (Exchange) مسیریابی پیام ها را انجام می دهد.در واقع پیام ها در Exchange های داخل کارگزار منتشر می شوند. سپس Exchange کپیهایی از آن پیامها را طبق قوانین خاص که bindings نام دارند و توسط توسعهدهنده تعریفشده در صفها توزیع میکند. Binding یک رابطه بین یک Exchange و یک صف است. هر صف با یک Exchange از طریق یک binding key یکتا مرتبط می شوند. (دقت کنید binding key ربطی به routing key ندارد)
- مولفه Queue
موجودیتی که پیام ها را در حافظه یا روی دیسک (که توسط Exchange مسیریابی شده اند) ذخیره می کند و آنها را به یک یا چند مصرف کننده تحویل می دهد صف نامیده می شود . صف ها اجزای دو طرفه هستند. سمت ورودی یک صف پیام ها را از یک یا چند Exchange دریافت می کند و سمت خروجی صف به یک یا چند مصرف کننده پیام متصل است. هر پیام تا زمانی که توسط مصرف کننده پیام دریافت شود در صف ذخیره می ماند.صف دارای ویژگیهای مختلفی مانند خصوصی/اشتراکی (private/shared)، بادوام/موقت (durable/temporary)، و غیره است. این ویژگیها برای پیادهسازی یک صف با ویژگیهای عملکردی متفاوت مفید هستند. به عنوان مثال، یک صف خصوصی برای رساندن پیام به یک مصرف کننده خاص یا منفرد است، در حالی که یک صف اشتراکی پیام را به چند مصرف کننده تحویل می دهد.
مطلبی دیگر از این انتشارات
API Gateway به زبان ساده (قسمت اول)
مطلبی دیگر از این انتشارات
مدل های Communication در معماری میکروسرویس (قسمت اول)
مطلبی دیگر از این انتشارات
Scalability and Architecture Trade-Offs