在CentOS部署AspNetCore网站

 

  前段时间某云服务器大促,就买了一台打算折腾一下,买了几个月,却啥也没做,就改了个初始密码。最近快到双十一了,另一家厂商相同配置的服务器价格又便宜了一大截,看来又得剁手了。从今年开始,搜索一下云服务器,发现好多大厂都开始涉足云服务器市场了,之前做这块和没做这块业务的大大小小的厂商今年都在大力推广自己的云服务器产品,市场竞争起来了,价格就友好多了呀。 2019年已经不适合在地上走了,咱也到云里面去看一看。开始折腾吧。

 

安装dotnet 运行时

  首先注册微软产品仓库,这样就可以通过yum安装.NET Rumtime了。

sudo rpm -Uvh https://packages.microsoft.com/config/centos/7/packages-microsoft-prod.rpm

  目前dotnetcore3.0已经发布,运行时版本最好选择和本地开发的sdk版本一致。我本地已经更新到.NET SDK3.0了,所以在服务器安装aspnetcore-runtime-3.0

sudo yum install aspnetcore-runtime-3.0

 

aspnetcore网站

  创建aspnetcore Web程序,目标框架选择.NET Core 3.0,啥也不做,直接发布。powershell或者cmd进入到publish目录,使用dotnet命令运行一下程序,默认访问5000端口,可以看到网站正常运行。

 

上传到服务器

  远程连接工具使用WinSCP和PuTTY。首先用WinSCP连接到服务器,在home目录创建目录wwwroot专门用来存放网站资源,再创建一个目录firstnetcorev3对应刚刚发布的网站,将publish目录下的所有文件上传到firstnetcorev3这个目录。在服务器网站目录中使用dotnet命令启动网站,不出意外应该会提示现在监听5000端口。此时在本地浏览器访问服务器5000端口是不会有响应的,因为在服务器上还没有开放端口。在服务器上的浏览器访问5000端口,应该可以看到网站运行的页面,不过我的服务器是最小化安装,没有图形化界面。 ̄□ ̄||

 

安装nginx

  添加yum源,根据自己的服务器系统架构选择。http://nginx.org/packages/

sudo rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

  安装

sudo yum install -y nginx

  启动

sudo systemctl start nginx.service

  现在本地访问服务器ip就可以看到nginx的欢迎页面了。

  开机启动

sudo systemctl enable nginx.service

  nginx全局配置文件在这里:/etc/nginx/nginx.conf

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}
View Code

  可以看到它包含了这个目录下的所有配置文件:/etc/nginx/conf.d/,目录下有一个default.conf文件,这是nginx的默认配置,修改一下,或者新增一个conf文件。如果是新增的conf,监听端口不可以是80,因为默认配置中已经使用了80端口。我这里新增了一个firstnetcorev3.conf文件。

server {
# 监听外网端口 listen 500
0; location / {
# 内部转发端口 proxy_pass http:
//localhost:5000; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection keep-alive; proxy_set_header Host $host; proxy_cache_bypass $http_upgrade; } }

  重启nginx

nginx -s reload

 

开放端口

  查看防火墙状态

systemctl status firewalld

  启动防火墙

systemctl start firewalld

  开放80端口,我同时开放了5000端口。

firewall-cmd --zone=public --add-port=80/tcp --permanent

  重启防火墙

firewall-cmd --reload

 

外网访问服务器网站

  在本地浏览器直接输入服务器ip,正常打开nginx欢迎页面。我之前是新增了一个nginx配置文件,监听外部5000端口转发服务器内部5000端口,在本地访问服务器5000端口,报500错误。80端口正常,说明nginx运行正常,5000端口是刚刚部署的网站端口,500错误应该是网站没有启动。

  进入网站发布路径,使用dotnet命令启动网站,然而报错了。

在CentOS部署AspNetCore网站_第1张图片

   提示5000端口已经被使用了,原来是之前开放了防火墙5000端口,那就换另一个端口,先删除5000端口,再开放5001端口,重启防火墙。

firewall-cmd --zone=public --remove-port=5000/tcp --permanent
firewall-cmd --zone=public --add-port=5001/tcp --permanent
firewall-cmd --reload

  修改firstnetcorev3.conf,将开放端口改成5001。进入网站发布路径,再次启动网站。

在CentOS部署AspNetCore网站_第2张图片

在CentOS部署AspNetCore网站_第3张图片

  网站部署成功了,先小结一段。服务器多站点部署情况下,nginx可以使用多个配置文件,nginx监听的防火墙端口不可以和web应用程序运行的端口冲突。但是这种部署方式需要手动启动网站,虽然已经设置开机启动nginx服务,但是网站本身不会自动启动,重启服务器的话,需要手动启动网站。这个时候就需要一个程序自动启动网站了。

 

使用守护进程supervisor

  安装supervisor

yum install supervisor

  安装成功后,在/etc/目录下会产生一个supervisord.conf文件,打开文件查看,这一行:files = supervisord.d/*.ini,可以看到配置文件都在supervisord.d目录下,并且是ini格式。进入到supervisord.d目录,创建一个firstnetcorev3.ini文件。

[program:firstnetcorev3]
command=dotnet publish2centos.dll
directory=/home/wwwroot/firstnetcorev3/
autostart=true
autorestart=true
stderr_logfile=/var/log/firstnetcorev3.err.log
stdout_logfile=/var/log/firstnetcorev3.out.log
environment=ASPNETCORE_ENVIRONMENT=Production
user=root
startsecs=1
stopsignal=INT

  启动supervisor,并设置为开机启动。

systemctl enable supervisord
systemctl start supervisord
systemctl is-enabled supervisord

   重启服务器试试,在PuTTY里面用命令reboot弹出了一个弹窗,但是应该已经重启成功了,不确定的话,在云服务器控制面板重启服务器,完成重启后,再次访问服务器5001端口,网站运行正常。这样,AspNetCore网站部署在CentOS服务器就成功了。

 

你可能感兴趣的:(在CentOS部署AspNetCore网站)