- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章.Net Core项目如何添加日志功能详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1、微软内置的日志组件 。
在.Net Core中使用模板新建的Web Api项目时,会自动加入日志功能。只需要在控制器中注入ILogger就可以了。命名空间为:Microsoft.Extensions.Logging.
会发现只有Error被打印到了控制台,Trace没有被打印。那是因为在appsetting.json中配置了Logging>Console>Default的等级为Debug,日志的等级大于等于Debug才会输出到控制台。在这里说一下LogLevel:Trace<Debug<Information<Warning<Error<Critical<None.
当打开appsettings.development.json文件你会发现跟appsettings.json配置不同。如下:
1
2
3
4
5
6
7
8
9
10
|
{
"Logging"
: {
"IncludeScopes"
:
false
,
"LogLevel"
: {
"Default"
:
"Debug"
,
"System"
:
"Information"
,
"Microsoft"
:
"Information"
}
}
}
|
例如:
"System": "Information" 表示命名空间以System开头的类中且日志等级大于等于Information才会输出到控制台.
"Default": "Debug" 表示除以System和Microsoft开头的命名空间日志等级大约等于Debug才会输出到控制台.
这里说明一下到底是在什么时候,读取了appsettings.json中的配置了了? 其实是在Program中 WebHost.CreateDefaultBuilder(arge) .
打开源码发现 。
当然我们可以不用微软提供的默认配置 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
public
class
Program
{
public
static
void
Main(
string
[] args)
{
//指定配置文件路径
var configBuilder =
new
ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile($
"appsettings.json"
,
true
,
true
)
.AddJsonFile($
"appsettings.{EnvironmentName.Development}.json"
,
true
,
true
);
var config = configBuilder.Build();
var host =
new
WebHostBuilder()
.UseKestrel()
.UseStartup<Startup>()
.UseContentRoot(Directory.GetCurrentDirectory())
.UseUrls(config[
"AppSettings:Url"
])
//设置启动时的地址
.Build();
host.Run();
}
}
|
配置文件为:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
{
"AppSettings"
: {
"Url"
:
"http://0.0.0.0:6000"
},
"Logging"
: {
"IncludeScopes"
:
false
,
"Debug"
: {
"LogLevel"
: {
"Default"
:
"Info"
}
},
"Console"
: {
"LogLevel"
: {
"Default"
:
"Warning"
}
}
}
}
|
StartUp为:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
public
class
Startup
{
public
IConfiguration Configuration {
get
;
private
set
; }
public
Startup(IHostingEnvironment env)
//在构造函数中注入 IHostingEnvironment
{
Configuration =
new
ConfigurationBuilder()
.SetBasePath(env.ContentRootPath)
.AddJsonFile($
"appsettings.json"
)
.Build();
}
public
void
ConfigureServices(IServiceCollection services)
{
services.AddMvc();
}
public
void
Configure(IApplicationBuilder app,
IHostingEnvironment env,
ILoggerFactory loggerFactory)
{
if
(env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
//添加控制台输出
loggerFactory.AddConsole(Configuration.GetSection(
"Logging"
));
loggerFactory.AddDebug();
app.UseMvc();
}
}
|
但是微软提供的内置的日志组件没有实现将日志记录到文件、数据库上。下面介绍NLog 。
2、NLog 。
首先使用NuGet添加NLog,然后在Startup的Configure中添加以下代码 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
public
void
Configure(IApplicationBuilder app,
IHostingEnvironment env,
ILoggerFactory loggerFactory)
{
if
(env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
//添加控制台输出
loggerFactory.AddConsole(Configuration.GetSection(
"Logging"
));
loggerFactory.AddDebug();
loggerFactory.AddNLog();
//添加NLog
NLog.LogManager.LoadConfiguration($
@"{env.ContentRootPath}/nlog.config"
);
//指定NLog的配置文件
app.UseMvc();
}
|
配置NLog的配置文件 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
<?
xml
version
=
"1.0"
encoding
=
"utf-8"
?>
<
nlog
xmlns
=
"http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi
=
"http://www.w3.org/2001/XMLSchema-instance"
autoReload
=
"true"
>
<!--internalLogLevel="Warn"
internalLogFile="internal-nlog.txt">-->
<
targets
>
<
target
name
=
"allfile"
xsi:type
=
"File"
fileName
=
"./logs/${shortdate}/all.log"
layout
=
"${longdate}|${message} ${exception}"
/>
<
target
name
=
"debugfile"
xsi:type
=
"File"
fileName
=
"./logs/${shortdate}/debug.log"
layout
=
"${longdate}|${message} ${exception}"
/>
<
target
name
=
"infofile"
xsi:type
=
"File"
fileName
=
"./logs/${shortdate}/info.log"
layout
=
"${longdate}|${message} ${exception}"
/>
<
target
name
=
"warnfile"
xsi:type
=
"File"
fileName
=
"./logs/${shortdate}/warn.log"
layout
=
"${longdate}|${message} ${exception}"
/>
<
target
name
=
"errorfile"
xsi:type
=
"File"
fileName
=
"./logs/${shortdate}/error.log"
layout
=
"${longdate}|${message} ${exception}"
/>
<
target
name
=
"fatalfile"
xsi:type
=
"File"
fileName
=
"./logs/${shortdate}/fatal.log"
layout
=
"${longdate}|${message} ${exception}"
/>
<
target
name
=
"network"
xsi:type
=
"Network"
address
=
"udp://chinacloudapp.cn:4561"
layout
=
"Development|${longdate}|${event-properties:item=EventId.Id}|${logger}|${uppercase:${level}}|${message} ${exception}"
/>//将日志通过网络输出
<
target
name
=
"debuge"
xsi:type
=
"Console"
/>//将日志输出到控制台
</
targets
>
<
rules
>
<
logger
name
=
"*"
minlevel
=
"Trace"
writeTo
=
"allfile,debuge"
/>
<
logger
name
=
"*"
level
=
"Info"
writeTo
=
"infofile"
/>
<
logger
name
=
"*"
level
=
"debug"
writeTo
=
"debugfile"
/>
<
logger
name
=
"*"
level
=
"warn"
writeTo
=
"warnfile"
/>
<
logger
name
=
"*"
level
=
"error"
writeTo
=
"errorfile"
/>
<
logger
name
=
"*"
level
=
"fatal"
writeTo
=
"fatalfile"
/>
</
rules
>
</
nlog
>
|
xsi:type=“File”存储日志为文件格式 .
xsi:type="Console" 表示为控制台输出.
fileName="./logs/${shortdate}/all.log" 表示存储文件路径.
layout="${longdate}|${message} ${exception}" 表示为文件内容的布局.
rules标签下面表示,对应等级的日志写到对应target中。如 。
<logger name="*" level="Info" writeTo="infofile" /> 表示等级为Info的日志写到target名称为infofile的文件中.
<logger name="*" minlevel="Trace" writeTo="allfile,debuge" /> 表示日志等级大于Trace的日志写到target名称为allfile和debuge(控制台输出)中.
同样在使用的时候,只需要在用到的地方注入ILogger,就可以使用了.
总结 。
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我的支持.
原文链接:https://www.cnblogs.com/MicroHeart/p/9268596.html 。
最后此篇关于.Net Core项目如何添加日志功能详解的文章就讲到这里了,如果你想了解更多关于.Net Core项目如何添加日志功能详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
创建使用.NET框架的asp.net页面时,访问该页面的客户端是否需要在其计算机上安装.NET框架? IE。用户访问www.fakesite.com/default.aspx,如果他们没有安装框架,他
我阅读了很多不同的博客和 StackOverflow 问题,试图找到我的问题的答案,但最后我找不到任何东西,所以我想自己问这个问题。 我正在构建一个应用程序,其中有一个长时间运行的工作线程,它执行一些
已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 我一直想知道为什么微软为这样一个伟大的平台选择了一个如此奇怪的、对搜索引擎不友好的名称。他们就
.Net Framework .Net .NET Standard的区别 1、.NET Framework 在未来.NET Framework或许成为过去时,目前还是有很多地方在使用的。这一套
如果有选择的话,您会走哪条路? ASP.NET Webforms + ASP.NET AJAX 或 ASP.NET MVC + JavaScript Framework of your Choice
我有一个 Web 服务,它通过专用连接通过 https 使用第三方 Web 服务,我应用了 ServicePointManager.ServerCertificateValidationCallbac
为什么我应该选择ASP.NET Web Application (.NET Framework)而不是ASP.NET Core Web Application (.NET Framework)? 我在
我在网络上没有找到任何关于包含 .NET Standard、.NET Core 和 .NET Framework 项目的 .NET 解决方案的公认命名约定。 就我而言,我们在 .NET 框架项目中有以
.NET Compact 是 .NET 的完美子集吗? 假设我考虑了屏幕大小和其他限制并避免了 .NET Compact 不支持的类和方法,或者 .NET Compact 是一个不同且不兼容的 GUI
我已经阅读了所有我能找到的关于 connectionManagement 中的 maxconnection 设置的文章:即 http://support.microsoft.com/kb/821268
我现在正在使用asp.net mvc,想知道使用内置的Json或 Json.Net哪个是更好的选择,但我不确定一个人是否比另一个人有优势。 另外,如果我确实选择沿用Json.Net的路线,那么我应该选
在 Visual Studio 中,您至少可以创建三种不同类型的类库: 类库(.NET Framework) 类库(.NET 标准) 类库(.NET Core) 虽然第一个是我们多年来一直使用的,但我
.NET 和 ASP.NET 之间有什么区别?它们有什么关系? 最佳答案 ASP.Net 基于 .Net 框架构建,提供有关 Web 开发的附加功能。 你可以去看看wikipedia article
在安装更高版本(3.0)之前,我需要安装.net框架1.1和2.0吗?或者单独安装 3.0 框架就足够了,并为在早期框架版本上编写的软件提供支持?谢谢 ,丽然 最佳答案 不,您不必安装以前的框架。 我
我正在开发一个项目,人们可以“更新”类别,例如更改类别的名称。我收到以下消息 This is called after clicking update 按钮 with the SQL statemen
.NET 类 System.Net.CookieContainer 线程安全吗? --更新:交 key 答复-- 是否有任何方法可以确保异步请求期间修改的变量(即 HttpWebRequest.Coo
我正在使用 JScript.NET 在我编写的 C# WinForms 应用程序中编写脚本。它工作得很好,但我只是尝试在脚本中放置一些异常处理,但我无法弄清楚如何判断我的 C# 代码抛出了哪种类型的异
我需要你的帮助, 比如我有一个小数类型的变量,我想这样取整。 例如 3.0 = 3 3.1 = 4 3.2 = 4 3.3 = 4 3.4 = 4 3.5 = 4 3.6 = 4 3.7 = 4 3.
我使用过这样的代码:http://msdn.microsoft.com/en-us/library/dw70f090.aspx在 ASP.NET 中工作之前访问数据库(2-3 年前)。我没有意识到我正
自 ConfigurationManager .NET Standard 中不存在,检索正在执行的程序集的应用程序设置的最佳方法是什么,无论是 web.config或 appSettings.{env
我是一名优秀的程序员,十分优秀!