پروژه بنیاد محاسبات بومی ابری (CNCF).

این صفحه حاوی جزئیات یک پروژه نگارش فنی است که برای فصل اسناد Google پذیرفته شده است.

خلاصه پروژه

سازمان منبع باز:
بنیاد محاسبات بومی ابری (CNCF)
نویسنده فنی:
شریتی
نام پروژه:
بهبود اسناد SMI و مش های خدمات مرتبط
طول پروژه:
طول استاندارد (3 ماه)

شرح پروژه

فناوری Service Mesh اساساً با هدف ارائه ارزش به تعداد فزاینده خدمات، از طریق رسیدگی به تمام نیازهای امنیتی، مدیریتی و نظارتی شما انجام می شود. Service Mesh Interface (SMI) مجموعه‌ای از APIها را برای رایج‌ترین موارد استفاده از مش (سیاست ترافیک، تله متری و جابجایی) تعریف می‌کند و سازگاری بین مش‌های سرویس را امکان‌پذیر می‌کند، که لایه‌های زیرساخت اختصاصی برای مدیریت ارتباط سرویس به سرویس در یک محیط میکروسرویس ها استانداردسازی این رابط‌ها یک تجربه کاربر نهایی پیشرفته را فراهم می‌کند و بنابراین، یک هدف آینده برای SMI و شبکه‌های خدمات مرتبط است.

وضعیت فعلی:

راهنمای کاربر: SMI یک پروژه جعبه ایمنی نسبتاً جدید است که در آوریل 2020 به CNCF اهدا شد. در نتیجه، پروژه فاقد مستندات کاربر نهایی است. Meshery یک صفحه مدیریت خدمات با معیار عملکرد برای انواع خدماتی است که پذیرش، پیکربندی، عملیات و مدیریت عملکرد مش های مختلف سرویس را تسهیل می کند و مجموعه و نمایش معیارهای برنامه های کاربردی را در بالای هر سرویس مشی اجرا می کند. بنابراین، من می خواهم با راهنمای مشری شروع کنم، که به عنوان نقطه شروعی برای کل جامعه کاربران SMI عمل خواهد کرد.

آموزش های کاربر: در میان پلتفرم های SMI موجود: برنامه نمونه، Learn Layer5، در حال حاضر به عنوان یک دستگاه یادگیری برای SMI و به عنوان برنامه نمونه برای انجام اعتبار سنجی مشخصات SMI عمل می کند. اما در غیر این صورت، پروژه های SMI به طور کامل فاقد آموزش های کاربر نهایی هستند. به دلیل ماهیت بسیار فنی پروژه ها یک مانع جدی است. Meshery برنامه عالی برای نمایش مزایا و استفاده از SMI و مش های خدمات مرتبط است، به همین دلیل است که من از آن به عنوان ابزار پایه برای نمایش ویژگی های SMI استفاده خواهم کرد.

اسناد API: در حال حاضر وجود ندارد. SMI و پروژه های مختلف مرتبط، نقاط پایانی API خود را بر روی یک پلت فرم تعریف می کنند. به عنوان مثال، Meshery نقاط پایانی خود را در server.go تعریف کرده است (https://github.com/layer5io/meshery/blob/master/router/server.go)، اما آنها به خوبی اظهار نظر یا مستندسازی خارجی ندارند. این را می توان با مستندات معنی دار API حل کرد و با افزودن روش هایی برای کاربران برای آزمایش نقاط پایانی آن و پیش نمایش ویژگی های آن، بهبود یافت.

تحلیل:

آموزش های کاربری ایجاد شده است تا به کاربر اجازه دهد تا نرم افزار را درگیر کند و آزمایشی را انجام دهد. آنها باید تعاملی و از نظر زیبایی شناسی جذاب باشند تا توجه کاربر را به خود جلب کنند و مهمتر از همه، استفاده آسان باشد.

با این حال، برای نوشتن یا میزبانی راهنماهای کاربر، قالبی بالغ‌تر توصیه می‌شود، زیرا راهنمای کاربر اغلب به عنوان راهنمای مرجع یا مکانی برای رفع سریع مشکلات است. آنها به جای تعاملی بودن، باید ساختار خوبی داشته باشند و بر بهبود وضوح، انسجام و جریان کاربر خوب تمرکز کنند.

یک راه حل ممکن برای این امر ایجاد آموزش های کاربر جداگانه با استفاده از Google Codelabs و یک راهنمای کاربر مستقل با کمک Jekyll و در نهایت ادغام آنها به همراه اسناد API برای ارائه یک تجربه کامل به کاربر نهایی و همکاران آینده است. .

مخاطب هدف: پروژه‌های SMI روش‌های استقرار و عملیاتی، محیط‌های یادگیری و معیارهای عملکرد را برای همه پروژه‌های تحت آن ارائه می‌کنند. هم به افراد و هم به سازمان ها پاسخ می دهد.

راهنماهای کاربر: من کاربران مبتدی را هدف قرار خواهم داد، بدون هیچ پیش فرضی مبنی بر دانش IT از قبل موجود در پایان کاربر. هدف: کاربران مبتدی دلیل: عمدتاً به عنوان یک راهنمای مرجع گسترده استفاده می شود که باید با گذشت زمان به روز شود. این شامل توضیحات عمیق و نکات مفیدی است تا مطمئن شود کاربر تمام اطلاعات مورد نیاز برای راه اندازی و کار با یک سرویس مش را دارد. این راهنما با افزودن فیلم‌ها، تصاویر، اسکرین‌شات‌ها و تصاویر GIF، در هر کجا که لازم باشد، جذاب‌تر و کاربرپسندتر می‌شود.

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

مستندات نقطه پایانی API: هدف: کاربران پیشرفته دلیل: این بخش بر استفاده از ویژگی های پیچیده تر سرویس مش تمرکز دارد که بیشتر به نفع کاربران پیشرفته با سطح دانش پایه IT است. کاربران پیشرفته به دنبال آموزش های مختصر هستند که در صورت نیاز می توانند به عنوان راهنمای مرجع نیز مورد استفاده قرار گیرند. مستندات Endpoint باید به گونه‌ای نوشته شود که به‌روزرسانی آن آسان باشد، بدون اینکه دقت یا سازگاری آن به خطر بیفتد. ترجیحاً این باید یک فرآیند خودکار باشد.

منابع: راهنمای کاربر: Codelab توسعه دهندگان گوگل - برای ساختن آموزش های تعاملی و جامع کاربر نهایی استفاده می شود. مزایا: - می تواند آموزش جعبه شنی تولید کند. - رویکرد عملی دارد. - با استفاده از Google Docs نوشته شده و از متن Markdown پشتیبانی می کند. - قابل نظارت با استفاده از Google Analytics - مشاهده آسان ترافیک کاربر. - استفاده آسان. آموزش های زیبایی شناسی را تولید می کند که به کاربر امکان می دهد مستقیماً بدون سرمایه گذاری مستقیم با نرم افزار درگیر شود.

Google Codelabs را می توان با استفاده از پروژه CLaaT (Codelabs as a Thing) ارتقا داد و به راحتی مستقر کرد - این برنامه ای است که ابزار خط فرمانی را ارائه می دهد که برای تبدیل آموزش های نوشته شده در Google Doc با استفاده از Markdown به قالب کدلب (HTML) استفاده می شود.

راهنمای کاربر: Jekyll - اسناد موجود برای meshery.io، که در اینجا یافت می شود، در Jekyll میزبانی می شود و از موضوع Docsy Jekyll استفاده می کند. از Markdown، مایع، HTML و CSS برای تولید وب‌سایت‌های آماده میزبان، ثابت و اجرا در محیط توسعه Ruby استفاده می‌کند. مزایا: - می تواند سایت ها را مستقیماً از مخازن GitHub میزبانی کند. - این یک پروژه با پشتیبانی خوب با یک جامعه بسیار فعال است - راهنماهای کاربری و پیشرفت‌ها را می‌توان به سادگی به اسناد SMI و Meshery موجود اضافه کرد، بدون اینکه مجبور باشید برای مهاجرت به پلتفرم دیگری زحمت بکشید.

اسناد API: Swagger (به طور متناوب Swaggo) برای ایجاد اسناد API برای SMI و Meshery استفاده خواهد شد. این یک راه حل زیبا برای نوشتن اسناد API است. مزایا: - مستندسازی از طراحی API شما: اطمینان حاصل می‌کند که اسناد شما با تکامل API شما به‌روز می‌مانند. - مستندات از طراحی API شما: می تواند به طور خودکار از تعاریف API تولید شود. - حفظ نسخه های مستند چندگانه - طراحی های API سفارشی شده

اهداف پروژه: - برای ایجاد آموزش های تعاملی کاربر نهایی برای SMI و شبکه های خدمات مرتبط با استفاده از Meshery به عنوان یک ابزار، از Google Developer Codelabs استفاده کنید. - با استفاده از Jekyll برای مش های سرویس، یک راهنمای کاربر نهایی ایجاد کنید. - از Swagger برای تولید اسناد نقطه پایانی API برای SMI استفاده کنید. - جامعه پروژه را به گونه‌ای هدایت کنید که کاربران یا توسعه‌دهندگان آینده و فعلی بتوانند به راحتی تحت هدایت و نظارت انجمن SMI به اضافه کردن آن ادامه دهند.

جدول زمانی: جدول زمانی پیشنهادی را می‌توانید در اینجا پیدا کنید: https://docs.google.com/document/d/1If2mtBdWZer4qrh66NfXOWBx_3-tiA09jnoPMqy2lqs/edit#bookmark=kix.j1b6m64eubsl

ساختار: ساختار پیشنهادی برای راهنمای کاربر را می‌توانید در اینجا بیابید: https://docs.google.com/document/d/1A3YYAMUte06MojNWo8hdF4KZbvr-qVaaA2myzWeshHQ/edit?usp=sharing

چرا این پروژه؟ جامعه مش خدمات با سرعت رعد و برق سریع در حال گسترش است که با ادغام اخیر آن به عنوان یک پروژه sandbox در CNCF فعال شده است. با این حال، این پروژه شاهد کمبود جدی مستندات، هم برای کاربران نهایی و هم برای توسعه دهندگان است. من در گذشته با سرویس‌های مختلفی از جمله linkerD با برنامه EmojiVoto، Istio با برنامه bookinfo و کنسول Hashicorp بازی کرده‌ام. من تقسیم ترافیک SMI را نیز امتحان کرده‌ام و قوانین اعتبارسنجی مختلفی را در پیکربندی مش سرویس خود پیاده‌سازی کرده‌ام. فرآیند یادگیری بسیار جذاب است اما بسیار فنی است و می تواند برای کاربران جدید و همچنین توسعه دهندگانی که به دنبال برداشتن اولین گام های خود در جامعه سرویس مش یا استفاده از مش های سرویس برای پروژه های شخصی یا حرفه ای خود هستند، به تعویق بیفتد. من می‌خواهم این شکاف را پر کنم که تنها با راهنماها و آموزش‌های کارآمد و مستند قابل انجام است.