三种把.Net Core部署至 Windows 服务的方法
为什么部署至Windows Services在很多情况下,很少会把.Net Core项目部署至Windows服务中,特别是Asp.net Core就更少了。一般情况下,Asp.net Core会部署至linux服务器,或者部署至Windows的IIS中。但也不排除会有Asp.net Core部署至Windows 服务中的情况,比如Windows服务器并没有安装IIS,或者Asp.net Core中
为什么部署至Windows Services
在很多情况下,很少会把.Net Core
项目部署至Windows服务中,特别是Asp.net Core就更少了。一般情况下,Asp.net Core会部署至linux服务器,或者部署至Windows的IIS中。但也不排除会有Asp.net Core部署至Windows 服务中的情况,比如Windows服务器并没有安装IIS,或者Asp.net Core中存在一些定时任务,需要实时运行,等等一些情况。
微软解决方案
微软也提供了.Net Core部署至Windows 服务的解决方案,应该说是 Asp.net Core的解决方案。可以参看官方文档 https://docs.microsoft.com/zh-cn/aspnet/core/host-and-deploy/windows-service?view=aspnetcore-2.1&tabs=aspnetcore2x 。但是官方的解决方案比较繁琐,而且需要更改部分代码。
第一种方式:控制台运行
打开cmd ,路径定位到项目根目录文件夹,运行dotnet run
如果端口冲突,可在launchSettings.json
修改对应端口。
运行后会自动监听对应端口,直接访问 http://127.0.0.1:5002/api/values 即可调取接口
第二种方式:IIS部署
发布到文件夹binDebug etcoreapp2.1publish
1. 新建IIS站点
端口为9011,程序池设置CLR版本为无托管代码
2. 安装 .NET Core Windows Server 托管捆绑包
此时访问接口 依然报错,网上查询,还需要安装.NET Core Windows Server
托管捆绑包 。
如果想监听日志,在发布文件夹下新建logs
文件夹,然后修改web.config
设置stdoutLogEnabled=”true
”
此时访问http://127.0.0.1:9011/api/values
,成功调取接口
第三种方式:使用NSSM
后面的代码演示以Asp.net Core 2.1作为演示,其他.Net Core
方式一致。
1、确保.Net Core
程序可以正常运行
先把Asp.net Core发布,然后直接运行dotnet
命令,确保程序可以运行并访问
2、使用NSSM安装dotnet
下载NSSM
,使用命令窗口至NSSM
目录中找到nssm.exe
所在的目录,然后运行nssm install
,然后会弹框,选择相应的文件和文件夹。
Path
:dotnet所在的目录,一般默认是在C:Program Filesdotnetdotnet.exe;
Startup directory
:程序所在的目录,就是最后程序dll所在的目录;
Arguments
:程序dll的名称,一般是项目名加上.dll;
Service name
:在此写上服务的名称即可。
然后点击Install service
按钮就完成了部署。
最后到Windows服务管理界面找到安装的服务名称,右键启动即可,或者直接运行nssm start 服务名称,也可以运行net start 服务名称。这样就可以非常简单的把.Net Core托管至Window服务中。方便管理、启动、停止等等。
NSSM更多的操作
命令窗口至NSSM目录中找到nssm.exe
所在的目录,然后运行nssm
,会看到NSSM的更多操作
比如对服务的增删改查,启动,停止,重启等等。都可以直接用NSSM
直接操作,一些常用的操作支持界面话(GUI)。
总结
1、使用NSSM
不仅可以把Asp.net Core部署到Windows
服务中,也可以把.Net Core甚至于其他exe
程序封装在服务中运行。
2、为.Net Core提供了另一种部署在Windows
的方式。
更多推荐
所有评论(0)