Go Casts 🚀
سلام به همه دوستان احتمالا دیگه کسی نباشه که به نحوی با نوشتن به زبان فارسی سر و کله بزنه و با فونت بینظیر وزیر آشنا نباشه. سال هاست که از این فونت استفاده میکنم و بعد از اضافه شدنش به فونت های گوگل، تقریبا هر جا که بخوام فارسی بنویسم از فونت وزیر استفاده…
خدا رحمتش کنه، ان شاءالله روحش قرین رحمت الهی باشه، صابر کاری کرد که در زندگی دیجیتال روزمره همه ما تاثیر گذاشت و تقریبا اپلیکیشنی نیست که وقتی میخوام فارسی تایپ کنم داخلش دنبال فونت وزیر نگردم. صابر همیشه تو یاد ما میمونه تا ابد 🖤 💔
https://www.linkedin.com/feed/update/urn:li:share:7131581329975984129/
https://www.linkedin.com/feed/update/urn:li:share:7131581329975984129/
Linkedin
Sign Up | LinkedIn
500 million+ members | Manage your professional identity. Build and engage with your professional network. Access knowledge, insights and opportunities.
❤52
#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 باید انجام بشه، نمیدونم..
شما ایده ای ندارید؟
سلام به همه دوستان، مخصوصا دوستان خفن 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👍3❤1
برنامه هایی که با گولنگ نوشته میشن یکی از شایع ترین خطاهایی که در runtime و روی production باهاش مواجه میشن خطای panic از جنس nil pointer هست. که میتونه منجر به از کار افتادن برنامه هم بشه، هر چند راه هایی وجود داره که شما بتونید panic رو recover کنید، اما اصولا جواب بهتر اینه که سعی کنید قسمت هایی از کد که باعث ایجاد این دسته از panic ها میشن رو شناسایی کنید و مشکل رو از ریشه حل کنید.
شرکت Uber اخیر مقاله ای منتشر کرده که در این مورد توضیحات خوبی رو ارائه داده، دوست داشتید مطالعه کنید.
NilAway: Practical Nil Panic Detection for Go
یه پروژه open-source هم در همین رابطه منشتر کرده که من روی یکی از پروژه هام اجراش کردم و کلی statement پیدا کرد که این مشکل رو داره احتمالا.
خودش هشدار داده که پروژه در دست توسعه ست و ممکنه خطای false positive داشته باشید، ولی بد نیست به پروسه ci اضافه بشه یا حداقل لوکال چک کنید.
نصب و اجراشم ساده ست.
@gocasts
#golang
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
#تیمسازی
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🔥2❤1
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
#تیمسازی
شما 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
#تیمسازی
GitHub
GitHub - segmentio/ksuid: K-Sortable Globally Unique IDs
K-Sortable Globally Unique IDs. Contribute to segmentio/ksuid development by creating an account on GitHub.
🔥12👍3
سلام دوستان
یه سری توضیحات در مورد تیمسازی میدم خدمتتون.
توجه کنید که جلسات تیمسازی هم ضبط میشه، یعنی الان به جز ۲۷ جلسه آموزشی، ۱۰ جلسه تیمسازی یک و ۲ جلسه تیمسازی دو هم در اسپات پلیر در دسترس هست.
تو این جلسات در مورد چالش های فنی و غیر فنی پروژه های تیمسازی صحبت میکنیم.
تو تیمسازی بچه ها کد میزنن و بصورت جدی روی پروژه های واقعی کار میکنن که میتونه هم تجربه کاری شون رو بهتر کنه هم کلی چالش فنی و غیرفنی رو باهاش مواجه میشن.
جلسات تیمسازی هفتگی هست و اونجا به ریویو کد و تقسیم بندی کارها و انتقال دانش میپردازیم و همچنین خارج از جلسه تیمسازی کد بچه ها ریویو میشه.
اینم فیدبک عرفان جان با بیش از ۴ سال سابقه برنامه نویسی نسبت به دوره
لینکدین عرفان جان
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
یه سری توضیحات در مورد تیمسازی میدم خدمتتون.
توجه کنید که جلسات تیمسازی هم ضبط میشه، یعنی الان به جز ۲۷ جلسه آموزشی، ۱۰ جلسه تیمسازی یک و ۲ جلسه تیمسازی دو هم در اسپات پلیر در دسترس هست.
تو این جلسات در مورد چالش های فنی و غیر فنی پروژه های تیمسازی صحبت میکنیم.
تو تیمسازی بچه ها کد میزنن و بصورت جدی روی پروژه های واقعی کار میکنن که میتونه هم تجربه کاری شون رو بهتر کنه هم کلی چالش فنی و غیرفنی رو باهاش مواجه میشن.
جلسات تیمسازی هفتگی هست و اونجا به ریویو کد و تقسیم بندی کارها و انتقال دانش میپردازیم و همچنین خارج از جلسه تیمسازی کد بچه ها ریویو میشه.
اینم فیدبک عرفان جان با بیش از ۴ سال سابقه برنامه نویسی نسبت به دوره
لینکدین عرفان جان
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🔥6❤2
خیلی اوقات ناچار هستیم از راه های نامتمرکز برای ساخت شناسه استفاده کنیم. این مقاله شما رو با راهکارهای مختلف تولید شناسه بصورت نامتمرکز آشنا میکنه
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
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
Medium
7 Famous Approaches to Generate Distributed ID with Comparison Table
Nowadays, many small and large systems require unique global identifiers; it is an essential task in distributed computing with growing…
👍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
Sharding Pinterest: How we scaled our MySQL fleet
https://medium.com/pinterest-engineering/sharding-pinterest-how-we-scaled-our-mysql-fleet-3f341e96ca6f
@gocasts
درس بزرگش استفاده از راه حال های خیلی ساده حتی برای 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
ProxySQL
Scale 100K+ connections
across thousands of servers
In the dynamic landscape of modern database management, optimizing performance and efficiently handling database traffic are paramount concerns for businesses of all sizes. Enter ProxySQL, a
across thousands of servers
In the dynamic landscape of modern database management, optimizing performance and efficiently handling database traffic are paramount concerns for businesses of all sizes. Enter ProxySQL, a
🔥28👍9❤2
نمونه فیلم دوره
فیلمی که اینجا 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
فیلمی که اینجا 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
👍16❤7🔥2
سلام به همگی
توضیحاتی در مورد دوره و تیمسازی و برخی سوالات
این voice رو اگه تمایل داشتید گوش بدید، سعی کردم نکاتی زیادی رو پوشش بدم، از طولانی شدن voice عذرخواهی میکنم.
لینک جزییات و خرید دوره
https://gocasts.ir/gocasts-bootcamp-140110
@gocasts
توضیحاتی در مورد دوره و تیمسازی و برخی سوالات
این voice رو اگه تمایل داشتید گوش بدید، سعی کردم نکاتی زیادی رو پوشش بدم، از طولانی شدن voice عذرخواهی میکنم.
لینک جزییات و خرید دوره
https://gocasts.ir/gocasts-bootcamp-140110
@gocasts
👍12❤5
Go Casts 🚀
Voice message
ضمانت بازگشت وجه تا ۳۰ روز پس از خرید
از زمان فروش دوره ویدیویی پس از پایان بوتکمپ تا به امروز الحمدلله فقط یک نفر اعلام نارضایتی کرده، (احتمالا شاید ناراضی ها بیشتر از یک نفر باشن اما چیزی نگفتن، به هر دلیلی...)
همانطور که در voice هم عرض کردم، این پیامیه که در دیسکورد چند ماه پیش گذاشتم برای شرکت کنندگان در دوره.
بارها هم گفتم که دوره بنده هم مثل هر دوره دیگه ای کلی نقص داره در کل
در نهایت هم اگه دوره رو خریدی و دیدی و از دوره و تیمسازی راضی نبودی من هزینه خرید رو پس میدم.
خدای نکرده هیچ وقت دوست نداشتم و ندارم پول چیزی رو بگیرم که مخاطب ازش ناراضی باشه.
اینارو نمیگم که الکی ترغیب بشی به خریدن دوره، ولی اگه فکر میکنی دوره و تیمسازی برات مفیده نگران کیفیتش نباش، نه اینکه دوره و تیمسازی بی نقص باشه، نه، ولی در صورت نارضایتی تا ۳۰ روز پس از خرید دوره، هزینه تون پس داده میشه
بازم دمتون گرم ❤️
لینک جزییات و خرید دوره
https://gocasts.ir/gocasts-bootcamp-140110
@gocasts
از زمان فروش دوره ویدیویی پس از پایان بوتکمپ تا به امروز الحمدلله فقط یک نفر اعلام نارضایتی کرده، (احتمالا شاید ناراضی ها بیشتر از یک نفر باشن اما چیزی نگفتن، به هر دلیلی...)
همانطور که در 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
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
اگه دوست داشتید به کانال boost بدید که بشه از یه سری قابلیت های تلگرام برای کانال استفاده کرد.
دمتون گرم ❤️
https://news.1rj.ru/str/gocasts?boost
Telegram
Go Casts 🚀
از این کانال حمایت کنید تا بتواند به قابلیتهای اضافی دسترسی پیدا کند.
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
جناب مهندس افشاری، دفترچه 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
👍12❤3🔥3
سلام به همه دوستان
اگه فکر میکنید برنامه نویس ارشد مهندس نرم افزار و بکند هستید و به اندازه کافی تجربه دارید با گولنگ و دیتابیس های relational لطفا رزومه تون رو برای من ارسال کنید. تیم SnappKitchen به دنبال نیروی ارشد مهندس نرم افزار هستند.
با دارا جان هم میتونید در ارتباط باشید
Dara Nasibi
https://www.linkedin.com/in/dara-nasibi-510887139/
@gocasts
اگه فکر میکنید برنامه نویس ارشد مهندس نرم افزار و بکند هستید و به اندازه کافی تجربه دارید با گولنگ و دیتابیس های 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
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
در لحظه ۴ مصاحبه 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
اوزان غزل که مست مستم کرده
یک شاعر خوب و چیره دستم کرده
گویم همه جا خدا پرستم اما
ایوان نجف علی پرستم کرده
مخلص همه، یا علی 🌹
@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
پیشنهاد می کنم این دو ویدیو کوتاه که خیلی خوب و ساده تفاوت ماشین مجازی و کانتینر رو توضیح میدن، ببینید
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
YouTube
Containers vs VMs: What's the difference?
Learn more about Containers: http://ibm.biz/guide-to-containers
Learn more about VMs: http://ibm.biz/virtual-machines-guide
What are virtual machines and containers, and how do they fit into our modern cloud-native way of building and architecting applications?…
Learn more about VMs: http://ibm.biz/virtual-machines-guide
What are virtual machines and containers, and how do they fit into our modern cloud-native way of building and architecting applications?…
❤14👍5