در سالهای اخیر، معماری میکروسرویس، یکی از محبوبترین روشها برای طراحی نرمافزار بودهاست. جهت بهبود کارآیی، رفع خطا، درک عملکرد سیستم در محیط عملیاتی و نمایش چگونگی فراخوانی سرویسها توسط یکدیگر میتوانیم از ابزارهای distributed tracing استفاده کنیم. ابزارهای متنوعی برای این منظور وجود دارند، اما بطور کلی همه با روش مشابهی کار میکنند. اطلاعات مربوط به فعالیتهایی مثل فراخوانی سرویس و مراجعه به دیتابیس که درون میکروسرویس رخ میدهد، د ...
معماری میکرو سرویس یا یکپارچه؟ برای درک میکروسرویسها، باید بدانیم کاربرد سیستمهای یکپارچه چیست و چه چیزی باعث شد در زمانهای اخیر از برنامههای یکپارچه به میکروسرویسها حرکت
کنیم. سیستمهای یکپارچه ( Monolithic applications ) اگر تمام عملکردهای یک پروژه در یک بخش واحد وجود داشته
باشند، آن برنامه به عنوان یک برنامهی یکپارچه شناخته میشود. ما برنامهی خود را در
لایههای مختلفی ...
RabbitMq شبیه به یک صف FIFO عمل میکند؛ یعنی دادهها به ترتیب وارد queue میشوند و به ترتیب نیز به Consumerها ارسال میشوند. برای شروع، یک سولوشن جدید را به نام RabbitMqExample ایجاد میکنیم و پروژههای زیر را به آن اضافه میکنیم. یک پروژه از نوع Asp.Net Core Web Application ایجاد میکنیم به نام RabbiMqExample.Producer که همان ارسال کننده (Producer) میباشد. یک پروژه از نوع Asp.Net Core Web Application به نام RabbitMqExample.Consumer برای ...
در قسمت اول این مقاله ، مشخصات کلیدی یک سرویس مورد بررسی قرار گرفت و APIها و وابستگیها یا Dependencies هر سرویس نیز مورد بررسی قرار گرفتند. همانطور که مشخص است با زیاد شدن این سرویسها و وابستگی هایی که به یکدیگر پیدا میکنند، سردرگمیها نیز برای اعضای تیمهای مختلف، زیاد میگردد. چرا که افراد هر تیم دائما باید از APIهای ارائه شده توسط تیمهای دیگر مطلع باشند. به همین جهت زمانیکه شما یک سبک معماری مانند میکروسرویس را انتخاب مینمایید، ...
معماری میکروسرویس (یا به اختصار: میکروسرویس) یک سبک معماری نرم افزار میباشد که در آن یک نرم افزار، به مجموعهای از سرویسها خرد میشود؛ به نحوی که هر سرویس مسئولیت انجام بخشی از منطق کسب و کار را به عهده داشته باشد.
این تقسیم بندی مزایای متعددی را به همراه دارد که نهایتا پیاده سازی و توسعه راحتتر نرم افزارهای بزرگ و پیچیده را ممکن مینماید. از جمله مزایای این معماری میتوا ...
Protocol Buffers فرمتی جدید برای تبادل دیتا بین سرور و کلاینت میباشد که توسط گوگل طراحی و ساخته شده است و همچنین اکثر زیرساختهای گوگل از این فرمت برای تبادل اطلاعات بین سرویسها استفاده میکنند. Protocol Buffer را میتوان به عنوان جایگزینی برای JSON/XML بکار برد و به دلایل زیادی که در ادامه دربارهی آن صحبت میکنیم میتواند گزینهی مناسبی برای Microservicesها باشد و همچنین سرعت بالا، سادگی در استفاده، پشتیبانی از زبانهای برنامه نویسی متع ...
در قسمت قبل با مفهوم مایکرو سرویسها آشنا شدیم. سرویسهای کوچک و مجزایی که بصورت مستقل، قابلیت توسعه و استقرار دارند و در راستای انجام یک قابلیت کسب و کار در اختیار دیگران قرار میگیرند. ویژگیهای یک مایکرو سرویس چیست؟ بعد از آشنایی با معماری مایکرو سرویسها میخواهیم با ویژگیهای آن آشنا شویم. البته باید به این نکته توجه داشت که همهی معماریهای مایکروسرویسها این ویژگیها را ندارند؛ ولی میتوان انتظار داشت اکثر آنها این ویژگیها ...
در نرم افزارهای Enterprise، توسعه محصول، چالش اصلی تیم نمیباشد. اصلیترین چالش، بعد از استقرار نرم افزار و زیر بار رفتن آن بهوجود میآید؛ مسائلی نظیر مدیریت تغییرات و scaling و چنانچه نرم افزار بصورت صحیحی توسعه نیافته باشد، میتوان گفت که انجام موارد ذکر شده بسیار سخت یا شاید غیر ممکن شوند و باید نرم افزار، بازنویسی شود. برای روشن شدن موضوع یک مثال میزنم. فرض کنید یک نرم افزار جامع بیمه (Core Insurance) داریم که بصورت یک نرم ...
همانطور که در مطلب آشنایی با معماری Microservices گفته شد، Seneca یک فریمورک مبتنی بر Node.js برای ساخت برنامههای سمت سرور بر مبنای معماری Microservices با هسته Monolithic است. در این مطلب قصد ارائه یک مثال عملی را بر اساس این فریمورک ندارم. هدف، آشنایی با اجزای اصلی Seneca و چهارچوب کاری آن است. فواید استفاده از فریمورک Seneca فریمورک Seneca کدنویسی برای ایجاد درخواستها، ارسال پاسخ به درخواستهای رسیده و تبدیل د ...
برنامههای بزرگ سمت سرور که با تعداد بسیار زیادی کاربر و داده سر و کار دارند، نباید فقط درگیر پاسخگویی سریع و فراهم کردن وب سرویسها برای پلتفرمهای مختلف باشند. این برنامهها باید بتوانند به سادگی رشد کرده، ارتقاء پیدا کنند و به روز شوند. برای ساخت و توسعه این نوع برنامهها، دو مدل معماری وجود دارد: یکی معماری Monolithic و دیگری معماری Microservices. برای شناخت معماری Microservices، ابتدا بایستی با معماری Monolithic آشنا شد. ...