0


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

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

在这里插入图片描述
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";returnView(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设置为始终复制

在这里插入图片描述

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

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

2、使用Log4net记录文本日志

//注意日志存放地址publicclassFirstController: Controller
    {//日志private readonly ILogger<FirstController> _logger;private readonly ILoggerFactory _logFactory;publicFirstController(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异常日志)只记录ERRORFATAL日志--><!--当level value="WARN" (WARN警告日志)只记录WARNERRORFATAL日志--><!--当level value="DEBUG"(DEBUG调试状态) 只记录DEBUGWARNERRORFATAL日志--><!--当level value="INFO"(INFO普通日志) 只记录INFOWARNERRORFATAL日志--><level value="ALL"/></root>

四、日志组件NLog

1、NLog程序包的引入

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

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

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

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

在这里插入图片描述

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

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

2、怎么使用Nlog记录日志

publicclassFirstController: Controller
    {//日志private readonly ILogger<FirstController> _logger;private readonly ILoggerFactory _logFactory;publicFirstController(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、数据库日志表结构

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

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

1、脚本启动

dotnet run

2、VS2022启动

2.1 控制台启动

使用控制台启动,将在地址栏中弹出一个控制台,项目将调用Properties→launchSettings.json中的配置端口
在这里插入图片描述
在这里插入图片描述

2.2 IIS Express

启动时直接调动DLL文件,项目将调用Properties→launchSettings.json中的配置端口
在这里插入图片描述

在这里插入图片描述

六、IIS部署 .Net Core 程序

1 IIS安装及配置

1.1 IIS安装

打开启用或关闭Windows功能,将Internet Information Services下面全部勾选安装
在这里插入图片描述

1.2 依赖组件下载及配置

1.2.1 依赖组件下载

IIS 部署需要安装ASP.NET Core Module v2 官网地址: 访问
建议下载Windows 下的Hosting Bundle ( 网盘资源 提取码:tply)进行安装
在这里插入图片描述

1.2.2 配置AspNetCoreModuleV2

打开IIS 点击根目录,点击 模块 ,点击配置模板,找到 AspNetCoreModuleV2 进行添加
在这里插入图片描述

在这里插入图片描述

2 部署.Net Core 应用程序

2.1 项目的编译

第一步:选中项目,点击发布
在这里插入图片描述
第二步:有6种发布方式,这里选择了文件夹的方式
在这里插入图片描述
第三步:点击发布
在这里插入图片描述

2.2 IIS 发布项目

打开IIS,点击添加网站,配置应用程序地址及其他信息。
在这里插入图片描述

七、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配置文件中通过脚本启动的路径

在这里插入图片描述

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

标签: .net 学习

本文转载自: https://blog.csdn.net/liyonghewangtao/article/details/128701051
版权归原作者 木衍大师 所有, 如有侵权,请联系我们删除。

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

还没有评论