Go Casts 🚀 – Telegram
Go Casts 🚀
7.67K subscribers
279 photos
20 videos
13 files
497 links
VP of Eng Zarinpal | Ex Snapp! Senior SE
فوق لیسانس هوش مصنوعی از دانشگاه تهران

اشتراک محتوا در مورد مهندسی نرم افزار، هوش مصنوعی، گولنگ
https://gocasts.ir

پروفایل
https://www.linkedin.com/in/gohossein

ارتباط
@lifography

Ai for Software
@aicasts_ir
Download Telegram
#php #devops

سلام به همه دوستان، مخصوصا دوستان خفن php developer و devops
یکی از دوستان من یه اپلیکیشن داره که با php توسعه داده شده، من dockerizeش کردم براش، ولی خیلی عملکرد نسخه dockerize شده روی vps با ۱۶ گیگ رم بدتر از نسخه ای هست که روی یه هاست cpanel هست.

حالا از دوستان خفن php و devops در مورد performance این اپلیکیشن php اگه میتونید راهنمایی کنید که چرا عملکرد اپلیکیشن روی مثلا یه هاست با CPanel خیلی بهتر از عملکرد همون اپلیکیشن روی vps با nginx بصورت dockerize شده هست؟

اینطوری بگم که برای تست لود با ۱۰ هزار درخواست تفاوت عملکرد مثلا روی cpanel عدد ۱۸۰ rps رو داره ولی روی vps که ۱۶ گیگ هم رم داره و ۸ هسته cpu داره حدود 40 rps هست؟

چه چیزایی میتونه کمک کنه عملکرد php در نسخه dockerize شده رو بهینه کرد؟
اینم مشخصاتیه که ممکنه کمک کنه
php: 7.4.33
OPCache: enabled
composer install --optimize-autoloader --no-dev

دو لایه nginx وجود داره که یکی ش gateway هست و صرفا proxy میکنه و یکی ش nginx داخل container خود php هست که nginx و fpm اونجا هستند، ولی واقعیتش فکر نمیکنم مشکل nginxها باشن چون تفاوت عملکرد خیلی زیاده، حدسم اینه یه چیزی در مورد خود تنظیمات fpm یا php یا docker باید انجام بشه، نمیدونم..

شما ایده ای ندارید؟
🔥5👍31
برنامه هایی که با گولنگ نوشته میشن یکی از شایع ترین خطاهایی که در runtime و روی production باهاش مواجه میشن خطای panic از جنس nil pointer هست. که میتونه منجر به از کار افتادن برنامه هم بشه، هر چند راه هایی وجود داره که شما بتونید panic رو recover کنید، اما اصولا جواب بهتر اینه که سعی کنید قسمت هایی از کد که باعث ایجاد این دسته از panic ها میشن رو شناسایی کنید و مشکل رو از ریشه حل کنید.


panic: runtime error: invalid memory address or nil pointer dereference

شرکت Uber اخیر مقاله ای منتشر کرده که در این مورد توضیحات خوبی رو ارائه داده، دوست داشتید مطالعه کنید.

NilAway: Practical Nil Panic Detection for Go

یه پروژه open-source هم در همین رابطه منشتر کرده که من روی یکی از پروژه هام اجراش کردم و کلی statement پیدا کرد که این مشکل رو داره احتمالا.

خودش هشدار داده که پروژه در دست توسعه ست و ممکنه خطای false positive داشته باشید، ولی بد نیست به پروسه ci اضافه بشه یا حداقل لوکال چک کنید.

نصب و اجراشم ساده ست.


go install go.uber.org/nilaway/cmd/nilaway@latest
nilaway ./...



@gocasts

#golang
👍40🔥6
اگه با conventional commit آشنایی ندارید پیشنهاد میکنم لینک زیر رو باز کنید.

https://www.conventionalcommits.org/en/v1.0.0-beta.2

به شما کمک میکنه commit message هایی که میزنید دارای ساختار مشخص باشه و همچنین بتونید از طریق این ساختار بصورت خودکار changelog بسازید و versioning رو خودکار انجام بدید و لازم نباشه هر بار دستی tag مربوط به version رو بزنید.

تو تیمسازی conventional commit رو به عنوان یه github action اضافه کردیم که ساختار Pull request noscriptها بهتر بشه.

این issueی هست که ثبت کردیم
https://github.com/ormushq/ormus/issues/7

و اینم pull requestی که بچه های تیمسازی زحمت کشیدن زدند.
https://github.com/ormushq/ormus/pull/10/files


تو تیمسازی قراره ان شاءالله اکثر کارهارو بچه ها انجام بدن و من بشینم بیرون گود و لذت ببرم. 🔥

ماشاءالله محمدحسین جان 🚀
https://www.linkedin.com/in/hossein-hajiha-75375a206/

@gocasts

#تیمسازی
👍19🔥21
Go Casts 🚀
توضیحات معرفی دوره سلام دوستان، پیشنهاد می‌کنم این ویدیو رو در مورد جزئیات دوره مشاهده کنید. لینک جزئیات سرفصل‌های دوره آموزشی و ثبت‌نام در دوره https://gocasts.ir/gocasts-bootcamp-140110?utm_source=telegram&utm_medium=message @gocasts
امروز تو جلسه تیمسازی با بچه های بوتکمپ در مورد نحوه ساخت writekey صحبت کردیم و نیازمندی هایی که داریم.
شما writekey رو یه unique id در نظر بگیرید.
سرویس segment که نمونه خارجی معروف و محبوب cdp هست یه پکیجی رو توسعه داده به اسم ksuid برای همین کار.
https://github.com/segmentio/ksuid

قبلا در مورد مشکلات uuid صحبت کردیم، که بخاطر مرتب نبودنشون خیلی مناسب نیستن برای استفاده کردن به عنوان id و primary key اینجا میتونید بخونید در موردشون
https://news.1rj.ru/str/gocasts/132
https://news.1rj.ru/str/gocasts/212

دیدن این ویدیو هم خالی از لطف نیست
How Shopify’s engineering improved database writes by 50% with ULID
https://www.youtube.com/watch?v=f53-Iw_5ucA

اینم یه پکیج گولنگی هست که میتونید استفاده کنید
https://github.com/oklog/ulid

اینم یه تصویری که راه حل های جایگزین رو نشون داده
https://miro.medium.com/v2/resize:fit:720/format:webp/1*Uk_poUK8O-l0ctfgecueFQ.png

@gocasts

#تیمسازی
🔥12👍3
پرسش و پاسخ
یه پروژه پرچالش مثل شبکه اجتماعی رو چطور شروع کنیم؟
دیتابیسمون چی باشه؟

@gocasts

#qa
🔥115👍5
سلام دوستان
یه سری توضیحات در مورد تیمسازی میدم خدمتتون.
توجه کنید که جلسات تیمسازی هم ضبط میشه، یعنی الان به جز ۲۷ جلسه آموزشی، ۱۰ جلسه تیمسازی یک و ۲ جلسه تیمسازی دو هم در اسپات پلیر در دسترس هست.
تو این جلسات در مورد چالش های فنی و غیر فنی پروژه های تیمسازی صحبت میکنیم.

تو تیمسازی بچه ها کد میزنن و بصورت جدی روی پروژه های واقعی کار میکنن که میتونه هم تجربه کاری شون رو بهتر کنه هم کلی چالش فنی و غیرفنی رو باهاش مواجه میشن.

جلسات تیمسازی هفتگی هست و اونجا به ریویو کد و تقسیم بندی کارها و انتقال دانش میپردازیم و همچنین خارج از جلسه تیمسازی کد بچه ها ریویو میشه.


اینم فیدبک عرفان جان با بیش از ۴ سال سابقه برنامه نویسی نسبت به دوره

لینکدین عرفان جان
https://www.linkedin.com/in/erfan-taghinia-547284163

لینک توضیحات ویدیویی دوره
https://news.1rj.ru/str/gocasts/297

لینک سرفصل های دوره
https://gocasts.ir/downloads/GoCasts-Bootcamp-Syllabus-v1.0.0-14020314.pdf

لینک جزئیات و خرید دوره ویدیویی
https://gocasts.ir/gocasts-bootcamp-140110


@gocasts
👍10🔥62
خیلی اوقات ناچار هستیم از راه های نامتمرکز برای ساخت شناسه استفاده کنیم. این مقاله شما رو با راهکارهای مختلف تولید شناسه بصورت نامتمرکز آشنا میکنه

7 Famous Approaches to Generate Distributed ID with Comparison Table
https://medium.com/bytebytego-system-design-alliance/7-famous-approaches-to-generate-distributed-id-with-comparison-table-af89afe4601f

@gocasts
👍8
Go Casts 🚀
خیلی اوقات ناچار هستیم از راه های نامتمرکز برای ساخت شناسه استفاده کنیم. این مقاله شما رو با راهکارهای مختلف تولید شناسه بصورت نامتمرکز آشنا میکنه 7 Famous Approaches to Generate Distributed ID with Comparison Table https://medium.com/bytebytego-system-design…
بسی لذت بردم از خوندن این مقاله

درس بزرگش استفاده از راه حال های خیلی ساده حتی برای scale خیلی بزرگی مثل pinterest هست

یکی از نکات جالب این مقاله استفاده از دیتابیس های master بود و از slave فقط برای بکاپ استفاده میکردن، همه read و writeهای production روی master هست و دیگه مشکلی بابت lagهای slave که میتونه خیلی bug-prone باشه ندارن.

جالبه که در انتخاب دیتابیس maturity دیتابیس رو اولویت قرار دادن و دیتابیس MySQL رو به MongoDB و Cassandra ترجیح دادن با اینکه راه حل های مدرن تر قابلیت auto-scaling دارن. حقیقتا به شخصه هم MySQL رو دوست دارم، هم ساده ست و هم mature و هم کلی ابزار خوب مثل ProxySQL براش هست.
https://proxysql.com

برای shard کردن روی هر سرور EC2 یه سرویس MySQL بالا آوردن و هر سرویس MySQL در حالت master-master روی هاست بکاپ replicate میشه، این مستر بکاپ فقط برای وقتی هست که مستر اصلی fail بشه. روی پروداکشن همه read و writeها توسط master اصلی انجام میشه و این کار رو pinterest خیلی توصیه میکنه چون ساده میشه همه چیز.

هر نسخه از سرویس MySQL میتونه شامل چندین database باشه که اسم دیتابیس ها unique هست در سرتاسر ناوگان (کلاسترهای) MySQL. یه تصمیم دیگه ای هم که گرفتن اینه که وقتی داده ای در یک shard ذخیره میشه دیگه هیچ وقت به shard دیگه ای منتقل نمیشه. ولی برای افزایش ظرفیت یک shard میشه کل اون shard رو به یک ماشین دیگه منتقل کرد.

دغدغه دیگه شون هم طبیعتا ساخت uuid بوده
نحوه ساختن UUIDشون خیلی جالبه، اینطوریه که سه بخش داره، بخش اول میشه شناسه shard بخش دوم میشه شناسه جدول، مثلا جدول pin ها شناسه ش ۱ هست و بخش سوم هم میشه شناسه عددی id رکورد در جدول pins که یه auto-increment integer هست.

یکی از کارهای جالب دیگه شون اینه که جدول دیتابیس شون کلا یه فیلد blob داره که یه فیلد TEXT هست که داده های serializeشده json رو ذخیره میکنن. علتش هم اینه که میگن اضافه کردن ستون به دیتابیس توسط دستور alter table خیلی هزینه بر هست ولی اضافه کردن فیلد به json نه. سمت اپلیکیشن ها هم سعی میکنن برای فیلدهای جدید تعریف شده default value در نظر بگیرن که اگه داده قدیمی jsonی اون فیلدهارو نداشت مشکلی پیش نیاد.

برای edit کردن یک رکورد دیتابیس هم از select for update استفاده میکنن که read lock بگیرن روی اون record دیتابیس.
http://dev.mysql.com/doc/refman/5.7/en/innodb-locking-reads.html

> BEGIN
> SELECT blob FROM db03429.pins WHERE local_id=7075733 FOR UPDATE
[Modify the json blob]
> UPDATE db03429.pins SET blob=’<modified blob>’ WHERE local_id=7075733
> COMMIT


Sharding Pinterest: How we scaled our MySQL fleet
https://medium.com/pinterest-engineering/sharding-pinterest-how-we-scaled-our-mysql-fleet-3f341e96ca6f

@gocasts
🔥28👍92
توصیه ای خیلی جدی به دوستان تازه کارم ❤️❤️

@gocasts
👍7317🔥5
نمونه فیلم دوره

فیلمی که اینجا preview شده توسط تلگرام از تیمسازی هست نه دوره، لینک های نمونه دوره رو که پایین تر گذاشتم باز کنید

برخی از دوستان خواسته بودن که نمونه فیلم هایی از دوره ارائه بدم.
ارائه فیلم نمونه از یه دوره ۲۷ جلسه ای خیلی کار سختیه
اما من سعی کردم چند نمونه بذارم.
سعی کردم خوب و بد رو بذارم چون قصد ندارم کسی رو با نمایش دادن فقط قسمت های صرفا خوب به اشتباه بندازم.


نمونه فیلم های دوره

مثلا نمونه اول از نظر کیفیت نور تصویر خودم خوب نیست (فکر کنم از ۲۷ جلسه ۲ جلسه ش این شکلیه)
https://gocasts.ir/downloads/1_gameapp_mysql_docker_sample.mkv

از سه جلسه solution design سعی کردم بخش هاییش رو بذارم
https://gocasts.ir/downloads/2_gameapp_solution_design_player_selection_sample.mkv

نمونه ای از پیاده سازی روی کد رو گذاشتم
https://gocasts.ir/downloads/2_gameapp_grpc_2_sample.mkv

نمونه ای هم از آموزش های مقدماتی (اینجا pointer رو توضیح دادم که جلوترش کد هم زدم ولی تو فیلم نیست)
https://gocasts.ir/downloads/session_3_6_pointer_1_sample.mkv


نمونه فیلم های تیمسازی
دقت کنید تیمسازی الان در حال انجامه و ربطی به دوره نداره و خیلی از جلساتش رو تو ماشین یا هرجا که بتونم برگزار میکنم که بچه ها بتونن کارشون رو پیش ببرن..

یه جلسه solution design داشتیم در تیمسازی این بخش هاییشه
https://gocasts.ir/downloads/teamsazi_session_5_14020822_sample.mkv

ریویوی کد رو معمولا داریم تو جلسات تیمسازی
https://gocasts.ir/downloads/teamsazi_session_10_14020912_sample.mkv

اینم باز ریویو کد در تیمسازی
https://gocasts.ir/downloads/teamsazi_session_11_14020919_sample.mp4

لینک جزییات و خرید دوره
https://gocasts.ir/gocasts-bootcamp-140110


@gocasts
👍167🔥2
سلام به همگی
توضیحاتی در مورد دوره و تیمسازی و برخی سوالات

این voice رو اگه تمایل داشتید گوش بدید، سعی کردم نکاتی زیادی رو پوشش بدم، از طولانی شدن voice عذرخواهی میکنم.

لینک جزییات و خرید دوره
https://gocasts.ir/gocasts-bootcamp-140110

@gocasts
👍125
Go Casts 🚀
Voice message
ضمانت بازگشت وجه تا ۳۰ روز پس از خرید

از زمان فروش دوره ویدیویی پس از پایان بوتکمپ تا به امروز الحمدلله فقط یک نفر اعلام نارضایتی کرده، (احتمالا شاید ناراضی ها بیشتر از یک نفر باشن اما چیزی نگفتن، به هر دلیلی...)

همانطور که در voice هم عرض کردم، این پیامیه که در دیسکورد چند ماه پیش گذاشتم برای شرکت کنندگان در دوره.

بارها هم گفتم که دوره بنده هم مثل هر دوره دیگه ای کلی نقص داره در کل
در نهایت هم اگه دوره رو خریدی و دیدی و از دوره و تیمسازی راضی نبودی من هزینه خرید رو پس میدم.

خدای نکرده هیچ وقت دوست نداشتم و ندارم پول چیزی رو بگیرم که مخاطب ازش ناراضی باشه.

اینارو نمیگم که الکی ترغیب بشی به خریدن دوره، ولی اگه فکر میکنی دوره و تیمسازی برات مفیده نگران کیفیتش نباش، نه اینکه دوره و تیمسازی بی نقص باشه، نه، ولی در صورت نارضایتی تا ۳۰ روز پس از خرید دوره، هزینه تون پس داده میشه

بازم دمتون گرم ❤️

لینک جزییات و خرید دوره
https://gocasts.ir/gocasts-bootcamp-140110


@gocasts
29👍5
تراکنش های distributed چطوری کار میکنن؟

How Distributed Transactions Work in TiDB
https://www.pingcap.com/blog/distributed-transactions-tidb/

کلا که به قول martin fowler بهتر don't distribute your object اولین قانونی باشه که در نظر میگیری
First Law of Distributed Object Design: "don't distribute your objects".
https://martinfowler.com/articles/distributed-objects-microservices.html

اما اگه لازم شد بهتره سراغ راه حل هایی بری که موضوع رو برات حل میکنن، نه اینکه خودت بخوای پیاده سازی کنی چون چالش زیاد داره

استفاده از TiDB رو در پروداکشن توصیه نمیکنم اما برای تجربه و بررسی بد نیست تست بشه
https://github.com/pingcap/tidb

یه kv storage هم داره که پایه و اساس همین TiDB هست که اونم خوبه بررسی بشه
https://github.com/tikv/tikv
اینم معماریشه
https://docs.pingcap.com/tidb/stable/tikv-overview

@gocasts

#database
#distributed_transaction
👍14
سلام به همه دوستان
اگه دوست داشتید به کانال boost بدید که بشه از یه سری قابلیت های تلگرام برای کانال استفاده کرد.

دمتون گرم ❤️

https://news.1rj.ru/str/gocasts?boost
Go Casts 🚀
Ansible2.pdf
Kubernetes pocket guide.pdf
12.2 MB
سلام دوستان
جناب مهندس افشاری، دفترچه kubernetes رو بروزرسانی کرده و یه نسخه به انگلیسی ارائه داده که خیلی کار جالبی هست، فکر میکنم براتون مفید هست اگه خواستید بررسی کنید.

اینم لینک کانال ایشون که میتونید کارهای بیشتری رو ببینید
@dev_cheatsheet

Kubernetes pocket guide
Language: English

The Kubernetes Pocket Guide is a small and easy-to-use document that helps you understand Kubernetes better. Inside this booklet, we have taken great care to gather and explain all the important ideas and knowledge about Kubernetes in a simple way

#kubernetes

@gocasts
👍123🔥3
سلام به همه دوستان

اگه فکر میکنید برنامه نویس ارشد مهندس نرم افزار و بکند هستید و به اندازه کافی تجربه دارید با گولنگ و دیتابیس های relational لطفا رزومه تون رو برای من ارسال کنید. تیم SnappKitchen به دنبال نیروی ارشد مهندس نرم افزار هستند.


با دارا جان هم میتونید در ارتباط باشید
Dara Nasibi
https://www.linkedin.com/in/dara-nasibi-510887139/


@gocasts
7
این مقاله عالی و کوچیک و جدید یه نکته خیلی مهم و آموزنده داره:
Scale Up vs Scale Out

https://talk.gocasts.ir/t/scale-up-vs-scale-out/473?u=hossein

@gocasts
13👍8
مصاحبه mock طراحی سیستم، با افراد واقعی و تجربه های واقعی بصورت ناشناس به gocasts اضافه شد 🚀

در لحظه ۴ مصاحبه mock با موضوع طراحی سیستم انجام شده و کم کم ان شاءالله مصاحبه های بیشتری با افراد دیگه اضافه میشه

هدف ما اینه پکیج gocasts شامل دوره آموزشی، تیمسازی (برای تمرین کد زدن روی پروژه های واقعی)، مصاحبه های mock ان شاءالله یه پکیجی باشه که به شما کمک کنه زودتر و بهتر به هدفتون برسید.

توضیحات مفصل صوتی در مورد دوره و تیمسازی
https://news.1rj.ru/str/gocasts/369

نمونه فیلم های دوره
https://news.1rj.ru/str/gocasts/367

ضمانت بازگشت وجه
https://news.1rj.ru/str/gocasts/370

پرسش و پاسخ
https://news.1rj.ru/str/gocasts/337


لینک جزییات و خرید دوره
https://gocasts.ir/gocasts-bootcamp-140110

@gocasts
23👍9
This media is not supported in your browser
VIEW IN TELEGRAM
ولادت حضرت علی علیه السلام و روز پدر مبارک

اوزان غزل که مست مستم کرده
یک شاعر خوب و چیره دستم کرده

گویم همه جا خدا پرستم اما
ایوان نجف علی پرستم کرده


مخلص همه، یا علی 🌹

@gocasts
32👍3
Virtual Machine vs Container

پیشنهاد می کنم این دو ویدیو کوتاه که خیلی خوب و ساده تفاوت ماشین مجازی و کانتینر رو توضیح میدن، ببینید

https://youtu.be/cjXI-yxqGTI?si=RA3WTvIUCTZC55Qi

https://youtu.be/eyNBf1sqdBQ?si=dJD-F_mBjrRD4lF7

احتمالا با دیدن این دو ویدیو متوجه بشید چرا VM ها رو hardware level virtualization میگن و Container ها رو OS level virtualization

سوالاتی که برای درک عمیق تر موضوع میشه بیشتر در موردشون تحقیق کرد:
- چطوری hypervisor منابع سخت افزاری رو بین vmها مدیریت میکنه
https://www.xenserver.com/what-is-a-hypervisor

https://www.youtube.com/watch?v=p-8GFj3BCQw

- چطوری Linux kernel با استفاده از قابلیت های namespaces و cgroups اجازه میده کانتینر ها process isolation داشته باشن
https://blog.kubesimplify.com/understanding-how-containers-work-behind-the-scenes

https://www.nginx.com/blog/what-are-namespaces-cgroups-how-do-they-work/

https://terenceli.github.io/%E6%8A%80%E6%9C%AF/2020/01/05/cgroup-internlas

@gocasts
14👍5