- 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的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!