🔵 عنوان مقاله
From Go Code to Container Image with Depot API
🟢 خلاصه مقاله:
**این مطلب دو مسیر عملی را پوشش میدهد: ۱) تبدیل کد Go به ایمیج کانتینری با API دیپوت برای بیلدهای سریع، قابلتکرار و مناسب CI، و انتشار در رجیستری؛ ۲) استقرار سایت استاتیک Hugo در هتزنر با ساخت آرتیفکتها، راهاندازی وبسرور یا کانتینر، تنظیم دامنه و SSL، و خودکارسازی در CI/CD. هدف، سادهسازی مسیر از کد تا تولید با تکیه بر سرعت، پایداری نتایج و هزینه اثربخش است.
🟣لینک مقاله:
https://golangweekly.com/link/173630/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
From Go Code to Container Image with Depot API
🟢 خلاصه مقاله:
**این مطلب دو مسیر عملی را پوشش میدهد: ۱) تبدیل کد Go به ایمیج کانتینری با API دیپوت برای بیلدهای سریع، قابلتکرار و مناسب CI، و انتشار در رجیستری؛ ۲) استقرار سایت استاتیک Hugo در هتزنر با ساخت آرتیفکتها، راهاندازی وبسرور یا کانتینر، تنظیم دامنه و SSL، و خودکارسازی در CI/CD. هدف، سادهسازی مسیر از کد تا تولید با تکیه بر سرعت، پایداری نتایج و هزینه اثربخش است.
🟣لینک مقاله:
https://golangweekly.com/link/173630/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
Depot
From Go code to container image with Depot API
Build a specialized container building system using Depot's low-level Go SDK to transform tar archives into container images. This advanced walkthrough demonstrates the three-step build flow: registering builds, acquiring ephemeral BuildKit machines, and…
❤2
🔵 عنوان مقاله
a fantastic illustrated introduction to Big O notation
🟢 خلاصه مقاله:
** این مقاله معرفیای تصویری و روان از نمادگذاری Big O ارائه میدهد و با تکیه بر مثالها، تفاوت مرتبههایی مانند O(1)، O(log n)، O(n) و موارد رایج دیگر را توضیح میدهد. هدف آن نشاندادن مفهوم رشد با بزرگشدن ورودی و مقایسهٔ مقیاسپذیری الگوریتمهاست، بدون درگیرشدن با جزئیات پیادهسازی یا ثابتها. برای هر کسی که تا به حال معنی O(1) و O(log n) برایش سؤال بوده، این نوشته یک شروع عالی است.
🟣لینک مقاله:
https://golangweekly.com/link/173358/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
a fantastic illustrated introduction to Big O notation
🟢 خلاصه مقاله:
** این مقاله معرفیای تصویری و روان از نمادگذاری Big O ارائه میدهد و با تکیه بر مثالها، تفاوت مرتبههایی مانند O(1)، O(log n)، O(n) و موارد رایج دیگر را توضیح میدهد. هدف آن نشاندادن مفهوم رشد با بزرگشدن ورودی و مقایسهٔ مقیاسپذیری الگوریتمهاست، بدون درگیرشدن با جزئیات پیادهسازی یا ثابتها. برای هر کسی که تا به حال معنی O(1) و O(log n) برایش سؤال بوده، این نوشته یک شروع عالی است.
🟣لینک مقاله:
https://golangweekly.com/link/173358/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
🔥1🎉1 1
Forwarded from Software Engineer Labdon
امروز یکی از همکارانم سوال خوبی پرسید که فکر میکنم دغدغه خیلیهاست:
"فرق واقعی Async و Concurrency چیه؟ مگه هر دو به معنی انجام همزمان کارها نیستن؟"
این دو مفهوم اغلب با هم اشتباه گرفته میشن. بذارید با یک مثال ساده تفاوتشون رو باز کنم:
۱. Synchronous vs. Asynchronous
این مفاهیم درباره انتظار کشیدن هستن.
Sync
مثل اینه که بری کافه، قهوه سفارش بدی و همونجا جلوی پیشخوان منتظر بمونی تا آماده بشه و تحویل بگیری.
تا قهوه رو نگیری، هیچ کار دیگهای نمیکنی.
Async
سفارش میدی، یک پیجر (Pager) میگیری و میری سر میزت مینشینی.
در این فاصله میتونی ایمیلهاتو چک کنی.
هر وقت قهوهات آماده شد، پیجر بهت خبر میده.
تو منتظر نموندی و از زمانت استفاده کردی.
۲. Concurrency
این مفهوم درباره مدیریت چند کار در یک بازه زمانی هست.
باریستای کافه رو در نظر بگیرید:
اون همزمان هم سفارش شما رو آماده میکنه، هم سفارش نفر بعدی رو میگیره و هم شیر رو برای یک سفارش دیگه گرم میکنه.
در واقع اون با جابجایی سریع بین کارها (Context Switching)، چند وظیفه رو پیش میبره.
این یعنی همروندی.
نکته کلیدی
برنامهنویسی Async یکی از راههای رسیدن به Concurrency هست.
درک این تفاوت، در طراحی سیستمهای مدرن مثل میکروسرویسها یا پایپلاینهای پردازش دیتا، یک مزیت فوقالعاده است.
این درک به شما کمک میکنه تا بین ابزارهایی مثل Kafka, gRPC یا WebSockets انتخاب درستی داشته باشید و سیستمی بسازید که هم Scalable و هم Reliable باشه.
@ | <Ali Naseri/>
"فرق واقعی Async و Concurrency چیه؟ مگه هر دو به معنی انجام همزمان کارها نیستن؟"
این دو مفهوم اغلب با هم اشتباه گرفته میشن. بذارید با یک مثال ساده تفاوتشون رو باز کنم:
۱. Synchronous vs. Asynchronous
این مفاهیم درباره انتظار کشیدن هستن.
Sync
مثل اینه که بری کافه، قهوه سفارش بدی و همونجا جلوی پیشخوان منتظر بمونی تا آماده بشه و تحویل بگیری.
تا قهوه رو نگیری، هیچ کار دیگهای نمیکنی.
Async
سفارش میدی، یک پیجر (Pager) میگیری و میری سر میزت مینشینی.
در این فاصله میتونی ایمیلهاتو چک کنی.
هر وقت قهوهات آماده شد، پیجر بهت خبر میده.
تو منتظر نموندی و از زمانت استفاده کردی.
۲. Concurrency
این مفهوم درباره مدیریت چند کار در یک بازه زمانی هست.
باریستای کافه رو در نظر بگیرید:
اون همزمان هم سفارش شما رو آماده میکنه، هم سفارش نفر بعدی رو میگیره و هم شیر رو برای یک سفارش دیگه گرم میکنه.
در واقع اون با جابجایی سریع بین کارها (Context Switching)، چند وظیفه رو پیش میبره.
این یعنی همروندی.
نکته کلیدی
برنامهنویسی Async یکی از راههای رسیدن به Concurrency هست.
درک این تفاوت، در طراحی سیستمهای مدرن مثل میکروسرویسها یا پایپلاینهای پردازش دیتا، یک مزیت فوقالعاده است.
این درک به شما کمک میکنه تا بین ابزارهایی مثل Kafka, gRPC یا WebSockets انتخاب درستی داشته باشید و سیستمی بسازید که هم Scalable و هم Reliable باشه.
@ | <Ali Naseri/>
🔵 عنوان مقاله
The 9 Go Test Assertions I Use (and Why)
🟢 خلاصه مقاله:
این مقاله با تکیه بر بحثی قدیمی در دنیای Go بررسی میکند که آیا باید از پکیجهای Assertion استفاده کرد یا خیر. نویسنده میگوید بهجای چارچوبهای سنگین، از چند تابع کمکی ساده و دستساز برای آزمونها استفاده میکند؛ تابعهایی که کارهای رایجی مثل برابری/نابرابری، بررسی خطا (از جمله خطاهای انتظاررفته یا پیچیده)، nil بودن یا نبودن، شامل بودن، طول مجموعهها، مقایسه تقریبی اعداد/زمان و انتظار وقوع panic را پوشش میدهند و پیام خطای واضحی میدهند بدون اینکه وابستگی خارجی اضافه کنند. او به پرسش «آیا Assertionها ضدالگو هستند؟» پاسخ میدهد: وقتی منطق را پنهان کنند و به زنجیرهسازی و DSLهای مبهم تبدیل شوند، بله؛ اما اگر کوچک، هدفمند و شفاف باشند نهتنها ایرادی ندارند، بلکه خوانایی و نگهداشت را بهتر میکنند. در نهایت توصیه میکند Helperها حداقلی و محلی باشند، نامگذاری روشن داشته باشند، از اغراق در انتزاع پرهیز شود، و فقط در موارد لازم سراغ ابزارهایی مثل go-cmp یا testify برویم. نتیجهگیری: مشکل در خود Assertion نیست، در استفاده بیملاحظه از آن است.
🟣لینک مقاله:
https://golangweekly.com/link/173627/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
The 9 Go Test Assertions I Use (and Why)
🟢 خلاصه مقاله:
این مقاله با تکیه بر بحثی قدیمی در دنیای Go بررسی میکند که آیا باید از پکیجهای Assertion استفاده کرد یا خیر. نویسنده میگوید بهجای چارچوبهای سنگین، از چند تابع کمکی ساده و دستساز برای آزمونها استفاده میکند؛ تابعهایی که کارهای رایجی مثل برابری/نابرابری، بررسی خطا (از جمله خطاهای انتظاررفته یا پیچیده)، nil بودن یا نبودن، شامل بودن، طول مجموعهها، مقایسه تقریبی اعداد/زمان و انتظار وقوع panic را پوشش میدهند و پیام خطای واضحی میدهند بدون اینکه وابستگی خارجی اضافه کنند. او به پرسش «آیا Assertionها ضدالگو هستند؟» پاسخ میدهد: وقتی منطق را پنهان کنند و به زنجیرهسازی و DSLهای مبهم تبدیل شوند، بله؛ اما اگر کوچک، هدفمند و شفاف باشند نهتنها ایرادی ندارند، بلکه خوانایی و نگهداشت را بهتر میکنند. در نهایت توصیه میکند Helperها حداقلی و محلی باشند، نامگذاری روشن داشته باشند، از اغراق در انتزاع پرهیز شود، و فقط در موارد لازم سراغ ابزارهایی مثل go-cmp یا testify برویم. نتیجهگیری: مشکل در خود Assertion نیست، در استفاده بیملاحظه از آن است.
🟣لینک مقاله:
https://golangweekly.com/link/173627/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
www.alexedwards.net
The 9 Go test assertions I use (and why) - Alex Edwards
🤝3❤1
🎙 پادکست جدید
🚧 Go Improvement: 🫸 waitgroup.Go, json/v2, 🐍 new features for cobra apps, with Jeremy Foran
➖➖➖➖➖➖➖➖
👑 @gopher_academy
🚧 Go Improvement: 🫸 waitgroup.Go, json/v2, 🐍 new features for cobra apps, with Jeremy Foran
➖➖➖➖➖➖➖➖
👑 @gopher_academy
🔥2 1
🔵 عنوان مقاله
Making Games in Go: 3 Months Without LLMs vs 3 Days With LLMs
🟢 خلاصه مقاله:
**این مقاله روایت شخصی و سرگرمکنندهای از ساخت دو بازی کارتی با زبان Go است که دو رویکرد را مقایسه میکند: بدون کمک LLMها حدود سه ماه زمان برد، اما با کمک LLMها ظرف سه روز به نتیجه رسید. نویسنده نشان میدهد که بخش عمده زمان بدون LLM صرف مطالعه مستندات، اتصال کتابخانهها و رفع خطاها میشود، در حالیکه LLMها با تولید اسکلت کد، خلاصهسازی اسناد و پیشنهاد راهحلها، کارهای زمانبر را فشرده میکنند. نتیجهگیری مقاله این است که LLMها جایگزین مهارت مهندسی نیستند، اما با نظارت و آزمون مناسب میتوانند مسیر رسیدن از ایده به نمونهٔ قابل اجرا را بهطور چشمگیری کوتاه کنند، و Go بستر ساده و محکمی برای این کار فراهم میکند.
🟣لینک مقاله:
https://golangweekly.com/link/173648/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
Making Games in Go: 3 Months Without LLMs vs 3 Days With LLMs
🟢 خلاصه مقاله:
**این مقاله روایت شخصی و سرگرمکنندهای از ساخت دو بازی کارتی با زبان Go است که دو رویکرد را مقایسه میکند: بدون کمک LLMها حدود سه ماه زمان برد، اما با کمک LLMها ظرف سه روز به نتیجه رسید. نویسنده نشان میدهد که بخش عمده زمان بدون LLM صرف مطالعه مستندات، اتصال کتابخانهها و رفع خطاها میشود، در حالیکه LLMها با تولید اسکلت کد، خلاصهسازی اسناد و پیشنهاد راهحلها، کارهای زمانبر را فشرده میکنند. نتیجهگیری مقاله این است که LLMها جایگزین مهارت مهندسی نیستند، اما با نظارت و آزمون مناسب میتوانند مسیر رسیدن از ایده به نمونهٔ قابل اجرا را بهطور چشمگیری کوتاه کنند، و Go بستر ساده و محکمی برای این کار فراهم میکند.
🟣لینک مقاله:
https://golangweekly.com/link/173648/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
Forwarded from DevOps Labdon
امنیت در Docker: چیزی که اغلب فراموش میکنیم!
* از rootless containers استفاده کنید: اجرای اپلیکیشن با کاربر non-root ریسک نفوذ رو خیلی کم میکنه.
* از Base image سبک و امن استفاده کنید: مثلاً alpine یا distroless. imageهای بزرگتر مثل ubuntu اغلب پکیجهای غیرضروری دارن که سطح حمله رو زیاد میکنن.
* حتما وDependencyها رو pin کنید: همیشه نسخه دقیق کتابخونهها رو مشخص کنید تا از تغییرات ناخواسته جلوگیری بشه.
* از .dockerignore استفاده کنید: فایلهای حساس (مثل .env یا کلیدها) هرگز نباید داخل image قرار بگیرن.
* بهروز نگه داشتن imageها: آسیبپذیریها خیلی سریع پیدا میشن، پس آپدیت مرتب imageها ضروریه.
بارها پیش میاد که به خاطر استفاده از یک base image قدیمی، vulnerability جدی توی اسکن امنیتی پیدا میشه. فقط با عوض کردن base image به نسخهی جدیدتر و سبکتر، هم امنیت بیشتر میشه، هم حجم image کاهش پیدا میکنه.
نکات تکمیلی امنیت در Docker
1. استفاده از Healthcheck
- توی Dockerfile با HEALTHCHECK وضعیت سرویس رو بررسی کنید که باعث میشه container ناسالم زودتر شناسایی و جایگزین بشن.
2. حداقل کردن Surface Attack با distroless images
- این imageها فقط باینری نهایی رو دارن (بدون package manager یا shell).
- دسترسی مهاجم به شدت محدود میشه.
3.فعال کردن User namespace remapping
- باعث میشه کاربر root داخل container، روی سیستم میزبان واقعاً root نباشه.
4. استفاده از Read-Only Filesystem
- container رو با --read-only بالا بیارید تا کسی نتونه فایلهای سیستمی داخلش رو تغییر بده.
5. مدیریت Secretها بهدرستی
- هرگز secrets رو داخل image نذارید.
- از ابزارهایی مثل Docker secrets، HashiCorp Vault یا AWS/GCP Secret Manager استفاده کنید.
6. Scan امنیتی منظم
- ابزارهایی مثل Trivy, Grype یا Docker Scout رو برای اسکن image استفاده کنید.
- این ابزارها آسیبپذیریهای شناختهشده (CVE) رو شناسایی میکنن.
7. محدود کردن Resourceها
- با --cpus و --memory منابع container رو محدود کنید تا جلوی حملات DoS یا مصرف بیرویه گرفته بشه.
8. استفاده از شبکههای ایزوله
- کانتینرهایی که لازم نیست با اینترنت یا کانتینرهای دیگه در ارتباط باشن رو توی یک شبکهی جداگانه نگه دارید.
9. امضای دیجیتال و اعتبارسنجی Imageها
- با Docker Content Trust (DCT) یا cosign امضا و اعتبارسنجی کنید که image تغییر نکرده باشه.
10. بروزرسانی مرتب Docker Engine و Runtime
- چون آسیبپذیریها فقط توی imageها نیستن، بلکه خود daemon و runtime هم میتونه مشکل امنیتی داشته باشه.
*امنیت در Docker فقط به Dockerfile محدود نیست؛ از انتخاب base image شروع میشه، به مدیریت secret و network میرسه و حتی شامل CI/CD pipeline هم میشه*
<Somaye Omidi/>
* از rootless containers استفاده کنید: اجرای اپلیکیشن با کاربر non-root ریسک نفوذ رو خیلی کم میکنه.
* از Base image سبک و امن استفاده کنید: مثلاً alpine یا distroless. imageهای بزرگتر مثل ubuntu اغلب پکیجهای غیرضروری دارن که سطح حمله رو زیاد میکنن.
* حتما وDependencyها رو pin کنید: همیشه نسخه دقیق کتابخونهها رو مشخص کنید تا از تغییرات ناخواسته جلوگیری بشه.
* از .dockerignore استفاده کنید: فایلهای حساس (مثل .env یا کلیدها) هرگز نباید داخل image قرار بگیرن.
* بهروز نگه داشتن imageها: آسیبپذیریها خیلی سریع پیدا میشن، پس آپدیت مرتب imageها ضروریه.
بارها پیش میاد که به خاطر استفاده از یک base image قدیمی، vulnerability جدی توی اسکن امنیتی پیدا میشه. فقط با عوض کردن base image به نسخهی جدیدتر و سبکتر، هم امنیت بیشتر میشه، هم حجم image کاهش پیدا میکنه.
نکات تکمیلی امنیت در Docker
1. استفاده از Healthcheck
- توی Dockerfile با HEALTHCHECK وضعیت سرویس رو بررسی کنید که باعث میشه container ناسالم زودتر شناسایی و جایگزین بشن.
2. حداقل کردن Surface Attack با distroless images
- این imageها فقط باینری نهایی رو دارن (بدون package manager یا shell).
- دسترسی مهاجم به شدت محدود میشه.
3.فعال کردن User namespace remapping
- باعث میشه کاربر root داخل container، روی سیستم میزبان واقعاً root نباشه.
4. استفاده از Read-Only Filesystem
- container رو با --read-only بالا بیارید تا کسی نتونه فایلهای سیستمی داخلش رو تغییر بده.
5. مدیریت Secretها بهدرستی
- هرگز secrets رو داخل image نذارید.
- از ابزارهایی مثل Docker secrets، HashiCorp Vault یا AWS/GCP Secret Manager استفاده کنید.
6. Scan امنیتی منظم
- ابزارهایی مثل Trivy, Grype یا Docker Scout رو برای اسکن image استفاده کنید.
- این ابزارها آسیبپذیریهای شناختهشده (CVE) رو شناسایی میکنن.
7. محدود کردن Resourceها
- با --cpus و --memory منابع container رو محدود کنید تا جلوی حملات DoS یا مصرف بیرویه گرفته بشه.
8. استفاده از شبکههای ایزوله
- کانتینرهایی که لازم نیست با اینترنت یا کانتینرهای دیگه در ارتباط باشن رو توی یک شبکهی جداگانه نگه دارید.
9. امضای دیجیتال و اعتبارسنجی Imageها
- با Docker Content Trust (DCT) یا cosign امضا و اعتبارسنجی کنید که image تغییر نکرده باشه.
10. بروزرسانی مرتب Docker Engine و Runtime
- چون آسیبپذیریها فقط توی imageها نیستن، بلکه خود daemon و runtime هم میتونه مشکل امنیتی داشته باشه.
*امنیت در Docker فقط به Dockerfile محدود نیست؛ از انتخاب base image شروع میشه، به مدیریت secret و network میرسه و حتی شامل CI/CD pipeline هم میشه*
<Somaye Omidi/>
❤3
🔵 عنوان مقاله
How to Deploy a Hugo Static Site to Hetzner
🟢 خلاصه مقاله:
یک راهنمای مرحلهبهمرحله برای استقرار سایت استاتیک Hugo روی Hetzнер است که با تکیه بر سادگی، هزینه کم و کارایی بالا، دو مسیر اصلی را توضیح میدهد: میزبانی روی یک سرور ابری سبک (با Nginx/Caddy) یا استفاده از سرویسهای ذخیرهسازی برای حذف نگهداری سرور. سپس یک خط لولهٔ خودکار پیشنهاد میکند که با هر push کد، سایت را میسازد و با ابزارهایی مثل rsync/scp/rclone منتشر میکند، همراه با مدیریت امن کلیدها، استقرار اتمیک و امکان rollback. در ادامه تنظیم DNS و TLS (Let’s Encrypt)، هدرهای کش، فشردهسازی، و در صورت نیاز CDN پوشش داده میشود. خروجی، فرآیندی تکرارپذیر از گیت تا تولید است که HTTPS، کارایی مناسب و نگهداری کمهزینه را روی Hetzner فراهم میکند.
🟣لینک مقاله:
https://golangweekly.com/link/173631/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
How to Deploy a Hugo Static Site to Hetzner
🟢 خلاصه مقاله:
یک راهنمای مرحلهبهمرحله برای استقرار سایت استاتیک Hugo روی Hetzнер است که با تکیه بر سادگی، هزینه کم و کارایی بالا، دو مسیر اصلی را توضیح میدهد: میزبانی روی یک سرور ابری سبک (با Nginx/Caddy) یا استفاده از سرویسهای ذخیرهسازی برای حذف نگهداری سرور. سپس یک خط لولهٔ خودکار پیشنهاد میکند که با هر push کد، سایت را میسازد و با ابزارهایی مثل rsync/scp/rclone منتشر میکند، همراه با مدیریت امن کلیدها، استقرار اتمیک و امکان rollback. در ادامه تنظیم DNS و TLS (Let’s Encrypt)، هدرهای کش، فشردهسازی، و در صورت نیاز CDN پوشش داده میشود. خروجی، فرآیندی تکرارپذیر از گیت تا تولید است که HTTPS، کارایی مناسب و نگهداری کمهزینه را روی Hetzner فراهم میکند.
🟣لینک مقاله:
https://golangweekly.com/link/173631/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
Pliutau
Deploy Hugo static site to Hetzner
Recently I ditched my AWS account and moved my personal small projects to a Hetzner VPS, what a nice feeling tinkering with your own server again! As a part of this process I also had to change how I deploy this blog, so I thought I would share my setup in…
🔥1
🔵 عنوان مقاله
YARR: Yet Another RSS Reader
🟢 خلاصه مقاله:
یک گردآورندهی فید به نام YARR است که بهعنوان یک RSS Reader، بهروزرسانیهای چندین وبسایت را در یک محیط واحد جمع میکند. هستهی سرویس با زبان Go نوشته شده تا سمت سرور سریع و کارآمد باشد و رابط کاربری با Vue.js ساخته شده تا تجربهای واکنشگرا و روان ارائه دهد. تفکیکِ روشن بین بکاند و فرانتاند، نگهداری و گسترش را ساده میکند و YARR را به گزینهای مناسب برای دنبالکردن متمرکز خبرها و مطالب از منابع مختلف تبدیل میسازد.
🟣لینک مقاله:
https://golangweekly.com/link/173349/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
YARR: Yet Another RSS Reader
🟢 خلاصه مقاله:
یک گردآورندهی فید به نام YARR است که بهعنوان یک RSS Reader، بهروزرسانیهای چندین وبسایت را در یک محیط واحد جمع میکند. هستهی سرویس با زبان Go نوشته شده تا سمت سرور سریع و کارآمد باشد و رابط کاربری با Vue.js ساخته شده تا تجربهای واکنشگرا و روان ارائه دهد. تفکیکِ روشن بین بکاند و فرانتاند، نگهداری و گسترش را ساده میکند و YARR را به گزینهای مناسب برای دنبالکردن متمرکز خبرها و مطالب از منابع مختلف تبدیل میسازد.
🟣لینک مقاله:
https://golangweekly.com/link/173349/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
GitHub
GitHub - nkanaev/yarr: yet another rss reader
yet another rss reader. Contribute to nkanaev/yarr development by creating an account on GitHub.
❤1
🔵 عنوان مقاله
Announcing GoReleaser v2.12
🟢 خلاصه مقاله:
گو ریلیزر نسخه ۲.۱۲ منتشر شد؛ ابزاری برای خودکارسازی انتشار پروژههای Go. این نسخه یکپارچهسازی جدید با Docker، گواهیگذاری (attestation) تصاویر Docker، پشتیبانی از بستهبندی Makeself برای ساخت بستههای خوداستخراج/اجرایی، سازگاری با Go 1.25 و بهبودهای دیگر را ارائه میکند.
🟣لینک مقاله:
https://golangweekly.com/link/173634/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
Announcing GoReleaser v2.12
🟢 خلاصه مقاله:
گو ریلیزر نسخه ۲.۱۲ منتشر شد؛ ابزاری برای خودکارسازی انتشار پروژههای Go. این نسخه یکپارچهسازی جدید با Docker، گواهیگذاری (attestation) تصاویر Docker، پشتیبانی از بستهبندی Makeself برای ساخت بستههای خوداستخراج/اجرایی، سازگاری با Go 1.25 و بهبودهای دیگر را ارائه میکند.
🟣لینک مقاله:
https://golangweekly.com/link/173634/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
Carlosbecker
Announcing GoReleaser v2.12 | Carlos Becker
This version introduces the new version of the Docker integration,
Docker image attestation,
Makeself packaging support,
Go 1.25,
and much more!
Docker image attestation,
Makeself packaging support,
Go 1.25,
and much more!
❤1🤝1
Forwarded from Software Engineer Labdon
کد ۴۸ ساله معروف بیل گیتس، اوپنسورس شد!
مایکروسافت کد ۴۸ سالهی معروف بیل گیتس را متنباز کرد تا هر کسی بتواند آن را ببیند و استفاده کند.
https://github.com/microsoft/BASIC-M6502
| <Saber V/>
مایکروسافت کد ۴۸ سالهی معروف بیل گیتس را متنباز کرد تا هر کسی بتواند آن را ببیند و استفاده کند.
https://github.com/microsoft/BASIC-M6502
| <Saber V/>
💋3🎉1
🔵 عنوان مقاله
Go 1.25 Released
🟢 خلاصه مقاله:
انتشار Go 1.25 همزمان با تعطیلات نویسنده بود و باعث شد پوشش فوری آن ممکن نشود. بااینحال این نسخه، مطابق روال نسخههای جزئی گو، بهبودهای تدریجی در پایداری، کارایی و تجربه توسعهدهنده ارائه میدهد. توصیه میشود یادداشتهای انتشار بررسی شود، نسخه جدید در محیط آزمایشی امتحان گردد و ارتقا بهصورت کنترلشده انجام شود. بهزودی مرور دقیقتری از نکات برجسته و تغییرات ظریف یا موارد از ردهخارج ارائه خواهد شد. از تلاشهای تیم و مشارکتکنندگان گو نیز قدردانی میشود.
🟣لینک مقاله:
https://golangweekly.com/link/173113/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
Go 1.25 Released
🟢 خلاصه مقاله:
انتشار Go 1.25 همزمان با تعطیلات نویسنده بود و باعث شد پوشش فوری آن ممکن نشود. بااینحال این نسخه، مطابق روال نسخههای جزئی گو، بهبودهای تدریجی در پایداری، کارایی و تجربه توسعهدهنده ارائه میدهد. توصیه میشود یادداشتهای انتشار بررسی شود، نسخه جدید در محیط آزمایشی امتحان گردد و ارتقا بهصورت کنترلشده انجام شود. بهزودی مرور دقیقتری از نکات برجسته و تغییرات ظریف یا موارد از ردهخارج ارائه خواهد شد. از تلاشهای تیم و مشارکتکنندگان گو نیز قدردانی میشود.
🟣لینک مقاله:
https://golangweekly.com/link/173113/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
go.dev
Go 1.25 is released - The Go Programming Language
Go 1.25 adds container-aware GOMAXPROCS, testing/synctest package, experimental GC, experimental encoding/json/v2, and more.
❤1
Forwarded from DevOps Labdon
🔵 عنوان مقاله
Getting Started with Falco Security Tool on GKE
🟢 خلاصه مقاله:
این آموزش نحوه راهاندازی و پیکربندی Falco روی GKE را برای امنیت زمان اجرا نشان میدهد: نصب عاملهای Falco در خوشه، آزمایش قوانین پیشفرض با شبیهسازی رفتارهای مشکوک، اتصال رویدادها به Google Cloud Monitoring برای ساخت هشدارهای قابل اقدام، و افزودن قوانین سفارشی برای متناسبسازی تشخیصها با نیازهای کلاستر. نتیجه، یک لایه تشخیص زمان اجرا روی GKE با هشداردهی یکپارچه و قابلیت تنظیم برای کاهش خطاهای مثبت کاذب است.
🟣لینک مقاله:
https://ku.bz/zFRVy94dl
➖➖➖➖➖➖➖➖
👑 @DevOps_Labdon
Getting Started with Falco Security Tool on GKE
🟢 خلاصه مقاله:
این آموزش نحوه راهاندازی و پیکربندی Falco روی GKE را برای امنیت زمان اجرا نشان میدهد: نصب عاملهای Falco در خوشه، آزمایش قوانین پیشفرض با شبیهسازی رفتارهای مشکوک، اتصال رویدادها به Google Cloud Monitoring برای ساخت هشدارهای قابل اقدام، و افزودن قوانین سفارشی برای متناسبسازی تشخیصها با نیازهای کلاستر. نتیجه، یک لایه تشخیص زمان اجرا روی GKE با هشداردهی یکپارچه و قابلیت تنظیم برای کاهش خطاهای مثبت کاذب است.
🟣لینک مقاله:
https://ku.bz/zFRVy94dl
➖➖➖➖➖➖➖➖
👑 @DevOps_Labdon
ferrishall.dev
Falco Setup Guide for GKE Beginners
Learn how to install and use Falco security tool on GKE for real-time monitoring and alerting in Kubernetes environments
🔵 عنوان مقاله
The Deeper Love of Go.
🟢 خلاصه مقاله:
این یادداشت در Golang Weekly توضیح میدهد چرا علاقه به Go با گذشت زمان عمیقتر میشود: سادگی زبانی، کتابخانه استاندارد کارآمد، ابزارهای یکپارچه و مدل همزمانی عملی که طراحی شفاف را تشویق میکند. نتیجه این ترکیب، ساخت و استقرار قابل پیشبینی، کد خوانا و تیمهایی است که سریعتر و مطمئنتر کار میکنند. در عین پذیرش محدودیتها—مثل رسیدگی صریح به خطا و پرهیز آگاهانه از ویژگیهای پیچیده—مقاله نشان میدهد همین قیود به نگهداشتپذیری و پایداری بلندمدت کمک میکنند. در نهایت، با وجود بهبودهای سنجیده در بخشهایی مانند جنریکها و ابزارها، ارزشهای اصلی Go یعنی سادگی، وضوح و قابلیت اتکا محور باقی میمانند.
🟣لینک مقاله:
https://golangweekly.com/link/173647/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
The Deeper Love of Go.
🟢 خلاصه مقاله:
این یادداشت در Golang Weekly توضیح میدهد چرا علاقه به Go با گذشت زمان عمیقتر میشود: سادگی زبانی، کتابخانه استاندارد کارآمد، ابزارهای یکپارچه و مدل همزمانی عملی که طراحی شفاف را تشویق میکند. نتیجه این ترکیب، ساخت و استقرار قابل پیشبینی، کد خوانا و تیمهایی است که سریعتر و مطمئنتر کار میکنند. در عین پذیرش محدودیتها—مثل رسیدگی صریح به خطا و پرهیز آگاهانه از ویژگیهای پیچیده—مقاله نشان میدهد همین قیود به نگهداشتپذیری و پایداری بلندمدت کمک میکنند. در نهایت، با وجود بهبودهای سنجیده در بخشهایی مانند جنریکها و ابزارها، ارزشهای اصلی Go یعنی سادگی، وضوح و قابلیت اتکا محور باقی میمانند.
🟣لینک مقاله:
https://golangweekly.com/link/173647/web
➖➖➖➖➖➖➖➖
👑 @gopher_academy
Bitfield Consulting
The Deeper Love of Go (Go 1.25 edition) — Bitfield Consulting
Hello, and welcome to learning Go! It's great to have you here. The Deeper Love of Go is a book introducing the Go programming language, suitable for complete beginners, as well as those with experience programming in other languages. Includes free …
❤2
Gopher Academy
🆗 کتاب The Anatomy of Go توضیحات این کتاب👇 ➖➖➖➖➖➖➖➖ 👑 @gopher_academy
🆗 معرفی کتاب «The Anatomy of Go»
درک عمیق از Go: این کتاب بهطور جامع به بررسی درونمایههای زبان Go میپردازد؛ از نوعها یا مدیریت حافظه گرفته تا concurrency و تبدیل کد به اسمبلی.
حالت Early Access: هماکنون بخش قابل توجهی از کتاب (فصلهای ۱ تا ۶) در دسترس است و بقیه فصول بهمرور منتشر میشوند. با خرید، علاوه بر دسترسی فعلی، بهروزرسانیهای آینده نیز بدون هزینه میرسانی میشود.
قیمت ویژه: نسخه Early Access با ۲۰ دلار قابل تهیه است و پس از انتشار کامل کتاب، قیمت به ۳۵ دلار افزایش خواهد یافت. خرید در این مرحله علاوه بر قیمت پایینتر، امکان دریافت updates را نیز فراهم میکند.
فهرست فصول اولیه (در دسترس)
Go Thinks Simple Works Better
فلسفه طراحی Go، نحوه اجرای کد، تصمیمات طراحی
Basic Data Types, Variables, and Constants
نوعهای دادهای، اشارهگرها، متغیرها، کانستنتها، و مواردی مثل unsafe pointers
Arrays, Slices, Strings and Maps
ساختار و رفتار داخلی آرایهها، اسلایس، رشتهها و مپها
Structs, Generics & Interfaces
ساختمان structها، جنریکها، اینترفیسها و عملکرد در زمان اجرا
How Does Go Code Turn into Assembly?
روند واقعی کامپایل: از AST تا SSA، بهینهسازی، inlining، و تولید اسمبلی
Functionality
نحوه عملکرد defer، panic/recover، حذف کدهای مرده، inlining و devirtualization
🆗پیشبینی فصول آینده
فصولی که در راه هستند عبارتند از:
فصل ۷: Memory
نحوه مدیریت حافظه: stack، heap، escape analysis، garbage collection
فصل ۸: Concurrency
مدل همزمانی Go: کانالها، Select، Goroutine lifecycle، Scheduler، شبکه و I/O
🆗درباره نویسنده
Phuong Le (func25):
نویسنده، فعال جامعه Go و مهندس فنی در VictoriaMetrics — شرکتی با محصولات مبتنی بر Go مثل VM و VictoriaLogs.
با تسلط بر مفاهیم پیچیده زبان، او در این کتاب تلاش میکند پیچیدگیها را ساده و کاربردی توضیح دهد.
🥳 https://www.bytesizego.com/books/anatomy-of-go
➖➖➖➖➖➖➖➖
👑 @gopher_academy
درک عمیق از Go: این کتاب بهطور جامع به بررسی درونمایههای زبان Go میپردازد؛ از نوعها یا مدیریت حافظه گرفته تا concurrency و تبدیل کد به اسمبلی.
حالت Early Access: هماکنون بخش قابل توجهی از کتاب (فصلهای ۱ تا ۶) در دسترس است و بقیه فصول بهمرور منتشر میشوند. با خرید، علاوه بر دسترسی فعلی، بهروزرسانیهای آینده نیز بدون هزینه میرسانی میشود.
قیمت ویژه: نسخه Early Access با ۲۰ دلار قابل تهیه است و پس از انتشار کامل کتاب، قیمت به ۳۵ دلار افزایش خواهد یافت. خرید در این مرحله علاوه بر قیمت پایینتر، امکان دریافت updates را نیز فراهم میکند.
فهرست فصول اولیه (در دسترس)
Go Thinks Simple Works Better
فلسفه طراحی Go، نحوه اجرای کد، تصمیمات طراحی
Basic Data Types, Variables, and Constants
نوعهای دادهای، اشارهگرها، متغیرها، کانستنتها، و مواردی مثل unsafe pointers
Arrays, Slices, Strings and Maps
ساختار و رفتار داخلی آرایهها، اسلایس، رشتهها و مپها
Structs, Generics & Interfaces
ساختمان structها، جنریکها، اینترفیسها و عملکرد در زمان اجرا
How Does Go Code Turn into Assembly?
روند واقعی کامپایل: از AST تا SSA، بهینهسازی، inlining، و تولید اسمبلی
Functionality
نحوه عملکرد defer، panic/recover، حذف کدهای مرده، inlining و devirtualization
🆗پیشبینی فصول آینده
فصولی که در راه هستند عبارتند از:
فصل ۷: Memory
نحوه مدیریت حافظه: stack، heap، escape analysis، garbage collection
فصل ۸: Concurrency
مدل همزمانی Go: کانالها، Select، Goroutine lifecycle، Scheduler، شبکه و I/O
🆗درباره نویسنده
Phuong Le (func25):
نویسنده، فعال جامعه Go و مهندس فنی در VictoriaMetrics — شرکتی با محصولات مبتنی بر Go مثل VM و VictoriaLogs.
با تسلط بر مفاهیم پیچیده زبان، او در این کتاب تلاش میکند پیچیدگیها را ساده و کاربردی توضیح دهد.
🥳 https://www.bytesizego.com/books/anatomy-of-go
➖➖➖➖➖➖➖➖
👑 @gopher_academy
🍾4
Gopher Academy
کتاب Foundations of Debugging for Golang (Book) 👇👇👇👇 ➖➖➖➖➖➖➖➖ 👑 @gopher_academy
این کتاب برای توسعهدهندگان Junior و Mid، طراحی شده تا مهارتهای عیبیابی در توسعه Go را از پایه تا سطح پیشرفته ارتقاء دهد.
---
معرفی کتاب
کتاب Foundations of Debugging for Golang**، نوشتهی **Matt Boyle**، با هدف آموزش مهارتهای حیاتی در زمینهی **دیباگکردن در محیطهای محلی و تولید منتشر شده است. توسط ByteSizeGo به قیمت ۳۵ دلار عرضه شده و شامل آپدیتهای مادامالعمر برای خریداران اولیه است ([bytesizego.com][1]).
---
فصلهایی که خواهید آموخت:
چه چیزهایی یاد میگیرید؟
* تقویت قدرت تشخیص خطاها تنها با مشاهده و تحلیل کد
* ساخت استراتژی لاگگذاری سازمانی برای اپلیکیشنهای Go
* تعریف و استفاده از Metrics و ایجاد داشبوردهای نظارتی
* پیادهسازی و استفاده از Distributed Tracing در معماری میکروسرویس
* استفاده از ابزارهای پروفایلینگ Go (مثل
---
درباره نویسنده و اعتبار کتاب
* نویسنده: **Matt Boyle**، مهندس ارشد با تجربهی عملی در سیستمهای توزیعشده و استفادهی حرفهای از Go.
* کتاب به سبک تجربی و کاربردی نوشته شده و بازخوردهای مثبتی از جامعه دریافت کرده:
«Topics like debugging-by-eye, logging, tracing, profiling... written in a clear style with minimal sample code»
---
معرفی کتاب
کتاب Foundations of Debugging for Golang**، نوشتهی **Matt Boyle**، با هدف آموزش مهارتهای حیاتی در زمینهی **دیباگکردن در محیطهای محلی و تولید منتشر شده است. توسط ByteSizeGo به قیمت ۳۵ دلار عرضه شده و شامل آپدیتهای مادامالعمر برای خریداران اولیه است ([bytesizego.com][1]).
---
فصلهایی که خواهید آموخت:
چه چیزهایی یاد میگیرید؟
* تقویت قدرت تشخیص خطاها تنها با مشاهده و تحلیل کد
* ساخت استراتژی لاگگذاری سازمانی برای اپلیکیشنهای Go
* تعریف و استفاده از Metrics و ایجاد داشبوردهای نظارتی
* پیادهسازی و استفاده از Distributed Tracing در معماری میکروسرویس
* استفاده از ابزارهای پروفایلینگ Go (مثل
pprof
) برای بررسی عملکرد و بهینهسازی اپها ([bytesizego.com][1])---
درباره نویسنده و اعتبار کتاب
* نویسنده: **Matt Boyle**، مهندس ارشد با تجربهی عملی در سیستمهای توزیعشده و استفادهی حرفهای از Go.
* کتاب به سبک تجربی و کاربردی نوشته شده و بازخوردهای مثبتی از جامعه دریافت کرده:
«Topics like debugging-by-eye, logging, tracing, profiling... written in a clear style with minimal sample code»
❤1
Forwarded from Gopher Job
Companies using Go.xlsx
12.1 KB
📂 یه فایل فوقالعاده آماده کردیم براتون!
🔹 لیست ۶۴ شرکت بزرگ دنیا که از Golang استفاده میکنن
🔹 همراه با موقعیتهای شغلی فعال Golang توی همین شرکتها
اگه دنبال فرصتهای شغلی توی حوزه Backend، DevOps یا Software Engineering هستی، این فایل میتونه یه نقطه شروع عالی باشه.
📌 همین الان فایل رو بردار و شرکتها + موقعیتها رو ببین
@gopher_job
🔹 لیست ۶۴ شرکت بزرگ دنیا که از Golang استفاده میکنن
🔹 همراه با موقعیتهای شغلی فعال Golang توی همین شرکتها
اگه دنبال فرصتهای شغلی توی حوزه Backend، DevOps یا Software Engineering هستی، این فایل میتونه یه نقطه شروع عالی باشه.
📌 همین الان فایل رو بردار و شرکتها + موقعیتها رو ببین
@gopher_job
❤1🤝1