ASP.NET Core 应用发布与部署指南/教程

一、前言

1、本教程主要包含哪些内容?

  1. 将ASP.NET Core项目发布到本地目录
  2. 将ASP.NET Core项目发布后传输到服务器并配置启动
  3. 将Nginx作为访问入口,配置反向代理

2、本篇环境信息

  • 开发环境:

用途

工具&版本

操作系统

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

3、准备工作

  • 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/sh
cd $(cd "$(dirname "$0")"; pwd)
APP_NAME=HelloWeb.dll
echo "start begin..."
echo $APP_NAME

cd app
nohup  dotnet $APP_NAME >>../logs/info.log 2>>../logs/error.log &
cd ..

sleep 5

if test $(pgrep -f $APP_NAME|wc -l) -eq 0
then
   echo "start failed"
else
   echo "start successed"
fi
  • 创建停止脚本

创建stop.sh文件

sudo vi /webroot/helloweb/stop.sh

脚本内容:

#!/bin/sh
cd $(cd "$(dirname "$0")"; pwd)
APP_NAME=HelloWeb.dll

PROCESS=`ps -ef|grep $APP_NAME|grep -v grep  |awk '{ print $2}'`
while :
do
  kill -9 $PROCESS > /dev/null 2>&1
  if [ $? -ne 0 ];then
   break
  else
   continue
fi
done

echo '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 即可

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏晓晨的专栏

.NET Core 中的路径问题

.NET Core 应用程序相对于以前的.NET Framework 应用程序在启动运行的方式上有一定的差异,今天就来谈一谈这个获取应用程序启动路径的问题。

21150
来自专栏张善友的专栏

项目管理方面的几个.NET开源项目

1、NTrac: Trac 是个项目管理系统,是Python所写的,是基于 Subvertion -- 史上最优秀的版本管理系统的!,在code.google....

21590
来自专栏哲学驱动设计

分享 MSDN 下载工具(Word/PDF)

给大伙分享一个最近出炉的 MSDN 到 Word/PDF 转换器。我已经用它转换了 WPF、VSPackage、WWF 等 MSDN 章节为 PDF。 介绍 下...

316100
来自专栏Core Net

ASP.NET Core 2.0 : 九.从Windows发布到CentOS的跨平台部署

38060
来自专栏pangguoming

Windows下Mongodb安装及配置

安装文件:MongoDB-win32-x86_64-2008plus-ssl-3.2.6-signed.msi 电脑配置:win7 64位 mongodb的安装...

39440
来自专栏乐沙弥的世界

Linux 前后台作业切换及脱机管理

    Linux bash shell单一终端界面下,我们经常需要管理或同时完成多个作业,如一边执行编译,一边实现数据备份,以及执行SQL查询等其他的任务。所...

16010
来自专栏cnblogs

nuget服务器搭建,以及如何发布一个Nuget包

一、本地dll如何打包,以及版本的更新 本小节主要介绍两种方式将本地dll打包为Nuget包, 1.1 利用nuget.exe进行打包(应用于.net fram...

1.1K90
来自专栏张善友的专栏

微软开源全新的文档生成工具DocFX

微软放弃Sandcastle有些年头了,微软最近开源了全新的文档生成工具DocFX,目前支持C#和VB,类似JSDoc或Sphinx,可以从源代码中提取注释生成...

26080
来自专栏weixuqin 的专栏

使用U盘安装 OS X 的坑

353100
来自专栏我和未来有约会

使用动态语言来制作silverlight

在silverlight beta 2 中已经支持了动态语言.但是在Visual Studio 和 Experssion Blend中还没有使用动态语言的模版....

22070

扫码关注云+社区

领取腾讯云代金券