📊 محبوبترین API Clientها در سال ۲۰۲۴ به آمار Cloudflare
روزهای آخر ساله و شرکتهای مختلف، آمار و ارقامشون رو میگذارن روی میز (مثل مطلب قبلی). حالا Cloudflare به عنوان پرمخاطبترین CDN دنیا که به گزارش سال ۲۰۲۲ W3Techs حدود ۸۰٪ همه وبسایتها ازش استفاده میکنن (سال ۱۴۰۰ هم آروان سهم کلودفلر رو بین سایتهای ایرانی حدود ۷۰٪ ذکر کرد)، آمار API Clientها رو برای سال ۲۰۲۴ ارائه کرده.
اینا رو عرض کردم که بدونیم آمار و ارقامش قابل اتکا است. ولی:
✏️ در نظر بگیریم که کلودفلر CDN محبوب وبسایتها است و خیلی از اپلیکیشنهای سازمانی پشت کلودفلر نیستن، بلکه پشت CDNهایی مثل Azure CDN یا آمازون CloudFront هستند یا اصلا از CDN استفاده نمیکنن.
با این توضیحات:
بر اساس گزارش جدید کلودفلر، زبان برنامهنویسی Go به محبوبترین زبان برای توسعه کلاینتهای API تبدیل شده و از Node.js پیشی گرفته. همچنین، AWS بهعنوان انتخاب اصلی برای میزبانی وبسایتهای عمومی در بین ۵۰۰۰ دامنه برتر شناخته شده.
جزئیات گزارش:
محبوبیت Go برای کلاینتهای API: بیش از نیمی از ترافیک اینترنتی که کلودفلر مشاهده کرده، مربوط به APIهاست.
تحلیلهاشون نشان داده که Go با ۱۱.۸٪ استفاده، در صدر زبانهای مورد استفاده برای توسعه کلاینتهای API قرار داشته، از طرفی Node.js با ۱۰٪ و پایتون با ۹.۶٪ در رتبههای بعدی بودن.
این تغییر نسبت به سال گذشته قابل توجه است، چرا؟ چون سال گذشته Node.js با ۱۴.۶٪ در صدر بود و Go با ۸.۴٪ در رتبه دوم قرار داشت.
میزبانی وبسایتهای عمومی: در بین ۵۰۰۰ دامنه برتر، AWS با ۶۲.۳٪ سهم، پیشتازه: در مقابل، مایکروسافت Azure فقط ۴.۸٪ سهم داشته و بعدش هم WP Engine با ۸.۵٪ و Vercel با ۶.۱٪ قرار داشتن.
فریمورکها و کتابخونههای وب: توی این دامنهها، PHP با ۴۸.۱٪ بهعنوان محبوبترین زبان برنامهنویسی بوده (یحتمل به خاطر وردپرس و...)، بعدش هم Node.js با ۲۷.۹٪ و جاوا با ۱۶.۸٪ قرار داشتن. در بین فریمورکهای جاوااسکریپت، React با ۳۶.۶٪ در صدر بوده و بعدش Vue.js با ۱۹.۷٪ و Next.js با ۱۲.۶٪ قرار داشتن.
🔗 لینک گزارش
👀 این اعداد به هیچ وجه به معنی برتری یا ترجیح یا حتی محبوبیت مطلق این ابزارها و تکنولوژیها نیست! 😊
پیشنهاد میکنم گزارش رو نگاهی بندازین. یا به صورت کلی پیگیر گزارشهای آخر سال شرکتهای بزرگ و منابع معتبر باشین (خصوصا رادارها شون)
روزهای آخر ساله و شرکتهای مختلف، آمار و ارقامشون رو میگذارن روی میز (مثل مطلب قبلی). حالا Cloudflare به عنوان پرمخاطبترین CDN دنیا که به گزارش سال ۲۰۲۲ W3Techs حدود ۸۰٪ همه وبسایتها ازش استفاده میکنن (سال ۱۴۰۰ هم آروان سهم کلودفلر رو بین سایتهای ایرانی حدود ۷۰٪ ذکر کرد)، آمار API Clientها رو برای سال ۲۰۲۴ ارائه کرده.
اینا رو عرض کردم که بدونیم آمار و ارقامش قابل اتکا است. ولی:
✏️ در نظر بگیریم که کلودفلر CDN محبوب وبسایتها است و خیلی از اپلیکیشنهای سازمانی پشت کلودفلر نیستن، بلکه پشت CDNهایی مثل Azure CDN یا آمازون CloudFront هستند یا اصلا از CDN استفاده نمیکنن.
با این توضیحات:
بر اساس گزارش جدید کلودفلر، زبان برنامهنویسی Go به محبوبترین زبان برای توسعه کلاینتهای API تبدیل شده و از Node.js پیشی گرفته. همچنین، AWS بهعنوان انتخاب اصلی برای میزبانی وبسایتهای عمومی در بین ۵۰۰۰ دامنه برتر شناخته شده.
جزئیات گزارش:
محبوبیت Go برای کلاینتهای API: بیش از نیمی از ترافیک اینترنتی که کلودفلر مشاهده کرده، مربوط به APIهاست.
تحلیلهاشون نشان داده که Go با ۱۱.۸٪ استفاده، در صدر زبانهای مورد استفاده برای توسعه کلاینتهای API قرار داشته، از طرفی Node.js با ۱۰٪ و پایتون با ۹.۶٪ در رتبههای بعدی بودن.
این تغییر نسبت به سال گذشته قابل توجه است، چرا؟ چون سال گذشته Node.js با ۱۴.۶٪ در صدر بود و Go با ۸.۴٪ در رتبه دوم قرار داشت.
میزبانی وبسایتهای عمومی: در بین ۵۰۰۰ دامنه برتر، AWS با ۶۲.۳٪ سهم، پیشتازه: در مقابل، مایکروسافت Azure فقط ۴.۸٪ سهم داشته و بعدش هم WP Engine با ۸.۵٪ و Vercel با ۶.۱٪ قرار داشتن.
فریمورکها و کتابخونههای وب: توی این دامنهها، PHP با ۴۸.۱٪ بهعنوان محبوبترین زبان برنامهنویسی بوده (یحتمل به خاطر وردپرس و...)، بعدش هم Node.js با ۲۷.۹٪ و جاوا با ۱۶.۸٪ قرار داشتن. در بین فریمورکهای جاوااسکریپت، React با ۳۶.۶٪ در صدر بوده و بعدش Vue.js با ۱۹.۷٪ و Next.js با ۱۲.۶٪ قرار داشتن.
🔗 لینک گزارش
👀 این اعداد به هیچ وجه به معنی برتری یا ترجیح یا حتی محبوبیت مطلق این ابزارها و تکنولوژیها نیست! 😊
پیشنهاد میکنم گزارش رو نگاهی بندازین. یا به صورت کلی پیگیر گزارشهای آخر سال شرکتهای بزرگ و منابع معتبر باشین (خصوصا رادارها شون)
Cloudflare
Cloudflare Radar 2024 Year in Review
The Cloudflare Radar 2024 Year In Review features interactive charts, graphs, and maps you can use to explore what changed on the Internet Worldwide throughout 2024.
👍2❤1
🚀 تبدیل فایلهای پیدیاف و آفیس و... به Markdown!
یک کتابخونه خوب پایتونی از مایکروسافت! (+ یک اپلیکیشن که با استفاده ازش ساخته شده) برای تبدیل فایلهای
- PDF (.pdf)
- PowerPoint (.pptx)
- Word (.docx)
- Excel (.xlsx)
- Images (EXIF metadata, and OCR)
- Audio (EXIF metadata, and speech transcription)
- HTML (special handling of Wikipedia, etc.)
- Various other text-based formats (csv, json, xml, etc.)
به Markdown!
توضیح اضافه ندم که چقدر میتونه برای تبدیل ساده مستندات سنتی و... به ابزارهای مدرن ویکی یا نگهدارای مستندات مفید باشه!
https://github.com/microsoft/markitdown
یک کتابخونه خوب پایتونی از مایکروسافت! (+ یک اپلیکیشن که با استفاده ازش ساخته شده) برای تبدیل فایلهای
- PDF (.pdf)
- PowerPoint (.pptx)
- Word (.docx)
- Excel (.xlsx)
- Images (EXIF metadata, and OCR)
- Audio (EXIF metadata, and speech transcription)
- HTML (special handling of Wikipedia, etc.)
- Various other text-based formats (csv, json, xml, etc.)
به Markdown!
توضیح اضافه ندم که چقدر میتونه برای تبدیل ساده مستندات سنتی و... به ابزارهای مدرن ویکی یا نگهدارای مستندات مفید باشه!
from markitdown import MarkItDown
markitdown = MarkItDown()
result = markitdown.convert("test.xlsx")
print(result.text_content)
https://github.com/microsoft/markitdown
GitHub
GitHub - microsoft/markitdown: Python tool for converting files and office documents to Markdown.
Python tool for converting files and office documents to Markdown. - microsoft/markitdown
❤2👍2🔥1
♻️💡 نظرسنجی در مورد محتوای کانال
سلام به همگی 😊
امروز، ۳ ماه از شروع این کانال میگذره، هدف اولیه (و فعلی) من اشتراک آموختهها و تجربهها بوده. ولی باور دارم زمانی این هدف محقق میشه که محتوا و مخاطب «همسو» با هم باشن.
لینک زیر یک نظرسنجی کوتاه و فقط ۵ سوال انتخابیه (و البته به صورت ناشناس) که با شرکت در اون کمک مهمی در مسیر آینده کانال و بهبود محتواش خواهید داشت...
دم شما گرم، منتظر پاسخها، نقدها، نظرها و پیشنهاداتتون هستم 😉
https://forms.gle/Qu8xC8PvxcUP8fAx5
سلام به همگی 😊
امروز، ۳ ماه از شروع این کانال میگذره، هدف اولیه (و فعلی) من اشتراک آموختهها و تجربهها بوده. ولی باور دارم زمانی این هدف محقق میشه که محتوا و مخاطب «همسو» با هم باشن.
لینک زیر یک نظرسنجی کوتاه و فقط ۵ سوال انتخابیه (و البته به صورت ناشناس) که با شرکت در اون کمک مهمی در مسیر آینده کانال و بهبود محتواش خواهید داشت...
دم شما گرم، منتظر پاسخها، نقدها، نظرها و پیشنهاداتتون هستم 😉
https://forms.gle/Qu8xC8PvxcUP8fAx5
Google Docs
نظرسنجی در مورد مطالب کانال تِکافترنون
این نظرسنجی ناشناس و بدون ثبت اطلاعات فردی شما خواهد بود
❤8
tech-afternoon pinned «♻️💡 نظرسنجی در مورد محتوای کانال سلام به همگی 😊 امروز، ۳ ماه از شروع این کانال میگذره، هدف اولیه (و فعلی) من اشتراک آموختهها و تجربهها بوده. ولی باور دارم زمانی این هدف محقق میشه که محتوا و مخاطب «همسو» با هم باشن. لینک زیر یک نظرسنجی کوتاه و فقط ۵…»
📚📚 بریم برای گپ و گفت در مورد کتابهایی که سال ۲۰۲۴ خوندیم (حالا کامل، یا فصلهایی که جالب بوده برامون)
این مطلب بسته به استقبال شما میتونه از ذکر اسم کتاب، تا خلاصه صوتی مطالب متغیر باشه!
از خودم شروع میکنم (بخش اول، کتابهای جدید؛ بخش بعدی: کتابهایی که بیشترین تعداد رجوع مجدد بهشون داشتم):
Architecture Modernization: Socio-technical alignment of software, strategy, and structure
سال انتشار: ۲۰۲۴
نویسنده: Nick Tune, Jean-Georges Perrin
——————
Patterns of Distributed Systems
سال انتشار: ۲۰۲۳
نویسنده: Unmesh Joshi
——————
ALEX KARP: From Philosophy to Palantir - A Life of Vision, Innovation, and Leadership
سال انتشار: ۲۰۲۴
نویسنده: Herbert K. Howard
——————
Clean Architecture with .NET
سال انتشار: ۲۰۲۴
نویسنده: Dino Esposito
——————
Programming Large Language Models with Azure Open AI: Conversational programming and prompt engineering with LLMs
سال انتشار: ۲۰۲۴
نویسنده: Francesco Esposito
——————
💸💸 انتشارات Packt مثل سالهای پیش، از امروز به مدت چند روز تمام کتابهاش رو فقط با ۹ یورو میفروشه!
این مطلب بسته به استقبال شما میتونه از ذکر اسم کتاب، تا خلاصه صوتی مطالب متغیر باشه!
از خودم شروع میکنم (بخش اول، کتابهای جدید؛ بخش بعدی: کتابهایی که بیشترین تعداد رجوع مجدد بهشون داشتم):
Architecture Modernization: Socio-technical alignment of software, strategy, and structure
سال انتشار: ۲۰۲۴
نویسنده: Nick Tune, Jean-Georges Perrin
——————
Patterns of Distributed Systems
سال انتشار: ۲۰۲۳
نویسنده: Unmesh Joshi
——————
ALEX KARP: From Philosophy to Palantir - A Life of Vision, Innovation, and Leadership
سال انتشار: ۲۰۲۴
نویسنده: Herbert K. Howard
——————
Clean Architecture with .NET
سال انتشار: ۲۰۲۴
نویسنده: Dino Esposito
——————
Programming Large Language Models with Azure Open AI: Conversational programming and prompt engineering with LLMs
سال انتشار: ۲۰۲۴
نویسنده: Francesco Esposito
——————
💸💸 انتشارات Packt مثل سالهای پیش، از امروز به مدت چند روز تمام کتابهاش رو فقط با ۹ یورو میفروشه!
❤12🔥2 2
🌟 ساده نگه داشتن سیستمها، ۶ درس از Werner Vogels
حرفهای زیادی میشه درباره AWS زد، اما واقعیت اینه که این غول کلود، سیستمها و سرویسهاش رو طی دو دهه با موفقیت scale کرده و همچنان کاربری راحتش رو حفظ کرده.
ورنر فوگلس، CTO آمازون، تو کنفرانس AWS re:Invent درسهای جذابی از تجربهاش تو نگهداری سیستمهای پیچیده مطرح کرد.
💫 نکته کلیدی؟ پیچیدگی همیشه توی طراحی سیستمها کمین میکنه، پس مهندس باید هوشیار باشه.
💫 هدف این نیست که پیچیدگی رو کلا حذف کنیم، بلکه باید اون رو مدیریت کنیم. لری تسلر میگه: "پیچیدگی رو نمیشه حذف کرد، فقط میشه جابجاش کرد".
یه مثال جالب: طراحی دوچرخه!
یک چرخه: خیلی انعطافپذیره، اما سوار شدنش سخته
سه چرخه: راحته، ولی جابجا کردنش سخته
دوچرخه: تعادل ایدهآل بین راحتی و انعطافپذیری
۶ توصیه Vogels برای مدیریت پیچیدگی:
۱. سیستمهای قابل تکامل بسازید
نرمافزارهایی که پیش نمیرن، میمیرن
هر بار که مقیاس سیستم عوض میشه، باید معماری رو بازنگری کنید
۲. پیچیدگی رو خرد کنید
تغییرات کوچک رو نادیده نگیرید
هر سرویس باید اونقدر کوچک باشه که تو ذهن یه مهندس جا بشه
۳. معماری رو با نیازهای کسبوکار هماهنگ کنید
اجزای هوشمند با رابطهای ریزدانه بسازید
با واحدهای کسبوکار همکاری کنید
۴. کار رو به سلولها تقسیم کنید
معماری سلولی پیچیدگی رو مدیریت میکنه
مشکلات رو محدود میکنه بدون تاثیر روی کل سیستم
۵. سیستمهای پیشبینیپذیر طراحی کنید
عدم قطعیت رو کاهش بدید
از معماریهای با پالس ثابت استفاده کنید
۶. همه چی رو اتوماتیک کنید
اتوماسیون استاندارد باشه
فقط جاهایی که نیاز به قضاوت انسانی هست، دخالت انسان لازمه
💫 خلاصه کلام: "سادگی نیاز به انضباط داره" - Werner Vogels
در موردش صحبت کنیم؟ نظر شما چیه؟
حرفهای زیادی میشه درباره AWS زد، اما واقعیت اینه که این غول کلود، سیستمها و سرویسهاش رو طی دو دهه با موفقیت scale کرده و همچنان کاربری راحتش رو حفظ کرده.
ورنر فوگلس، CTO آمازون، تو کنفرانس AWS re:Invent درسهای جذابی از تجربهاش تو نگهداری سیستمهای پیچیده مطرح کرد.
💫 نکته کلیدی؟ پیچیدگی همیشه توی طراحی سیستمها کمین میکنه، پس مهندس باید هوشیار باشه.
💫 هدف این نیست که پیچیدگی رو کلا حذف کنیم، بلکه باید اون رو مدیریت کنیم. لری تسلر میگه: "پیچیدگی رو نمیشه حذف کرد، فقط میشه جابجاش کرد".
یه مثال جالب: طراحی دوچرخه!
یک چرخه: خیلی انعطافپذیره، اما سوار شدنش سخته
سه چرخه: راحته، ولی جابجا کردنش سخته
دوچرخه: تعادل ایدهآل بین راحتی و انعطافپذیری
۶ توصیه Vogels برای مدیریت پیچیدگی:
۱. سیستمهای قابل تکامل بسازید
نرمافزارهایی که پیش نمیرن، میمیرن
هر بار که مقیاس سیستم عوض میشه، باید معماری رو بازنگری کنید
۲. پیچیدگی رو خرد کنید
تغییرات کوچک رو نادیده نگیرید
هر سرویس باید اونقدر کوچک باشه که تو ذهن یه مهندس جا بشه
۳. معماری رو با نیازهای کسبوکار هماهنگ کنید
اجزای هوشمند با رابطهای ریزدانه بسازید
با واحدهای کسبوکار همکاری کنید
۴. کار رو به سلولها تقسیم کنید
معماری سلولی پیچیدگی رو مدیریت میکنه
مشکلات رو محدود میکنه بدون تاثیر روی کل سیستم
۵. سیستمهای پیشبینیپذیر طراحی کنید
عدم قطعیت رو کاهش بدید
از معماریهای با پالس ثابت استفاده کنید
۶. همه چی رو اتوماتیک کنید
اتوماسیون استاندارد باشه
فقط جاهایی که نیاز به قضاوت انسانی هست، دخالت انسان لازمه
💫 خلاصه کلام: "سادگی نیاز به انضباط داره" - Werner Vogels
در موردش صحبت کنیم؟ نظر شما چیه؟
👍10🔥5❤4
🤔 موضوع دورهمی بعدی چی باشه؟
Final Results
13%
monorepo یا polyrepo
2%
internal تمایزش با public API
25%
Semantic Kernel و AI در .NET
10%
SQL Server Indexes
29%
Distributed Systems
21%
آسیبشناسی تیمهای نرمافزاری
👍1😁1
tech-afternoon
🤔 موضوع دورهمی بعدی چی باشه؟
خب، ممنون از همه دوستانی که طی ۲۴ ساعت گذشته مشارکت کردن 🙏🌱
📌 نتیجه میگیرم در دورهمی بعدی، در مورد سیستمهای توزیعشده گپ خواهیم زد.
ولی چون Semantic Kernal و AI هم فقط ۲ تا رأی فاصله داشت، دورهمی بعدش به احترام رفقایی که نظرشون روی کاربرد هوشمصنوعی بود، به اون خواهیم پرداخت.
من سعی میکنم زودتر برنامهریزی کنم. ولی فعلا خوشحال میشم توی کامنت یا ایمیل، دغدغه و نکاتی که بیشتر دوست دارید در موردش بدونید در رابطه با Distributed Systems برای بنویسید 😊
📌 نتیجه میگیرم در دورهمی بعدی، در مورد سیستمهای توزیعشده گپ خواهیم زد.
ولی چون Semantic Kernal و AI هم فقط ۲ تا رأی فاصله داشت، دورهمی بعدش به احترام رفقایی که نظرشون روی کاربرد هوشمصنوعی بود، به اون خواهیم پرداخت.
من سعی میکنم زودتر برنامهریزی کنم. ولی فعلا خوشحال میشم توی کامنت یا ایمیل، دغدغه و نکاتی که بیشتر دوست دارید در موردش بدونید در رابطه با Distributed Systems برای بنویسید 😊
❤8👍2👏1
🚀 💸 یک خبر خوب! امروز گیتهاب از سرویس رایگان کوپایلوت رونمایی کرد و بلافاصله هم تیم ویژوالاستدیو نسخه رایگان رو برای ویژوالاستدیو ارائه کرد.
من دو ساله مشترک کاپایلوت هستم و حقیقتا سرویس خوبیه. حتی از IntelliCode و JetBrains AI و Tabnine و Cody و Tabby هم که من تست کردم بهتر بوده (در تستها و نیازهای شخصی من، که قطعا جهانشمول نیست)
و AI چند ساله که کمکم بخشی از هزینههای سبد خانواده شده که باید بهش جدیتر فکر کرد. از بس که متعدد شدن!
خبر گیتهاب
خبر ویژوالاستدیو
خبر VS Code
من دو ساله مشترک کاپایلوت هستم و حقیقتا سرویس خوبیه. حتی از IntelliCode و JetBrains AI و Tabnine و Cody و Tabby هم که من تست کردم بهتر بوده (در تستها و نیازهای شخصی من، که قطعا جهانشمول نیست)
و AI چند ساله که کمکم بخشی از هزینههای سبد خانواده شده که باید بهش جدیتر فکر کرد. از بس که متعدد شدن!
خبر گیتهاب
خبر ویژوالاستدیو
خبر VS Code
👍8😍2🥰1😎1 1
✨ قابلیتهای جدید افزونهی SQL Server برای VS Code!
اگر سیر تغییر رویکرد مایکروسافت رو دنبال کرده باشید، سرعت توسعه و نوآوری توی VS Code به طرز محسوسی سریع و خوشحالکننده است.
حالا اومده خیلی قابلیتهایی که قبلا فقط توی SSMS برای SQL Server بود رو توی افزونه VS Code اضافه کرده.
احتمالا تصاویر گویا است و میبینید که کوئریپلن، و تولید اسکریپت و کلا محیط بصری خیلی بهتر و کاملتری نسبت به نسخههای قبلی توی ورژن جدید داریم.
از طرفی میدونید که Azure Data Studio که بر پایه VS Code توسعه داده شده و کدباز و رایگانه، از MySQL, PostgreSQL, MongoDB, CosmosDB و SQL Server پشتیبانی میکنه (نه به کاملی DataGrip ولی در حال بهبود و تکمیله).
اینا همه در حالیه که SSMS 21 که الان نسخه پیشنمایش است هم تغییرات بزرگی داشته.
مثل اینکه مایکروسافت برای سهمگیری از بازار ابزارهای مرتبط با دیتابیس و بهبود ابزارهای قبلی خودش خیز برداشته!
💬 شما از چی استفاده میکنید؟ ابزار مورد علاقهتون چیه؟!
اگر سیر تغییر رویکرد مایکروسافت رو دنبال کرده باشید، سرعت توسعه و نوآوری توی VS Code به طرز محسوسی سریع و خوشحالکننده است.
حالا اومده خیلی قابلیتهایی که قبلا فقط توی SSMS برای SQL Server بود رو توی افزونه VS Code اضافه کرده.
احتمالا تصاویر گویا است و میبینید که کوئریپلن، و تولید اسکریپت و کلا محیط بصری خیلی بهتر و کاملتری نسبت به نسخههای قبلی توی ورژن جدید داریم.
از طرفی میدونید که Azure Data Studio که بر پایه VS Code توسعه داده شده و کدباز و رایگانه، از MySQL, PostgreSQL, MongoDB, CosmosDB و SQL Server پشتیبانی میکنه (نه به کاملی DataGrip ولی در حال بهبود و تکمیله).
اینا همه در حالیه که SSMS 21 که الان نسخه پیشنمایش است هم تغییرات بزرگی داشته.
مثل اینکه مایکروسافت برای سهمگیری از بازار ابزارهای مرتبط با دیتابیس و بهبود ابزارهای قبلی خودش خیز برداشته!
💬 شما از چی استفاده میکنید؟ ابزار مورد علاقهتون چیه؟!
👌7👍2 2❤1
مفهوم Resiliency یا تابآوری، به توانایی یک سیستم برای بازیابی شرایط پایدار در صورت بروز خطا گفته میشه. حالا این بازیابی میتونی تلاش برای بازیابی باشه، یا انتخاب راه جایگزین. مثل اینکه شما ۲ بار تلاش میکنی از API آبوهوا مقدار دمای فعلی یک منطقه رو بگیری، هر بار با فاصله زمانی ۵ ثانیه API رو صدا میزنی ولی بعد از اینکه پاسخ موفق نمیگیری (تا اینجا به این میگن استراتژی retry) بعد تصمیم میگیری از cache آخرین مقداری که کمتر از ۵ ساعت گذشته وجود داشته رو استفاده کنی که فعلا کار راه بیوفته (استراتژی fallback) یا ... به هر کدوم از این رفتارها برای تداوم کار و مقابله با موانع، میگن resiliency strategy.
کتابخونه Polly محبوبترین در بین داتنتیهاست. و تو دل Aspire هم ازش استفاده شده، برای درک بهتر ویدیوی Aspire که به زودی پابلیش میشه، خوبه یه مرور روی انواع استراتژیها کنیم...
—————————
دو گروه اصلی داریم:
وقتی به کار میرن که یک خطا یا مشکلی رخ داده و سیستم باید به شکلی واکنش نشون بده.
فرضیه: خطاها موقتی هستن و ممکنه با کمی تأخیر و تلاش مجدد برطرف بشن.
در این استراتژی، سیستم تلاش میکنه که یک عملیات ناموفق رو بعد از یک بازهی زمانی مشخص دوباره امتحان کنه. این بازه زمانی میتونه ثابت یا متغیر باشه (مثل Exponential Backoff). مثلاً اگر سرور موقتی قطع شده باشه، با چند بار Retry ممکنه مشکل حل بشه. در Polly، این با “Retry Policy” قابل پیادهسازی است. و تعداد دفعات و بازه زمانی بین هر تلاش به تصمیم ما وابسته است.
فرضیه: وقتی سیستم به شدت دچار مشکل میشه، بهتره سریعاً فرآیندها متوقف بشن به جای اینکه کاربران منتظر بمونن.
چطور کمک میکنه؟ مدار رو قطع میکنه (اجرای درخواستها رو متوقف میکنه) در زمانی که خطاها از حدی مشخص بیشتر میشن (مثل وقتی میفرسته به صف ولی هِی روی هم انباشت میشه و از اون طرف پردازش نمیشن)
شبیه به فیوز برق که اگر بیش از حد فشار وارد بشه، مدار رو قطع میکنه. این استراتژی به سیستم اجازه میده برای مدتی مشخص درخواستها رو به مقصد ارسال نکنه تا از خرابیهای بیشتر جلوگیری بشه. مثلاً در Polly میتونید مدتزمانی که Circuit باز میمونه و شرایط بازگشت به حالت نرمال رو تنظیم کنیم.
فرضیه: خطا تداوم خواهد داشت؛ پس برای پلن B برنامهریزی میکنیم.
چطوری کمک میکنه؟ یک مقدار یا راه حل جایگزین در صورت بروز یا تداوم خطا ارائه میده.
وقتی یک عملیات شکست میخوره، به جای نمایش خطا به کاربر، یک نتیجه جایگزین برمیگرده. مثلاً به جای اینکه پیام “سرور API در دسترس نیست” نمایش داده بشه، میتونید یک مقدار ذخیره شده از کش رو ارائه بدید.
فرضیه: گاهی اوقات برخی مسیرها شاید کند یا حتی ناموفق باشن؛ پس بهتره چندین راه برای رسیدن به هدف در نظر بگیریم، هر کدوم زودتر جواب داد، همون.
چطوری کمک میکنه؟ برای یک کار، چند راه رو تلاش میکنه به طور موازی پی بگیره و منتظر اولین پاسخ موفق میمونه.
در این استراتژی، همزمان چند درخواست به چند مقصد مختلف ارسال میشه و اولین پاسخ موفق به عنوان نتیجه پذیرفته میشه. این کار برای کاهش زمان انتظار و بهبود اطمینانپذیری استفاده میشه.
این استراتژیها برای پیشگیری از بروز مشکلات در سیستم طراحی شدهاند.
فرضیه: بعد از مدت زمانی مشخص، موفقیت بعیده.
چطوری کمک میکنه؟ تضمین میکنه که درخواستها بیشتر از زمان مشخص منتظر نمیمونن.
در این استراتژی، زمان محدودی برای انجام یک عملیات در نظر گرفته میشه. اگر عملیات در این زمان به نتیجه نرسید، سیستم اون رو قطع میکنه. این کار مانع از این میشه که یک درخواست معلق منابع سیستم رو اشغال کنه.
فرضیه: محدود کردن تعداد درخواستهایی که سیستم در یک بازه زمانی مشخص میپذیره (راهی برای کنترل بار ورودی).
چطوری کمک میکنه؟ اجرای درخواستها رو محدود میکنه تا از حد مشخصی فراتر نره.
برای جلوگیری از بار زیاد روی سیستم، این استراتژی تعداد درخواستها در یک بازه زمانی مشخص رو محدود میکنه. مثلاً اگر کاربران زیادی همزمان به سیستم درخواست بفرستن، Rate Limiter میتونه از خرابی جلوگیری کنه.
—————————
ما میتونیم از یک یا ترکیبی از چند استراتژی برای افزایش تابآوری سیستمهامون استفاده کنیم.
🔗 رفرنس جهت مطالعه عمیقتر
Please open Telegram to view this post
VIEW IN TELEGRAM
👏8 3🔥2🙏2🤔1
مفهومی داریم به نام Cargo Cult Practices که به رفتارها یا فرآیندهایی اشاره داره که بهطور «سطحی» شبیه به رفتارهای موفق و موثر هستن، اما «بدون درک عمیقی» از دلیل یا اصول اساسیای که پشت اون رفتارها و انتخابها وجود داره...
ریشه تاریخی: کارگو کالت به رفتارها و آیینهایی گفته میشه که در برخی جوامع، بهویژه در جزایر اقیانوس آرام، بعد از جنگ جهانی دوم شکل گرفته. در طول جنگ، نیروهای نظامی آمریکایی در این جزایر پایگاههایی ساختند و کالاهای مدرن (کارگو) رو با هواپیما به اونجا میبردند. بومیان این جزایر که هرگز چنین فناوریهایی را ندیده بودن، شروع به تقلید از رفتارهای سربازها کردن!! با این باور که این کارها (اداها) باعث جلب کالاهایی شبیه اونایی که نظامیها میآوردن میشه!!
بعد از پایان جنگ و ترک نیروهای نظامی، بومیها به ساخت تجهیزات نمادین مثل باند فرودگاه، برج مراقبت و هواپیماهای چوبی ادامه دادن. حتی لباسهای شبیه به یونیفرم نظامی میپوشیدن و با چوبهای شبیه به رادیو ارتباط برقرار میکردن!
اصطلاح "کارگو کالت" در زمینههای مختلف برای توصیف تقلید ظاهری از یک عمل، بدون درک عمیق از مکانیزمهای واقعی اوها به کار میره، بهویژه در حوزههایی مثل مدیریت و توسعه نرمافزار.
استفاده از فلان معماری یا فلان زبون یا فلان ساختار تیمی چون فلان شرکت استفاده کرده، از همین مصادیقه... توی فرهنگ ما ضربالمثل «مرغی که انجیر میخوره نوکش کجه» مترادف با همینه...
و بعدش:
یلدای همگی مبارک و امیدوارم در کنار خانواده و عزیزانتون سلامت و شاد و موفق باشین 😉
Please open Telegram to view this post
VIEW IN TELEGRAM
❤12👏2 2👍1
ورکلودهای داتنت مجموعهای از اجزای اختیاری SDK هستن که برای توسعه انواع خاصی از برنامهها مورد استفاده قرار میگیرن. به زبون سادهتر، به جای نصب یک SDK بزرگ که همه چیز رو شامل بشه، میتونیم فقط اجزای مورد نیاز برای پروژه خودمون را نصب کنیم.
مثال:
توی نسخههای قبل از داتنت ۵، تمام قابلیتها در قالب یک SDK یکپارچه (مونولیتیک) ارائه میشد. این رویکرد مشکلات متعددی داشت:
- حجم زیاد SDK و مشکلات توزیع
- زمان طولانی ساخت محصول
- پیچیدگی توی مدیریت و بهروزرسانی
- مصرف منابع غیرضروری توی محیط CI/CD
مایکروسافت با معرفی ورکلودها، چند هدف کلیدی رو دنبال کرد:
- امکان دانلود انتخابی قابلیتهای مورد نیاز (مثلاً فقط ASP.NET Core یا فقط Xamarin)
- سادهسازی پیکربندی برای محیطهای CI/CD
- ارائه پیامهای خطای مفید هنگام نبود ورکلود مورد نیاز
- قابلیت نصب خودکار ورکلودها بر اساس فایل پروژه
- امکان بهروزرسانی ورکلودها بدون نیاز به نصب نسخه جدید SDK (مثلا aspire رو بهروز کنیم مستقل از سایر SDKها)
ساختار و ترکیببندی
ورکلودها از دو بخش اصلی تشکیل شدهاند:
برای دیدن لیست ورکلودها و انتخاب از بینشون:
dotnet workload search
یا برای آپدیت کردن ورکلودها:
dotnet workload update
یا مثلا وقتی میخواین ورکلود لازم برای ساختن نرمافزار روی تلویزیون سامسونگ مجهز به تایزن رو نصب کنین:
dotnet workload install maui-tizen
طبق برنامه مایکروسافت، در آینده:
یکی از ویژگیهای مهم که از داتنت ۸.۰.۴۰۰ معرفی شد، قابلیت Workload Sets بود. این قابلیت به ما امکان میده مجموعهای از ورکلودها رو با یک شماره نسخه مشخص مدیریت کنیم.
مزایای استفاده از Workload Sets
- کنترل بهتر روی نسخههای نصب شده
- اطمینان از سازگاری ورکلودها با همدیگه
- همگامسازی آسونتر نسخهها توی تیم توسعه
- مدیریت سادهتر بهروزرسانیها
مثال کاربردی:
dotnet workload install aspire --version 9.0.100-preview.7.24414.1
dotnet workload config --update-mode workload-set
حتی میتونیم توی
global.json هم درجشون کنیم:{
"sdk": {
"workloadVersion": "9.0.200-preview.0"
}
}ورکلودهای داتنت نشونهی تکامل طبیعی پلتفرم و حرکت به سمت ماژولار شدن هرچه بیشترش هستن. و این رویکرد به ما این امکان رو میده تا محیط توسعهمون رو بهینهتر و سبکتر نگه داریم و فقط ابزارهای مورد نیازمون رو نصب کنیم.
و NET Aspire. اساسا بر پایهی workloadها بنا شد و چابکی خودش رو وامدار workloadها است، و با رهانش (release)های مستقل از داتنت خودش رو مرتب بهبود داده تا امروز...
امیدوارم این مطلب به درک بهتر ورکلود کمک کرده باشه و بتونه به عنوان خونههای پازل کمک کنه تا Aspire رو بهتر درک کنید.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥11❤3👍1
از اونجایی که دورهمی بعدیمون در مورد سیستمهای توزیعشده است، مطالب دیروز (workload) و این مطلب (OpenTelemetry) پیشدرآمدی است برای دوستانی که آشنایی کمتری دارن ولی دوست دارن از دورهمی استفاده بیشتری ببرن.
به زبون ساده و تا حد امکان کوتاه، OpenTelemetry رو توضیح دادم و Log, Metric و Trace مرور کردم. اگر دوست داشتید مطالعه کنید (instant view تلگرام دسکتاپ مشکلاتی با فارسی داره که اگر روی دسکتاپ مطالعه میکنید بهتره تا لینک رو باز کنید)
📎 لینک مطلب
Please open Telegram to view this post
VIEW IN TELEGRAM
امین مصباحی
در باب OpenTelemetry
مقدمهحتماً اسم OpenTelemetry (یا همون OTel) رو حول و حوش موضوعات مانیتورینگ و لاگینگ، شنیدین. هرچقدر تنوع کامپوننتها، سرویسها، اپلیکیشنها بیشتر بیشتر بشه؛ یا به زبون ساده سیستم توزیع بشه، لزوم استفاده از یک استاندارد یا مکانیزم فراگیر، اهمیتش بیشتر میشه.…
❤10 3👍2🔥1
خودکار کردن کارها یه رکن اساسی مهندسی نرمافزاره. و عملا بخش مهمی از کار هر توسعهدهنده، DevOpsکار و Platform Engineer و... همین خودکار کردن فرایندهاست.
لذا طیف وسیعی از ابزارهای اتوماسیون برای کارهای مختلف وجود داره، یکی از مهمترینهاش هم ابزارهای خودکارسازی بیلد و دپلوی است. ابزارهای Build Automation از فایلهای XML که برای استفاده از MS Build سالها پیش میساختیم تا فایلهای Yaml که برای GitHub یا GitLab میسازیم؛ وقتی مراحل بیلد، پیچیده و متعدد میشدن؛ نوشتن، ایرادیابی و مدیریت فایل Yaml سختتر میشه.
حتی توی پروژهها و تیمهای کوچیک هم شاید یادگیریش برای دولوپر تازهکار دشوار باشه.
درسته که افزونههایی بروی سهولت نوشتنشون در دسترس هست؛ ولی بیاین فکر کنیم اگر توی فایل #C با متدها و کلاسهایی که AutoComplete و... خیلی خوبی هم دارن، بهتر نیست؟ خوندن داینامیک مقادیر و تصمیمگیری راحتتر نیست؟ دیباگ کردن راحتتر نیست؟
پروژه Nuke.Build و Cake همینه! یه پروژه رایگان کدباز با لایسنس MIT که با همه CI/CDهای رایج GitHub GitLab CI, Azure Pipelines, Actions و... هم سازگاره.
🧐 حالا یه سوال جدی؟ آیا «امروزه، عصر، عصر مهاجرت به Nuke است و با مهاجرت به آن موفقیت را در دستان خود بگیریم و به پوست شفافتر، زندگی شادابتر و گوارش بهتر دست یابیم!» است؟
خیر! nuke با ۳۱۰۰ ستاره در گیتهاب و cake با ۳۹۰۰ ستاره، پروژههای بدی نیستن، برای پروژههای کوچک، و یا جایی که دانش یا نیروی کافی برای DevOps نداریم، و یا نیازهای خاصی داریم که با Yamlنویسی نگهداری و توسعهاش سخت میشه (پایپلاینهای خیلی پویا)، باز هم خوبن. ولی اینکه از فردا روشهای native رو بگذاریم کنار و بدون دلیل منطقی و حسابشده بیوفتیم دنبال اینا هم کار ابلهانهای است😁 خودکارسازی خوبه، آشنایی با ابزارها خوبه، انتخاب با آگاهی و بجا از جفتش بهتره 😉
💬 تجربه شما چیه؟ با چه روش یا ابزاری build automation میکنین؟
لذا طیف وسیعی از ابزارهای اتوماسیون برای کارهای مختلف وجود داره، یکی از مهمترینهاش هم ابزارهای خودکارسازی بیلد و دپلوی است. ابزارهای Build Automation از فایلهای XML که برای استفاده از MS Build سالها پیش میساختیم تا فایلهای Yaml که برای GitHub یا GitLab میسازیم؛ وقتی مراحل بیلد، پیچیده و متعدد میشدن؛ نوشتن، ایرادیابی و مدیریت فایل Yaml سختتر میشه.
حتی توی پروژهها و تیمهای کوچیک هم شاید یادگیریش برای دولوپر تازهکار دشوار باشه.
درسته که افزونههایی بروی سهولت نوشتنشون در دسترس هست؛ ولی بیاین فکر کنیم اگر توی فایل #C با متدها و کلاسهایی که AutoComplete و... خیلی خوبی هم دارن، بهتر نیست؟ خوندن داینامیک مقادیر و تصمیمگیری راحتتر نیست؟ دیباگ کردن راحتتر نیست؟
پروژه Nuke.Build و Cake همینه! یه پروژه رایگان کدباز با لایسنس MIT که با همه CI/CDهای رایج GitHub GitLab CI, Azure Pipelines, Actions و... هم سازگاره.
خیر! nuke با ۳۱۰۰ ستاره در گیتهاب و cake با ۳۹۰۰ ستاره، پروژههای بدی نیستن، برای پروژههای کوچک، و یا جایی که دانش یا نیروی کافی برای DevOps نداریم، و یا نیازهای خاصی داریم که با Yamlنویسی نگهداری و توسعهاش سخت میشه (پایپلاینهای خیلی پویا)، باز هم خوبن. ولی اینکه از فردا روشهای native رو بگذاریم کنار و بدون دلیل منطقی و حسابشده بیوفتیم دنبال اینا هم کار ابلهانهای است
Please open Telegram to view this post
VIEW IN TELEGRAM
👍10❤3 3
🧠 مروری بر Semantic Kernel، نرمافزار، ولی باهوش!
شاید شوخی دور از واقعیتی نباشه که طی این چند سال، اینقدر که همه روی AI تمرکز کردن یا باهاش شوآف کردن، اگر روی پیدا کردن قاتل بروسلی وقت گذاشته بودن حتمن اون نامرد رو دستگیر کرده بودن!
مایکروسافت هم که به لطف سرمایهگذاریهای هوشمندانهای که روی استارتاپها و شرکتهای مستعد داشته، اوضاع خیلی خوبی داره. یادمون نره همونطور که برنامهنویسی وب یا معماری سرویسگرا، ۲۵ سال پیش چیزهای مدرنی بودن ولی الان بدیهی و پیشپا افتاده به شمار میان؛ استفاده از AI توی نرمافزارها هم تا چند وقت دیگه (خیلی خیلی کمتر از ۲۵ سال، حتی کمتر از ۵ سال دیگه) یه موضوع بدیهی خواهد بود.
🎅 دو تا خاطره توی کامنت این مطلب میگذارم (خاطره است و اگر نخونید چیزی از مطلب رو از دست ندادید)
البته منظورم چپوندن زورکی و شوآف نیست، بلکه چیزی برای تسهیل نیازهای کاربر نهایی و ارتقاء عملکرد خود سیستمه.
کتابخونه Semantic Kernel که فقط هم برای داتنتیها نیست و پایتون و جاوا رو هم پشتیبانی میکنه؛ یک کتابخونهی متنبازه که به عنوان میانافزار (middleware) عمل میکند.
❓ یعنی چی؟ یعنی این کتابخونه به توسعهدهنده کمک میکنه تا به سادگی مدلهای هوش مصنوعی مختلف رو با کدهای موجودش ترکیب کنه و عاملهای هوشمند (AI agents) بسازه، (بدون داشتن درک عمیق از دل و رودهی AI یا LLM)
❓ یکم بیشتر؟ چشم. مثلا شما میخواهید از مدلی که یه بابایی یا یه شرکتی، رایگان یا پولی، روی کامپیوتر خودتون یا روی کلاد، وجود داره و مثلا بهش یه متن میدید و میگید با صدای فلان خواننده بخونه؛ یا یه متن میدید میگید یه عکس بر اساسش بسازه؛ یا سوال و جواب عادی؛ یا سوال و جوابی که مبنای پاسخش دیتای توی دیتابیس شماست؛
مثلا شما یه نرمافزار سنتی فروشگاه آنلاین لباس داری؛ کاربر میگه برام یه ست لباس مهمونی برای فصل پاییز و سقف قیمت فلان، برای یک خانم ۳۰ ساله با سایز M پیشنهاد کن، این یه متنه، ولی Semantic Kernel این امکان رو میده به راحتی از دل دیتای ساختار یافته دیتابیس، فرض کنید جدولی که نام کالا، قیمت، رنگ و سایز رو داره، کوئری مورد نیاز رو بسازه. چجوری؟ با دیتایی که توی مدل زبانی داره میفهمه رنگهای مناسب با پاییز، یا نوع لباسهای مورد نیاز برای یک مهمانی (شلوار، پیراهن، پالتو، کفش، شالگردن برای پاییز و یک خانم نیازه) اینا رو از دل دیتابیس میکشه بیرون و متن هم از نتیج خروجی که احتمالا یه لیست از آبجکت کالا است بسازه که: فلانیجون اگر اینو اونو اونیکی رو ست کنی برای پاییز خوبه و به بودجهات هم میخوره!
🧞♂️ این یه روزی جادو بود، یه روز رویا بود، یه روز محال بود؛ الان با وجود امکانات ساختاری وکتورها و کتابخونهها به راحتی شدنیه، حتی با تغییرات کم در کدهای فعلی!
این Semantic Kernel در حقیقت یه پُله بین دنیای برنامهنویسی سنتی و مدلهای زبانی بزرگ (LLM).
فعلا هم با زبونهای C#، Python و Java قابل استفاده است. یه لایهی میانی که درخواستهای مدلهای AI رو به توابع تعریفشده توی کد ترجمه میکنه و پاسخها را مدیریت میکنه (تبدیل متن به یه کلاس، و ساخت متن با استفاده از دیتای ساختاریافته).
مدلهای هوش مصنوعی مثل GPT و DALL-E و… تحول بزرگی توی نحوه تعامل ما با نرمافزار ایجاد کردن. اما استفاده از این مدلها توی محیطهای واقعی چالشهایی هم داره:
🔤 مدیریت درخواستها: چجوری درخواستهای پیچیده کاربر رو به توابع کدنویسی ترجمه کنیم؟ (مثلا ورودیهای متد GetProductsByDescription)
🔤 اتصال به سیستمهای موجود: چجوری هوش مصنوعی با APIها، دیتابیسها، یا فرآیندهای کسبوکاری تعامل داشته باشه؟
🔤 امنیت و مقیاسپذیری: چجوری میشه این قابلیتها رو بهصورت ایمن (جلوگیری از نشت اطلاعات یا دسترسی به دادههایی که نباید بهش دسترسی داشته باشع) و توی مقیاس بزرگ ارائه کرد؟
و Semantic Kernel برای پاسخ به این چالشها طراحی شد؛ و هدفش سادهسازی یکپارچهسازی هوش مصنوعی در پروژههای واقعیه.
👀 چی کار میشه باهاش کرد حالا؟
- ایجاد رباتها و عاملهای هوشمند: مثل چتباتهایی که بهصورت پویا تصمیم میگیرن یا فرآیندها رو خودکار میکنن.
- یکپارچهسازی آسون با کد موجود: با استفاده از قابلیت Function Calling، میشه مدلهای AI رو به کدهای موجود متصل کرد.
- اتوماسیون فرآیندهای کسبوکار: مثل پردازش خودکار درخواستهای مشتریها یا مدیریت منابع سازمانی.
- مدیریت آسون هوش مصنوعی: فراهم کردن قابلیت مشاهده و نظارت بر عملکرد مدلهای مختلف.
- اتصال به مدلهای مختلف AI (مثل OpenAI، یا مدلهایی که روی ماشین خودتون دارید)
- پشتیبانی از Vector Storeها
✨ اگر دوست دارید این موضوع ادامه بدم:
ریاکشن 🤓
شاید شوخی دور از واقعیتی نباشه که طی این چند سال، اینقدر که همه روی AI تمرکز کردن یا باهاش شوآف کردن، اگر روی پیدا کردن قاتل بروسلی وقت گذاشته بودن حتمن اون نامرد رو دستگیر کرده بودن!
مایکروسافت هم که به لطف سرمایهگذاریهای هوشمندانهای که روی استارتاپها و شرکتهای مستعد داشته، اوضاع خیلی خوبی داره. یادمون نره همونطور که برنامهنویسی وب یا معماری سرویسگرا، ۲۵ سال پیش چیزهای مدرنی بودن ولی الان بدیهی و پیشپا افتاده به شمار میان؛ استفاده از AI توی نرمافزارها هم تا چند وقت دیگه (خیلی خیلی کمتر از ۲۵ سال، حتی کمتر از ۵ سال دیگه) یه موضوع بدیهی خواهد بود.
البته منظورم چپوندن زورکی و شوآف نیست، بلکه چیزی برای تسهیل نیازهای کاربر نهایی و ارتقاء عملکرد خود سیستمه.
کتابخونه Semantic Kernel که فقط هم برای داتنتیها نیست و پایتون و جاوا رو هم پشتیبانی میکنه؛ یک کتابخونهی متنبازه که به عنوان میانافزار (middleware) عمل میکند.
مثلا شما یه نرمافزار سنتی فروشگاه آنلاین لباس داری؛ کاربر میگه برام یه ست لباس مهمونی برای فصل پاییز و سقف قیمت فلان، برای یک خانم ۳۰ ساله با سایز M پیشنهاد کن، این یه متنه، ولی Semantic Kernel این امکان رو میده به راحتی از دل دیتای ساختار یافته دیتابیس، فرض کنید جدولی که نام کالا، قیمت، رنگ و سایز رو داره، کوئری مورد نیاز رو بسازه. چجوری؟ با دیتایی که توی مدل زبانی داره میفهمه رنگهای مناسب با پاییز، یا نوع لباسهای مورد نیاز برای یک مهمانی (شلوار، پیراهن، پالتو، کفش، شالگردن برای پاییز و یک خانم نیازه) اینا رو از دل دیتابیس میکشه بیرون و متن هم از نتیج خروجی که احتمالا یه لیست از آبجکت کالا است بسازه که: فلانیجون اگر اینو اونو اونیکی رو ست کنی برای پاییز خوبه و به بودجهات هم میخوره!
🧞♂️ این یه روزی جادو بود، یه روز رویا بود، یه روز محال بود؛ الان با وجود امکانات ساختاری وکتورها و کتابخونهها به راحتی شدنیه، حتی با تغییرات کم در کدهای فعلی!
این Semantic Kernel در حقیقت یه پُله بین دنیای برنامهنویسی سنتی و مدلهای زبانی بزرگ (LLM).
فعلا هم با زبونهای C#، Python و Java قابل استفاده است. یه لایهی میانی که درخواستهای مدلهای AI رو به توابع تعریفشده توی کد ترجمه میکنه و پاسخها را مدیریت میکنه (تبدیل متن به یه کلاس، و ساخت متن با استفاده از دیتای ساختاریافته).
مدلهای هوش مصنوعی مثل GPT و DALL-E و… تحول بزرگی توی نحوه تعامل ما با نرمافزار ایجاد کردن. اما استفاده از این مدلها توی محیطهای واقعی چالشهایی هم داره:
و Semantic Kernel برای پاسخ به این چالشها طراحی شد؛ و هدفش سادهسازی یکپارچهسازی هوش مصنوعی در پروژههای واقعیه.
- ایجاد رباتها و عاملهای هوشمند: مثل چتباتهایی که بهصورت پویا تصمیم میگیرن یا فرآیندها رو خودکار میکنن.
- یکپارچهسازی آسون با کد موجود: با استفاده از قابلیت Function Calling، میشه مدلهای AI رو به کدهای موجود متصل کرد.
- اتوماسیون فرآیندهای کسبوکار: مثل پردازش خودکار درخواستهای مشتریها یا مدیریت منابع سازمانی.
- مدیریت آسون هوش مصنوعی: فراهم کردن قابلیت مشاهده و نظارت بر عملکرد مدلهای مختلف.
- اتصال به مدلهای مختلف AI (مثل OpenAI، یا مدلهایی که روی ماشین خودتون دارید)
- پشتیبانی از Vector Storeها
ریاکشن 🤓
Please open Telegram to view this post
VIEW IN TELEGRAM
🤓17❤4👍1🤔1 1