یک نکتهی تکمیلی: معرفی سیستم Logging در Asp.Net Core
سیستم Logging در نسخه Core بصورت پیشفرض موجود هست، اما در پروژههای غیر Core اگر نیاز به استفاده از آن را داشتید باید اول پکیج Microsoft.Extensions.Logging.Console را نصب کنید. طریقه استفاده ازین سیستم بسیار راحت بوده و کانفیگ خیلی خاصی ندارد؛ اما قبل از استفاده باید با اصطلاحات اولیه آن آشنا بشیم. چیزی که مسئولیت ثبت Log در برنامههای Core را دارد Logging Api تعریف شده در خود پلتفرم Asp.Net Core میباشد. Logها طبق این سیستم ذخیره میشوند و توسط Providerهای مختلف قابل نمایش میباشند. اما Logging Provider چیست؟ ابزاری که با استفاده از آن میتوانیم Logهای ذخیره شده توسط Logger را مشاهده کنیم و یا بعضا دستور ذخیره Logها را به Logger ارسال کنیم. در ادامه لیستی از Logging Providerهای موجود را میبینیم که شامل Debug , Console , EventSource , EventLog , AzureAppService , Application Insights و... میباشد. Log Providerهای متنوعی وجود دارند که بعضی از آنها مزایا و معایب خود را دارند و قابل همگام سازی با سیستم Asp.Net Core Logging میباشند مثل Providerهای Serilog , NLog و دیگر پکیجهایی که برای این موضوع وجود دارند. در وهله بعد وقتی صحبت از ذخیره Logها به میان میاید تعاریفی برای درجه اهمیت هر Log و الویت بندی Logها مطابق اهمیتشان وجود دارد که به ما کمک میکند دسته بندی و نظم بهتری در Logهای برنامه خودمان بیابیم. به این الویتها اصطلاحا Log Level گفته میشود که به شرح زیر میباشد.
◾️الویت 0 Trace
گزارشهایی که شامل دقیقترین پیامها هستند. این پیامها ممکن است حاوی دادههای حساس برنامه باشند. این پیامها به طور پیش فرض غیرفعال هستند و هرگز نباید در محیط تولید فعال شوند.
◾️الویت 1 Debug
اطلاعات مربوط به بررسی لحظهای در حین رفع خطا یا روند Debugging. این گزارشها در درجه اول باید حاوی اطلاعات مفیدی برای رفع اشکال باشند و هیچ ارزش طولانی مدتی ندارند.
◾️الویت 2 Information
گزارشهایی که جریان کلی برنامه را ردیابی میکنند. این Logها باید چرخه درازمدت داشته باشند.
◾️الویت 3 Warning
گزارشهایی که یک رویداد غیر عادی یا غیر منتظره را در جریان برنامه ثبت میکنند؛ اما در غیر این صورت باعث توقف اجرای برنامه نمیشوند.
◾️الویت 4 Error
گزارشهایی که هنگام توقف جریان اجرای فعلی به دلیل خرابی، ثبت میشوند. اینها باید نشان دهندهی یک شکست در فعالیت فعلی باشند، نه یک شکست در کل برنامه.
◾️الویت 5 Critical
اطلاعات غیرقابل بازیابی برنامه یا خرابی سیستم که نیاز به توجه فوری دارند.
برای فعالسازی Logging پیشفرض در Core ابتدا باید در کلاس Program، برنامه Provider مورد استفاده را مشخص کنید. اطلاعات مربوط به Log Level نمایشی برنامه در فایل AppSettingJson قرار دارد که معمولا Log Level نمایشی روی Information قرار دارد و Log هایی با الویت کمتر از Information را نمایش نمیدهد. میتوانید با تغیر در سطح الویت LogLevel اطلاعات مربوط به سطوح پایینتر یعنی Trace و Debug را نیز مشاهده کنید.
روشهای دیگری نیز برای دسته بندی Logها وجود دارند از جمله Log Category یا Log Event Id که میتوانید به سادگی از آنها استفاده کنید و دسته بندی دلخواه خود را برای Logها در برنامه داشته باشید.
نظرات اشتراکها
پنل مدیریت ng2-admin-rtl - راستچین و فارسی سازی از تیم وبلی
سلام
پیش نیازهای استفاده :
- Webpack 2
- Angular 2
- Typescript
- Bootstrap 4
- ES 6
می باشد. برای هر قسمت هم توانید در سایت آموزشهای مرتبط را پیدا کنید.
اشتراکها
Angular 9.1 منتشر شد
اشتراکها
TypeScript 3.7 Beta منتشر شد
اشتراکها
TypeScript 3.5 منتشر شد
اشتراکها
TypeScript 3.5 RC منتشر شد
اشتراکها
Deno.js پروژهی جدید خالق Node.js
خالق node.js، چند ماه قبل در مورد تعدادی از مشکلات آن ارائهای داشت. سپس ماه قبل در JS Fest 2019، محصول جدیدی را به نام Deno.js ارائه کرده که با Rust و TypeScript تهیه شدهاست.
اشتراکها