C# Asp.Net6 MVC,Log4net NLog 日志插件应用 及Windows、Liux环境下程序发布

这篇具有很好参考价值的文章主要介绍了C# Asp.Net6 MVC,Log4net NLog 日志插件应用 及Windows、Liux环境下程序发布。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

c# 日志插件,.net,学习
connected Services 服务依赖(第三方)
Properties 文件下 launchSettings.json 项目启动配置文件
wwwroad 存放静态文件
依赖项 管理Nuget程序包
appsettings.json 配置文件

一、 MVC含义

C 业务逻辑运算–调用其他的服务做业务逻辑
M 实体对象,保存数据,数据传输
V 视图,表现层

二、数据传输

1、控制器向视图传输数据

//控制器中方法的代码
        public IActionResult Index()
        {
            ViewBag.User1 = "测试1";
            ViewData["User2"] = "测试2";
            TempData["User3"] = "测试3";
            HttpContext.Session.SetString("User4", "测试4");
            Object User5 = "测试5";
            return View(User5);
        }
// **使用 HttpContext.Session时需要在Program.cs类中注册**    
{
    builder.Services.AddSession();//注册session
}
app.UseSession();//new  session

//视图接收数据
<input value="@ViewBag.User1" />
<input value="@ViewData["User2"]" />
<input value="@TempData["User3"]" />
<input value="@Context.Session.GetString("User4")" />
<input value="@Model" /

三、日志组件Log4net

1、Nuget程序包引入

第一步:寻找log4net 程序包进行安装;

第二步:新建文件夹Log4net,添加Log4net.config配置文件

Log4net.config 下载链接: link 提取码:tply

第三步:Log4net.config设置为始终复制

c# 日志插件,.net,学习

第四步:在Program.cs中配置日志包

//配置日志包
{
    //NuGet包引入2项
    //1.Log4Net
    //2.Microsoft.Extensions.Logging.Log4Net.AspNetCore
    builder.Logging.AddLog4Net("Log4net/Log4net.config");//单独的配置文件需要配置文件路径,在项目下就不用配置
}

2、使用Log4net记录文本日志

//注意日志存放地址
  public class FirstController : Controller
    {
        //日志
        private readonly ILogger<FirstController> _logger;
        private readonly ILoggerFactory _logFactory;

        public FirstController(ILogger<FirstController> logger ,ILoggerFactory loggerFactory) {
          
            this._logger = logger;
            this._logger.LogInformation($"{this.GetType().Name},具体日志记录信息1");
            this._logFactory = loggerFactory;
        }

        public IActionResult Index()
        {
                  //日志
            /*     !--控制级别,由低到高:ALL | DEBUG | INFO | WARN | ERROR | FATAL | OFF
            比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录
            如果没有定义LEVEL的值,则缺省为DEBUG-- > */
            //第一种
            this._logger.LogInformation($"{this.GetType().Name},具体日志记录信息2");
            //第二种
            ILogger<FirstController> logger2=this._logFactory.CreateLogger<FirstController>();
            logger2.LogInformation($"{this.GetType().Name},执行记录");
            logger2.LogError($"{this.GetType().Name},Error信息");
            logger2.LogDebug($"{this.GetType().Name},Debug信息");
        }
    }

3、如何把日志记录到数据库

1、项目引用 System.data.Sqlclient (数据库不同引入不同);
2、在Log4net.config 的中添加appender 具体为写入数据库日志配置(注意数据库用户和密码),还需在中增加appender

<log4net>
	<!--Log4net日志写入各数库配置参考地址:https://logging.apache.org/log4net/release/config-examples.html -->
	<!--写入sqlserver库日志配置-->
	<appender name="AdoNetAppender_SqlServer" type="log4net.Appender.AdoNetAppender">
		<bufferSize value="100" />
		<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
		<connectionString value="data source=[database server];initial catalog=[database name];integrated security=false;persist security info=True;User ID=[user];Password=[password]" />
		<commandText value="INSERT INTO Log ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
		<parameter>
			<parameterName value="@log_date" />
			<dbType value="DateTime" />
			<layout type="log4net.Layout.RawTimeStampLayout" />
		</parameter>
		<parameter>
			<parameterName value="@thread" />
			<dbType value="String" />
			<size value="255" />
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%thread" />
			</layout>
		</parameter>
		<parameter>
			<parameterName value="@log_level" />
			<dbType value="String" />
			<size value="50" />
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%level" />
			</layout>
		</parameter>
		<parameter>
			<parameterName value="@logger" />
			<dbType value="String" />
			<size value="255" />
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%logger" />
			</layout>
		</parameter>
		<parameter>
			<parameterName value="@message" />
			<dbType value="String" />
			<size value="4000" />
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%message" />
			</layout>
		</parameter>
		<parameter>
			<parameterName value="@exception" />
			<dbType value="String" />
			<size value="2000" />
			<layout type="log4net.Layout.ExceptionLayout" />
		</parameter>
	</appender>
	
	<root>
		<!--写入sqlserver库日志配置-->
		<appender-ref ref="AdoNetAppender_SqlServer" />
		<level value="DEBUG" />
	</root>
</log4net>

4、Log4net 日志级别配置

1、日志级别的日志调用

ILogger<FirstController> logger2=this._logFactory.CreateLogger<FirstController>();
          logger2.LogInformation($"{this.GetType().Name},Info记录普通日志");
          logger2.LogDebug($"{this.GetType().Name},Debug记录调试日志");
          logger2.LogError($"{this.GetType().Name},Error记录异常日志");
          logger2.LogWarning($"{this.GetType().Name},Warn记录警告日志");
          logger2.LogTrace($"{this.GetType().Name},Trace记录");
          logger2.LogCritical($"{this.GetType().Name},Critical记录严重日志");

2、Log4net 日志级别在Log4net.config中的配置

<root>
        <!--Log4net日志级别配置-->
		<!--控制器级别由低到高 ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->
		<!--当level value="ALL" 记录所有日志-->
		<!--当level value="OFF" 不会记录任何日志-->
		<!--当level value="FATAL"FATAL非常严重的问题日志)只记录FATAL日志-->
		<!--当level value="ERROR"ERROR异常日志)只记录ERROR FATAL日志-->
		<!--当level value="WARN"WARN警告日志)只记录WARN ERROR FATAL日志-->
		<!--当level value="DEBUG"(DEBUG调试状态) 只记录DEBUG WARN ERROR FATAL日志-->
		<!--当level value="INFO"INFO普通日志) 只记录INFO WARN ERROR FATAL日志-->
		<level value="ALL" />
</root>

四、日志组件NLog

1、NLog程序包的引入

第一步:在Nuget找到程序包进行安装(NLog.Web.AspNetCore)

第二步:新建log4net(什么名称都行)文件夹,添加NLog.config配置文件

NLog.config配置文件 下载
提取码:tply

第三步:设置NLog.config为始终复制

c# 日志插件,.net,学习

第四步:在Program.cs中配置日志包

#region NLog 
{
    //需要引入命名空间 using NLog.Web;
    //Nuget:引入 NLog.Web.AspNetCore
    builder.Logging.AddNLog("Log4net/NLog.config");//单独的配置文件需要配置文件路径,在项目下就不用配置
}
#endregion

2、怎么使用Nlog记录日志

 public class FirstController : Controller
    {
        //日志
        private readonly ILogger<FirstController> _logger;
        private readonly ILoggerFactory _logFactory;

        public FirstController(ILogger<FirstController> logger ,ILoggerFactory loggerFactory) {
          
            this._logger = logger;
            this._logger.LogInformation($"{this.GetType().Name},具体日志记录信息1");
            this._logFactory = loggerFactory;
        }

        public IActionResult Index()
        {
                  //日志
            /*     !--控制级别,由低到高:ALL | DEBUG | INFO | WARN | ERROR | FATAL | OFF
            比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录
            如果没有定义LEVEL的值,则缺省为DEBUG-- > */
            //第一种
            this._logger.LogInformation($"{this.GetType().Name},具体日志记录信息2");
            //第二种
            ILogger<FirstController> logger2=this._logFactory.CreateLogger<FirstController>();
            logger2.LogInformation($"{this.GetType().Name},执行记录");
            logger2.LogError($"{this.GetType().Name},Error信息");
            logger2.LogDebug($"{this.GetType().Name},Debug信息");
        }
    }

3、怎么使用Nlog 将日志写入数据库

1、项目引用 System.data.Sqlclient (数据库不同引入不同);
2、数据库日志表结构

 INSERT INTO [SystemLogs](createDate, origin,logLevel,message,stackTrace)
				         VALUES(@createDate,@origin,@logLevel,@message,@stackTrace)

五、Asp.NetCore6项目多种启动方式

1、脚本启动

dotnet run

2、VS2022启动

2.1 控制台启动

使用控制台启动,将在地址栏中弹出一个控制台,项目将调用Properties→launchSettings.json中的配置端口
c# 日志插件,.net,学习
c# 日志插件,.net,学习

2.2 IIS Express

启动时直接调动DLL文件,项目将调用Properties→launchSettings.json中的配置端口
c# 日志插件,.net,学习

c# 日志插件,.net,学习

六、IIS部署 .Net Core 程序

1 IIS安装及配置

1.1 IIS安装

打开启用或关闭Windows功能,将Internet Information Services下面全部勾选安装
c# 日志插件,.net,学习

1.2 依赖组件下载及配置

1.2.1 依赖组件下载

IIS 部署需要安装ASP.NET Core Module v2 官网地址: 访问
建议下载Windows 下的Hosting Bundle ( 网盘资源 提取码:tply)进行安装
c# 日志插件,.net,学习

1.2.2 配置AspNetCoreModuleV2

打开IIS 点击根目录,点击 模块 ,点击配置模板,找到 AspNetCoreModuleV2 进行添加
c# 日志插件,.net,学习

c# 日志插件,.net,学习

2 部署.Net Core 应用程序

2.1 项目的编译

第一步:选中项目,点击发布
c# 日志插件,.net,学习
第二步:有6种发布方式,这里选择了文件夹的方式
c# 日志插件,.net,学习
第三步:点击发布
c# 日志插件,.net,学习

2.2 IIS 发布项目

打开IIS,点击添加网站,配置应用程序地址及其他信息。
c# 日志插件,.net,学习

七、Liux 配置及程序部署

1 Liux环境配置

1、准备CentOS–或者Liux云服务器
2、准备文件传输工具:建议MobaXterm
3、保证Liux服务器可以直接访问 (本地 ping)
4、安装.net 6运行环境

//依次执行命令
yum update
yum install net-tools

注册镜像地址
sudo rpm -Uvh https://packages.microsoft.com/config/rhel/7/packages-microsoft-prod.rpm

安装ASP.NET Core SDK
sudo yum update
sudo yum install dotnet-sdk-6.0

关闭防火墙
systemctl disable firewalld

2 应用程序部署到Liux环境

2.1 应用程序的编译

2.1.1 修改launchSettings.json配置文件中通过脚本启动的路径

c# 日志插件,.net,学习

2.1.2 程序发布

第一步 :VS选择程序,点击发布,发布方式选择文件夹
第二步:将编译后的文件通过MobaXterm工具直接拖到root目录下
第三步:通过CD 命令进入程序文件目录下
第四步:执行dotnet *.dll --urls=http://192.168.1.1:7879 & 命令可以启动( nohup dotnet *.dll --urls=http://192.168.1.1:7879 & 可以做到守护进程)

Asp.NET6练习资源: 百度网盘下载提取码:tply文章来源地址https://www.toymoban.com/news/detail-629631.html

到了这里,关于C# Asp.Net6 MVC,Log4net NLog 日志插件应用 及Windows、Liux环境下程序发布的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Asp.Net 使用Log4Net (SQL Server)

    首先,在你的SQL Server数据库中创建一个用于存储日志的表。以下是一个简单的表结构示例: 修改Log4Net配置文件(Log4Net.config),将 RollingLogFileAppender 替换为 AdoNetAppender 。配置 AdoNetAppender 以连接到数据库并将日志数据插入到上述创建的数据库表中。 注意 bufferSize value=\\\"10\\\"/ ,

    2024年02月15日
    浏览(44)
  • AI面试官:Asp.Net 中使用Log4Net (二)

    当面试涉及到使用log4net日志记录框架的相关问题时,通常会聚焦在如何在.NET或.NET Core应用程序中集成和使用log4net。以下是一些关于log4net的面试题目,以及相应的解答、案例和代码: 解答:可以使用log4net的多个appender来实现将日志信息同时输出到文件和数据库。可以配置一

    2024年02月15日
    浏览(45)
  • .Net6 Web Core API --- AOP -- log4net 封装 -- MySQL -- txt

    目录 一、引入 NuGet 包 二、配置log4net.config   三、编写Log4net封装类 四、编写日志记录类 五、AOP -- 拦截器 -- 封装 六、案例编写 七、结果展示 log4net  Microsoft.Extensions.Logging.Log4Net.AspNetCore    MySql.Data         ----  MySQL数据库需要 Newtonsoft.Json Autofac Autofac.Extensions.DependencyInj

    2024年02月14日
    浏览(48)
  • c# Log4net使用介绍

    注意:将log4net.config的属性“复制到输出目录”设置为“始终复制” Log4net 是一个用于 .NET 平台的日志记录框架,它可以帮助开发者在应用程序中记录和管理日志信息,以便于调试和监控应用程序的运行情况。下面是 Log4net 的配置和使用过程及案例: 安装 log4net 可以通过 Nu

    2024年02月02日
    浏览(77)
  • C# .Net Core log4net 使用方法

    一、背景 前排提示,觉得墨迹的朋友可以直接看解决方法部分! 啊,许久没有这般耗时耗力了。。。鼓捣了一下午,不断地查阅资料,终于成功把log4net配置成功了。不过,笔者对log4net的底层并不了解,这里只是简单记录学习过程,给同样的初学者提供些许方便。 二、探索

    2024年02月04日
    浏览(43)
  • 【C#】.net core 6.0 使用第三方日志插件Log4net,配置文件详细说明

    欢迎来到《小5讲堂》 大家好,我是全栈小5。 这是《C#》系列文章,每篇文章将以博主理解的角度展开讲解, 特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。 温馨提示:博主能力有限,理解水平有限

    2024年04月12日
    浏览(52)
  • .NetCore之log4net的使用

    1.首先下载log4ne的包: 2.添加配置文件log4net.config 3.添加日志帮助类 4.在服务中采用单例生命周期注入 5.添加全局异常过滤器 6.注入过滤器服务 7.使用 日志截图:

    2024年02月11日
    浏览(40)
  • .NET 最便捷的Log4Net日志记录器

    Apache log4net 库是一个帮助程序员将日志语句输出到各种的工具 的输出目标。log4net是优秀的Apachelog4j™框架的移植 ® Microsoft.NET 运行时。我们保持了与原始log4j相似的框架 同时利用 .NET 运行时中的新功能。 log4net是Apache软件基金会Apache日志记录服务项目的一部分。日志记录服务

    2024年02月11日
    浏览(35)
  • Log4net在.Net Winform项目中的使用

    Log4net是一个流行的日志记录工具,可以帮助开发人员在应用程序中实现高效的日志记录。本文将提供一个详细的分步骤示例,来帮助您在.Net Winform项目中使用Log4net。 打开Visual Studio工具。 选择您的.Net Winform项目,并右击选择“管理NuGet程序包”。 在NuGet程序包管理器中搜索并

    2024年02月12日
    浏览(42)
  • .NET Core WebAPI中使用Log4net记录日志

    2024年02月20日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包