标签:Core 服务 启动 windows 程序 部署 host Net
前言
netcore用了这么久,虽然多数都是部署在centos系统,但也有部署在windows上的情况。最省力的部署方式是发布后直接在发布目录打开cmd,运行dotnet命令。虽然很省力,但是保留一个命令窗口,如果需要同时部署多个程序的话,就会保留多个窗口,而且还不能叉掉,对强迫症(我这种)来说简直不能忍。。。。
所以更好的部署方式就是把程序以windows服务的方式部署,还可以设置自动启动,节省一点运维成本。
怎么做?
首先准备一个core程序,然后引入这个包:
再然后找到main入口:
public static void Main(string[] args) { var host = CreateWebHostBuilder(args).Build(); if (Debugger.IsAttached) host.Run(); else host.RunAsService(); }
Debugger.IsAttached的意思是:程序是否以debug模式启动,是的话返回true,否则false
这几行代码的意思就是:如果是debug模式,就还保持窗口启动,到了发布环境就以服务方式启动。
为什么呢?因为只以服务启动程序的话,debug启动会报错,这样写更方便。
就这?
当然不是。我们还需要在服务器搞些动作。
当我们把发布好的文件在服务器保存好以后,管理员身份打开cmd,执行这条命令:
sc create 你的服务名称 binPath= "\"C:\program files\dotnet\dotnet.exe\" \"程序发布目录\"" DisplayName= "你的服务名称" start= auto
(重点:binPath、DisplayName、start这三个参数的等号后面必须带一个空格)
然后就可以在服务列表里看到它了:
如果上面的操作都没问题,但服务就是跑不起来,有可能是SDK版本不对,下对版本就可以了。
转 https://www.cnblogs.com/muchengqingxin/p/13190189.html
标签:Core,服务,启动,windows,程序,部署,host,Net 来源: https://www.cnblogs.com/wl-blog/p/15772030.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。