一、前言

本篇主要包含哪些内容?
  1. 将项目发布到本地目录

  2. 将项目传输到服务器并配置启动&开机自动启动

  3. 将Nginx作为访问入口,配置反向代理

本篇环境信息
  • 开发环境:

用途 工具&版本
操作系统 Windows 10
开发工具 Visual Studio 2017(15.7.5)
SDK .NET Core SDK 2.1
传输工具 FlashFxp
  • 部署环境

用途 工具&版本
Linux Server CentOS 7
SDK .NET Core SDK 2.1
传输工具 Vsftp
反向代理 Nginx 1.12.2
准备工作
  • ASP.NET Core 示例项目

说明
SDK .NET Core SDK 2.1
项目模板 ASP.NET Core Web App(MVC)
项目名称 HelloWeb
解决方案名称 HelloWeb
解决方案根目录 D:\Projects\Test\HelloWeb

项目创建完成后,需要修改Program.cs文件
手动指定启动的Url为:http://*:5000

 public class Program{         public static void Main(string[] args)             {CreateWebHostBuilder(args).Build().Run();}     

     public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>WebHost.CreateDefaultBuilder(args).UseStartup<Startup>().UseUrls("http://*:5000");}

http://*:5000 可以兼容 http://localhost:5000http://127.0.0.1:5000http://所在机器ip:5000,方便我们部署到Linux Server后进行测试

  • CentOS 7 部署环境

CentOS 7虚拟机安装:https://ken.io/note/hyper-v-course-setup-centos

  1. 部署FTP服务:https://ken.io/note/centos-quickstart-ftpserver

  2. 部署 .NET Core SDK 2.1:https://ken.io/note/centos7-.netcore2.1-setup

  3. 部署Nginx:https://ken.io/note/centos-quickstart-nginx-setup

二、发布到本地

1、命令行发布

在cmd命令行操作

#进入项目根目录(HelloWeb.csproj所在目录)d: && cd D:\Projects\Test\HelloWeb\HelloWeb#执行publish命令dotnet publish -c release#dotnet publish -h可以查看publish可选参数#-c release 表示以Release方式进行编译
2、Visual Studio图形界面操作
  • 在项目的鼠标右键菜单中选择:发布

  • 在左侧选择文件夹,并创建配置

  • 在发布操作面板中选择发布即可

3、本地运行测试

发布完成后,可以在D:\Projects\Test\HelloWeb\HelloWeb\bin\Release\netcoreapp2.1\publish查看发布后的文件输出。

在cmd命令行操作:

#进入发布输出目录d: && cd D:\Projects\Test\HelloWeb\HelloWeb\bin\Release\netcoreapp2.1\publish#启动应用dotnet HelloWeb.dll#启动成功会输出以下信息Hosting environment: Production
Content root path: D:\Projects\Test\HelloWeb\HelloWeb\bin\Release\netcoreapp2.1\publish
Now listening on: http://[::]:5000
Application started. Press Ctrl+C to shut down.

通过浏览器访问:localhost:5000,验证是否正常

三、部署

1、环境配置&启动测试

通过XShell连接到CentOS7服务器进行操作

  • 创建站点目录并授权

#创建站点根目录sudo mkdir -p /webroot/helloweb#创建站点应用目录sudo mkdir -p /webroot/helloweb/app#创建站点日志目录sudo mkdir -p /webroot/helloweb/logs#目录授权sudo chmod 777 /webroot/helloweb/app
sudo chmod 777 /webroot/helloweb/logs
  • 开放端口

#添加可访问端口sudo firewall-cmd --add-port=5000/tcp --permanent#重新加载防火墙策略sudo firewall-cmd --reload
  • 启动应用

通过FTP将传输到/webroot/helloweb/app

通过命令启动:

#进入app目录并通过dotnet命令启动站点cd /webroot/helloweb/app/
dotnet HelloWeb.dll#启动成功后,将会输出:Hosting environment: Production
Content root path: /webroot
Now listening on: http://[::]:5000
Application started. Press Ctrl+C to shut down.

这时候通过浏览器访问 http://{centos-ip}:5000即可

如果网站样式没有被正常加载,那应该是访问wwwroot下面的静态文件时404了。
这是因为 ASP.NET Core默认是以命令执行所在的目录作为应用根目录读取文件的
所以,一定要在HelloWeb.dll所在目录执行dotnet命令,不然会读取不到wwwroot目录下的静态文件

2、配置启动脚本

显示启动的方式,如果关闭XShell的连接窗口,那这个应用的进行就被关掉了。所以可以用nohup命令启动,脚本示例:

nohup dotnet HelloWeb.dll &

nohup由于是隐私启动,那应用的关闭就要找到进程id后才能关闭,所以还是干脆配置启动、停止脚本来操作更方便一些

  • 创建启动脚本

创建start.sh文件

sudo vi /webroot/helloweb/start.sh

脚本内容:

#!/bin/shcd $(cd "$(dirname "$0")"; pwd)
APP_NAME=HelloWeb.dllecho "start begin..."echo $APP_NAMEcd app
nohup  dotnet $APP_NAME >>../logs/info.log 2>>../logs/error.log &cd ..sleep 5if test $(pgrep -f $APP_NAME|wc -l) -eq 0thenecho "start failed"elseecho "start successed"fi
  • 创建停止脚本

创建stop.sh文件

sudo vi /webroot/helloweb/stop.sh

脚本内容:

#!/bin/shcd $(cd "$(dirname "$0")"; pwd)
APP_NAME=HelloWeb.dllPROCESS=`ps -ef|grep $APP_NAME|grep -v grep  |awk '{ print $2}'`while :dokill -9 $PROCESS > /dev/null 2>&1  if [ $? -ne 0 ];thenbreakelsecontinuefidoneecho 'stop success!'
  • 脚本测试

#启动应用sh /webroot/helloweb/start.sh#启动成功输出start begin...
HelloWeb.dll
start successed#停止应用sh /webroot/helloweb/stop.sh#停止成功后输出stop success!

开机启动&反向代理配置

1、配置开机启动
  • 将停止脚本标记为可执行文件

sudo chmod +x /webroot/helloweb/stop.sh
  • 创建helloweb服务

#创建服务文件sudo vi /usr/lib/systemd/system/helloweb.service#文件内容[Unit]
Description=helloweb
After=network.target[Service]
WorkingDirectory=/webroot/helloweb/app
ExecStart=/usr/bin/dotnet /webroot/helloweb/app/HelloWeb.dll
ExecStop=/webroot/helloweb/stop.sh
Restart=always
RestartSec=10[Install]
WantedBy=multi-user.target

如果你配置了多个版本的.NET Core环境,记得把/usr/bin/dotnet换成对应的路径

  • 设置服务开机启动&开启服务

#设置服务开机启动sudo systemctl enable helloweb#启动服务sudo systemctl start helloweb
2、Nginx反向代理配置
  • 创建helloweb站点配置

#新建配置文件sudo vi /etc/nginx/conf.d/helloweb.conf#反向代理配置内容server {listen       80;        #监听80端口server_name  helloweb.mydomain.com; #绑定的域名location / {            #转发或处理proxy_pass http://localhost:5000;}error_page   500 502 503 504  /50x.html;#错误页location = /50x.html {root   /usr/share/nginx/html;}
}
  • 重载NGINX配置

sudo nginx -s reload
  • 开放防火墙端口

#添加可访问端口sudo firewall-cmd --add-port=80/tcp --permanent#重新加载防火墙策略sudo firewall-cmd --reload
  • 访问测试:

通过设置本地hosts将helloweb.mydomain.com指向服务器IP

然后通过浏览器访问: helloweb.mydomain.com 即可

原文地址:https://ken.io/note/asp.net-core-publish-deploy-guide

.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

ASP.NET Core 应用发布与部署指南相关推荐

  1. Asp.net Core 打包发布 (Linux+Nginx)

    如果你觉得如下这些文章对你有帮助,请点击链接支持作者原创 http://www.cnblogs.com/savorboard/ .Net Core SDK 命令介绍 前言 本篇主要介绍 asp.net ...

  2. ASP.NET Core Web API 最佳实践指南

    原文地址: ASP.NET-Core-Web-API-Best-Practices-Guide 介绍 当我们编写一个项目的时候,我们的主要目标是使它能如期运行,并尽可能地满足所有用户需求. 但是,你难 ...

  3. 基于VS2017的Docker Support体检ASP.NET Core站点的Docker部署

    最近在学习如何用 Docker 部署生产环境中的 ASP.NET Core 站点,作为一个 Docer 新手,从何处下手更容易入门呢?一开始就手写 Docker 配置文件(Docfile, docke ...

  4. 运行Vue在ASP.NET Core应用程序并部署在IIS上

    前言 从.NET Core 1.0开始我们就将其应用到项目中,但是呢我对ASP.NET Core一些原理也还未开始研究,仅限于会用,不过园子中已有大量文章存在,借着有点空余时间,我们来讲讲如何利用AS ...

  5. ASP.NET Core 程序发布到Linux(Centos7)爬坑实战

    前言 前阶段弄了个Linux系统想倒腾倒腾.NET Core,结果看了下网上的资料,大部分都是过期的,走了不少弯路,不过还好,今下午总算捣鼓出来了.Linux命令太多了,唉.血的教训:安装一定要看官网 ...

  6. ASP.NET Core 网站发布到Linux服务器

    长期以来,使用.NET开发的应用只能运行在Windows平台上面,而目前国内蓬勃发展的互联网公司由于成本的考虑,大量使用免费的Linux平台,这就使得.NET空有一身绝技但无法得到广大的施展空间,.N ...

  7. RoadFlow ASP.NET Core工作流引擎IIS部署

    RoadFlow最新版本采用ASP.NET CORE2.1开发,部署步骤和.NET CORE部署一样,具体可参数ASP.NET CORE的部署方式. 1. 获取代码     首先从RoadFlow官网 ...

  8. 使用Entity Framework Core,Swagger和Postman创建ASP.NET Core Web API的分步指南

    目录 介绍 背景 第1步:创建一个新项目 第2步:添加模型类 第3步:使用Entity Framework Core 第4步:添加数据库上下文和控制器 步骤5:在Package Manager控制台中 ...

  9. Asp.Net Core Blazor之容器部署

    写在前面 Docker作为开源的应用容器引擎,可以让我们很轻松的构建一个轻量级.易移植的容器,通过Docker方式进行持续交付.测试和部署,都是极为方便的,并且对于我们开发来说,最直观的优点还是解决了 ...

最新文章

  1. Linux修改/etc/profile配置错误command is not found自救方法
  2. 基于SSH的在线音乐点评网站-java在线音乐点评网站
  3. C++11 类型推导decltype
  4. 数学建模学习笔记——层次分析法(评价类,专家打分一般不用)
  5. Java程序员面试中的多线程问题
  6. 关于类黄酮和类胡萝卜素
  7. 微信小程序---实现弹窗效果
  8. crv仪表上的i是什么指示灯_汽车打不着火是怎么回事,仪表盘汽车发动机故障灯亮是什么情况故障指示灯图解大全集...
  9. 【VB.NET】测验题目Quiz1
  10. Java高级语法笔记-字符集与中文编码
  11. 华为Mate40系列屏幕细节曝光:至少要上90Hz刷新率
  12. 流媒体服务器主板型号怎么看,关于服务器的详解
  13. 华为HMS核心服务全面开放 赋能开发者共筑智慧新生态
  14. ios aes 128 解密 php,iOS AES加密 PHP解密
  15. php 课程节次周次提取,用PHP写一个最简单的解释器Part5(计算器最后一节,下节开始如何写个脚本语言)...
  16. centOS 8 操作系统下载与安装
  17. 小强开饭店-从单体应用到微服务
  18. 白蛇传 冯梦龙 警世通言
  19. 使用powershell提权的一些技巧
  20. Unity UI 框架

热门文章

  1. CLIENT系列、OFFSET系列、SCROLL系列
  2. linux ubuntu deepin apache2 rewrite
  3. 每个程序员都可能犯过的10个错误
  4. 聚类算法学习指南(二)
  5. [导入]php 安全基础 附录B. 函数
  6. 使用Popup窗口创建无限级Web页菜单(5)
  7. Kubernetes:标签、选择器、注解、容忍度、亲和性
  8. WPF 四种不同效果呼吸灯
  9. OAuth 2.1 带来了哪些变化
  10. .NET 6 中的隐式命名空间引用