https://github.com/codehaks/FileManagerDemo
پروژه ی نمونه ی کار با فایل و آپلود و دانلود در ASP MVC Core 2.0
پروژه ی نمونه ی کار با فایل و آپلود و دانلود در ASP MVC Core 2.0
GitHub
codehaks/FileManagerDemo
FileManagerDemo - A simple file manager in ASP MVC Core 2.0
آیا Stored Procedure از LINQ سریعتر است ؟
اخیرا در یک پروژه ی قدیمی از من خواسته شد سرعت تولید گزارشات را بالا ببرم.اجرای آن بیش از 5 دقیقه طول می کشید. مشکل اصلی این بود که بخش اصلی گزارش ها با SP برنامه نویسی شده بود . بعد از بررسی دقیق سورسها ساده ترین راهی که به نظرم رسید بازنویسی آن با LINQ درون #C بود. خروجی کار نتیجه ی جالب توجهی داشت. حالا گزارش در کمتر از 5 ثانیه تولید میشد. این یعنی سرعت کار بیش از 300 برابر شده بود.
جواب کوتاه سوال "بله" است. SQL دارای مکانیزم هایی است که به SP امکان میدهد همیشه چند برابر از LINQ یا Query های خارجی سریعتر عمل کند. اما سرعت همیشه ملاک برتری یک روش نیست. نوشتن SP نیاز به تخصص در T-SQL دارد. مهارتی میطلبد که خیلی از برنامه نویسان وب ندارند. خیلی راحت میتوانید یک SP بد بنویسید که از صد LINQ کندتر کار کند.
مسئله ی دیگر بروز رسانی و تغییر SP ها است. مدیریت کردن SP ها در درازمدت بسیار سخت تر از LINQ است. در بسیاری موارد زمان اجرای Query ها کسری از ثانیه است در نتیجه استفاده از SP چیز زیادی به سرعت سیستم اضافه نمیکند.
تنها زمانی باید به استفاده از SP فکر کرد که سرعت جمع آوری اطلاعات یک تنگنا یا اصطلاحا Buttleneck باشد.
اخیرا در یک پروژه ی قدیمی از من خواسته شد سرعت تولید گزارشات را بالا ببرم.اجرای آن بیش از 5 دقیقه طول می کشید. مشکل اصلی این بود که بخش اصلی گزارش ها با SP برنامه نویسی شده بود . بعد از بررسی دقیق سورسها ساده ترین راهی که به نظرم رسید بازنویسی آن با LINQ درون #C بود. خروجی کار نتیجه ی جالب توجهی داشت. حالا گزارش در کمتر از 5 ثانیه تولید میشد. این یعنی سرعت کار بیش از 300 برابر شده بود.
جواب کوتاه سوال "بله" است. SQL دارای مکانیزم هایی است که به SP امکان میدهد همیشه چند برابر از LINQ یا Query های خارجی سریعتر عمل کند. اما سرعت همیشه ملاک برتری یک روش نیست. نوشتن SP نیاز به تخصص در T-SQL دارد. مهارتی میطلبد که خیلی از برنامه نویسان وب ندارند. خیلی راحت میتوانید یک SP بد بنویسید که از صد LINQ کندتر کار کند.
مسئله ی دیگر بروز رسانی و تغییر SP ها است. مدیریت کردن SP ها در درازمدت بسیار سخت تر از LINQ است. در بسیاری موارد زمان اجرای Query ها کسری از ثانیه است در نتیجه استفاده از SP چیز زیادی به سرعت سیستم اضافه نمیکند.
تنها زمانی باید به استفاده از SP فکر کرد که سرعت جمع آوری اطلاعات یک تنگنا یا اصطلاحا Buttleneck باشد.
افزونه تبدیل تاریخ میلادی به شمسی با کمک Extension Method ها در #C :
https://www.nuget.org/packages/Codehaks.PersianDateTime
https://www.nuget.org/packages/Codehaks.PersianDateTime
کدهک
افزونه تبدیل تاریخ میلادی به شمسی با کمک Extension Method ها در #C : https://www.nuget.org/packages/Codehaks.PersianDateTime
برای استفاده از این افزونه ها کافیه پکیج Codehaks.PersianDateTime رو از طریق nuget نصب کنید. بعد هرجا نیاز به تبدیل تاریخ میلادی به شمسی داشتید ازش استفاده کنید :
DateTime.Now.ToPersianDate()
DateTime.Now.ToPersianDateTime()
DateTime.Now.ToFullPersianDate()
DateTime.Now.ToFullPersianDateTime()
این افزونه در ویو ها و کلاسهای سی شارپ قابل فراخوانیه و کار تبدیل تاریخ میلادی به شمسی رو راحت میکنه، ضمن اینکه خروجی از نوع string هست. سورس پروژه در آدرس زیر قابل مشاهده است :
https://github.com/codehaks/Codehaks.PersianDateTime
DateTime.Now.ToPersianDate()
DateTime.Now.ToPersianDateTime()
DateTime.Now.ToFullPersianDate()
DateTime.Now.ToFullPersianDateTime()
این افزونه در ویو ها و کلاسهای سی شارپ قابل فراخوانیه و کار تبدیل تاریخ میلادی به شمسی رو راحت میکنه، ضمن اینکه خروجی از نوع string هست. سورس پروژه در آدرس زیر قابل مشاهده است :
https://github.com/codehaks/Codehaks.PersianDateTime
GitHub
codehaks/Codehaks.PersianDateTime
Codehaks.PersianDateTime - Extention Methods to convert DateTime to persian
هنر بریدن ، چیدن و کوتاه کردن
وقتی تیمور لنگ شروع به کشور گشایی کرد هدفش فتح دنیا نبود، او فقط به قلعه ی بعدی فکر میکرد. عجیب آنکه سر آخر تا پشت دیوار چین پیش رفت . تنها چیزی که او را از ادامه ی پیروزی باز داشت مرگش بود.
مدیریت پروژه فرق زیادی با کشور گشایی ندارد. وقتی پروژه ای بیش از حد بزرگ باشد انجامش غیر ممکن میشود. بسیاری از کافرما ها اصرار دارند یک پروژه ی کامل تحویل بگیرند. آنها لیستی به شما میدهند و انتظار دارند با نسخه ی کامل رویایشان برگردید . در حالی که هیچکدام از شرکتهای تولید کننده ی نرم افزار از چنین روشی استفاده نمی کنند. آنها از سر و ته یک رویا میزنند تا پروژه در قالب زمان و پول جا شود.
سایت محصولات یکبار تولید نیست. ساده ترین سایت هم نیاز به بروز رسانی دارد. حتی اگر تکنولوژی تغییر نکند ، آمار بازدید زیاد نشود یا حادثه برای سرور رخ ندهد، خود کار فرما ایده های جدیدی خواهد داشت.
مهم نیست انتظار کارفرمای شما چیست. کار اول شما این است که از آن کم کنید. کارفرماها معمولا رویاهای بزرگی در ابعاد آمازون ، فیس بوک و یوتیوب دارند. به آنها یاد آوری کنید هدف اول باید فتح قلعه ی بعدی باشد. اینکه آیا در نهایت به دیوار چین میرسید یا نه به آینده بستگی دارد.
وقتی تیمور لنگ شروع به کشور گشایی کرد هدفش فتح دنیا نبود، او فقط به قلعه ی بعدی فکر میکرد. عجیب آنکه سر آخر تا پشت دیوار چین پیش رفت . تنها چیزی که او را از ادامه ی پیروزی باز داشت مرگش بود.
مدیریت پروژه فرق زیادی با کشور گشایی ندارد. وقتی پروژه ای بیش از حد بزرگ باشد انجامش غیر ممکن میشود. بسیاری از کافرما ها اصرار دارند یک پروژه ی کامل تحویل بگیرند. آنها لیستی به شما میدهند و انتظار دارند با نسخه ی کامل رویایشان برگردید . در حالی که هیچکدام از شرکتهای تولید کننده ی نرم افزار از چنین روشی استفاده نمی کنند. آنها از سر و ته یک رویا میزنند تا پروژه در قالب زمان و پول جا شود.
سایت محصولات یکبار تولید نیست. ساده ترین سایت هم نیاز به بروز رسانی دارد. حتی اگر تکنولوژی تغییر نکند ، آمار بازدید زیاد نشود یا حادثه برای سرور رخ ندهد، خود کار فرما ایده های جدیدی خواهد داشت.
مهم نیست انتظار کارفرمای شما چیست. کار اول شما این است که از آن کم کنید. کارفرماها معمولا رویاهای بزرگی در ابعاد آمازون ، فیس بوک و یوتیوب دارند. به آنها یاد آوری کنید هدف اول باید فتح قلعه ی بعدی باشد. اینکه آیا در نهایت به دیوار چین میرسید یا نه به آینده بستگی دارد.
فریم ورک Blazor
فریم ورک Blazor یک پروژه ی آزمایشی است که به تازگی به ASP اضافه شده و امکان استفاده از Web Assembly در دات نت را فراهم میکند. تمام مرورگرهای جدید از Web Assembly پشتیبانی می کنند. در نتیجه می توانید برنامه ی کلاینتی بنویسید که مانند جاوا اسکریپت به رویدادهای موس و کیبورد واکنش میدهد در کلاینت اجرا میشود.
نسخه ی آزمایشی این فریم ورک قابلیت دیباگ و Live Reloading دارد همچنین به شما امکان میدهد کامپوننت هایی بنویسید که به صورت تو در تو به هم وابستگی دارند. ابزاری مانند Dependency Injection و Server-Side Rendering هم در آن گنجاده خواهد شد.
یکی از جالبترین قابلیت های این فریم ورک امکان اجرای دستورات جاوا اسکریپت از درون #C است. حجم فریم ورک در حدود 400 کیلوبایت است که به همراه اولین بارگذاری صفحه دانلود میشود. در صورت عدم پشتیبانی مرورگر از Web Assembly یک فایل جاوا اسکریپت اجرای کدهای #C را شبیه سازی میکند. پس برنامه ی شما روی مرورگرهای قدیمی هم بدون مشکل اجرا خواهد شد.
جهت دانلود و نصب قالب نمونه می توانید به آدرس زیر مراجعه کنید :
https://github.com/aspnet/blazor
فریم ورک Blazor یک پروژه ی آزمایشی است که به تازگی به ASP اضافه شده و امکان استفاده از Web Assembly در دات نت را فراهم میکند. تمام مرورگرهای جدید از Web Assembly پشتیبانی می کنند. در نتیجه می توانید برنامه ی کلاینتی بنویسید که مانند جاوا اسکریپت به رویدادهای موس و کیبورد واکنش میدهد در کلاینت اجرا میشود.
نسخه ی آزمایشی این فریم ورک قابلیت دیباگ و Live Reloading دارد همچنین به شما امکان میدهد کامپوننت هایی بنویسید که به صورت تو در تو به هم وابستگی دارند. ابزاری مانند Dependency Injection و Server-Side Rendering هم در آن گنجاده خواهد شد.
یکی از جالبترین قابلیت های این فریم ورک امکان اجرای دستورات جاوا اسکریپت از درون #C است. حجم فریم ورک در حدود 400 کیلوبایت است که به همراه اولین بارگذاری صفحه دانلود میشود. در صورت عدم پشتیبانی مرورگر از Web Assembly یک فایل جاوا اسکریپت اجرای کدهای #C را شبیه سازی میکند. پس برنامه ی شما روی مرورگرهای قدیمی هم بدون مشکل اجرا خواهد شد.
جهت دانلود و نصب قالب نمونه می توانید به آدرس زیر مراجعه کنید :
https://github.com/aspnet/blazor
GitHub
GitHub - dotnet/blazor: Blazor moved to https://github.com/dotnet/aspnetcore
Blazor moved to https://github.com/dotnet/aspnetcore - GitHub - dotnet/blazor: Blazor moved to https://github.com/dotnet/aspnetcore
معرفی Technical Debt
بدهی فنی یا Technical Debt زمانی پیش می آید که بجای راه درست راه سریع را در پیش میگیرید. راه درست در بسیاری موارد طولانی و پیچیده است و شما خسته هستید،حوصله ندارید یا عجله دارید، پس سعی میکنید از راه میانبر بروید و با سرهم بندی مشکل را حل کنید.
ممکن است انتخاب راه میانبر از روی نادانستن باشد. اما معمولا این انتخاب عمدی است. محدودیت پول و زمان ، فشار کارفرما و یا باگ می تواند شما را به مسیر میانبر هدایت کند. وقتی سایت شما با هزاران کاربر ناگهان کرش میکند چیزی که اهمیت دارد آنلاین شدن مجدد پروژه است. با خود میگوید بعدا برمیگردم و اصلاح میکنم. اینجاست که بدهکار میشوید. بدهی مانند لایه های چربی دور شکم پروژه ی جمع میشود و آن را سنگین و مریض میکند.
هر چقدر پروژه بزرگتر باشد بدهی فنی با سرعت بیشتری بالا میرود. وقتی از برنامه عقب باشید اعضای تیم شروع به میانبر زدن میکنند و رهگیری همه آنها برای مدیر پروژه غیر ممکن است.
بدهی فنی لزوما بد نیست. در بسیاری از موارد چاره ای جز بدهکار شدن ندارید. مهم این است که :
1- بدانید کجا در حال میانبر زدن هستید.
2- آمار آن را به خوبی نگه دارید و هر وقت میانبر زدید جایی ثبت کنید.
3- همه روزه بخشی از زمان خود را صرف از بین بردن بدهی های قبلی کنید.
4- هیچوقت اجاز ندهید میزان بدهی فنی از 20 درصد کل پروژه بیشتر شود.
هر چه میزان بدهی بالا رود توسعه ی پروژه در درازمدت سخت تر میشود. خیلی زود مجبور میشوید روی میانبر های قبل میانبر های جدید پیاده کنید. آن وقت است که باید زنگ خطر را به صدا در آورید.
همانطور که بدهی بیش از حد باعث ورشکستگی میشود و وزن زیاد هم برای بدن شما خوب نیست ، بدهی فنی هم می تواند توسعه ی پروژه را غیر ممکن کند و هزینه ی حفظ و نگه داری را بیش از حد بالا ببرد. تا جایی که مجبور میشوید پروژه را رها کنید یا آن را از نو پیاده کنید.
بدهی فنی یا Technical Debt زمانی پیش می آید که بجای راه درست راه سریع را در پیش میگیرید. راه درست در بسیاری موارد طولانی و پیچیده است و شما خسته هستید،حوصله ندارید یا عجله دارید، پس سعی میکنید از راه میانبر بروید و با سرهم بندی مشکل را حل کنید.
ممکن است انتخاب راه میانبر از روی نادانستن باشد. اما معمولا این انتخاب عمدی است. محدودیت پول و زمان ، فشار کارفرما و یا باگ می تواند شما را به مسیر میانبر هدایت کند. وقتی سایت شما با هزاران کاربر ناگهان کرش میکند چیزی که اهمیت دارد آنلاین شدن مجدد پروژه است. با خود میگوید بعدا برمیگردم و اصلاح میکنم. اینجاست که بدهکار میشوید. بدهی مانند لایه های چربی دور شکم پروژه ی جمع میشود و آن را سنگین و مریض میکند.
هر چقدر پروژه بزرگتر باشد بدهی فنی با سرعت بیشتری بالا میرود. وقتی از برنامه عقب باشید اعضای تیم شروع به میانبر زدن میکنند و رهگیری همه آنها برای مدیر پروژه غیر ممکن است.
بدهی فنی لزوما بد نیست. در بسیاری از موارد چاره ای جز بدهکار شدن ندارید. مهم این است که :
1- بدانید کجا در حال میانبر زدن هستید.
2- آمار آن را به خوبی نگه دارید و هر وقت میانبر زدید جایی ثبت کنید.
3- همه روزه بخشی از زمان خود را صرف از بین بردن بدهی های قبلی کنید.
4- هیچوقت اجاز ندهید میزان بدهی فنی از 20 درصد کل پروژه بیشتر شود.
هر چه میزان بدهی بالا رود توسعه ی پروژه در درازمدت سخت تر میشود. خیلی زود مجبور میشوید روی میانبر های قبل میانبر های جدید پیاده کنید. آن وقت است که باید زنگ خطر را به صدا در آورید.
همانطور که بدهی بیش از حد باعث ورشکستگی میشود و وزن زیاد هم برای بدن شما خوب نیست ، بدهی فنی هم می تواند توسعه ی پروژه را غیر ممکن کند و هزینه ی حفظ و نگه داری را بیش از حد بالا ببرد. تا جایی که مجبور میشوید پروژه را رها کنید یا آن را از نو پیاده کنید.
نصب و راه اندازی dotnet watch
ابتدا باید بگم اگر سیستم شما دارای پردازنده ی سریع و رم بالایی نیست این ابزار کندتر از انتظار کار میکند. به نظر میرسه در نسخه ی 2.1 با تکنیک جدید بیلد سرعت این ابزار هم بیشتر باشه . قعلا باید منتظر نسخه ی بعدی باشیم.
برای نصب این ابزار کافیه پکیج Microsoft.DotNet.Watcher.Tools رو به پروژه اضافه کنید. البته مانند همه ی ابزار باید از طریق فایل csproj این کار را انجام دهید. خط زیر رو به فایل اضافه کنید :
<ItemGroup
<DotNetCliToolReference Include="Microsoft.DotNet.Watcher.Tools" Version="2.0.0" />
</ItemGroup>
بعد از تغییر فایل csproj مطمئن شوید پکیج ها restore شوند. سپس برای فعال کردن سیستم watch کافی است در cmd به مسیر پروژه بروید و دستور dotnet watch run را اجرا کنید.
حالا بعد از هر تغییر در فایلهای cs بلافاصله سیستم متوجه میشه و پروژه رو مجدد بیلد میکنه. خوبه که یکبار امتحان کنید و سرعتش رو روی سیستم خودتون بررسی کنید.اطلاعات بیشتر در لینک زیر موجود است :
https://docs.microsoft.com/en-us/aspnet/core/tutorials/dotnet-watch
ابتدا باید بگم اگر سیستم شما دارای پردازنده ی سریع و رم بالایی نیست این ابزار کندتر از انتظار کار میکند. به نظر میرسه در نسخه ی 2.1 با تکنیک جدید بیلد سرعت این ابزار هم بیشتر باشه . قعلا باید منتظر نسخه ی بعدی باشیم.
برای نصب این ابزار کافیه پکیج Microsoft.DotNet.Watcher.Tools رو به پروژه اضافه کنید. البته مانند همه ی ابزار باید از طریق فایل csproj این کار را انجام دهید. خط زیر رو به فایل اضافه کنید :
<ItemGroup
<DotNetCliToolReference Include="Microsoft.DotNet.Watcher.Tools" Version="2.0.0" />
</ItemGroup>
بعد از تغییر فایل csproj مطمئن شوید پکیج ها restore شوند. سپس برای فعال کردن سیستم watch کافی است در cmd به مسیر پروژه بروید و دستور dotnet watch run را اجرا کنید.
حالا بعد از هر تغییر در فایلهای cs بلافاصله سیستم متوجه میشه و پروژه رو مجدد بیلد میکنه. خوبه که یکبار امتحان کنید و سرعتش رو روی سیستم خودتون بررسی کنید.اطلاعات بیشتر در لینک زیر موجود است :
https://docs.microsoft.com/en-us/aspnet/core/tutorials/dotnet-watch
Docs
Develop ASP.NET Core apps using a file watcher
This tutorial demonstrates how to install and use the .NET Core CLI's file watcher (dotnet watch) tool in an ASP.NET Core app.