前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >.Net Core Linux centos7行—发布程序到生产环境

.Net Core Linux centos7行—发布程序到生产环境

作者头像
旺财的城堡
发布2018-11-20 16:02:13
1K0
发布2018-11-20 16:02:13
举报
文章被收录于专栏:calvincalvin

实验demo现在需要发布到生产环境,发现在发布的时候要考虑到不一致的几个地方。

1.各类配置文件线下,线上不一致。

2.绑定的url不一致,可能是域名不一致,也可能是schema不一致(http,https)

配置文件的不一致问题,可以使用环境配置来解决。系统默认定义了3个:Development, Staging, Production

appsettings.json

开发:appsettings.Development.json

线上:appsettings.Production.json

绑定url的问题在rc1还好解决。

project.json add

"commands": {

"web": "Microsoft.AspNetCore.Server.Kestrel --server.urls http://unix:/var/aspnet/HelloMVC/kestrel.sock",

},

但是到rc2之后,这个也取消了。google了一圈,找到有2种解决方案。

其一:http://benfoster.io/blog/how-to-configure-kestrel-urls-in-aspnet-core-rc2

使用配置文件的方式,因为没有环境参数所以不好兼容到线上线下环境。暂时不考虑

其二:https://www.billboga.com/posts/setting-host-uri-in-aspnet-core-rc2

使用启动参数来设置。暂时考虑使用这个,考虑到假如线上分布式部署,包括系统的安装,脚本等都是统一管理。所以还是可行的

发布到linux线上环境:

运行环境。nginx反向代理由kestrel运行.net core程序

第一步:搭建网站,本地能正常运行:http://www.cnblogs.com/calvinK/p/5604577.html

修改Main入口,使我们的程序绑定的url来自启动参数

发布到本地,然后上传到linux服务器。进入服务器,cd 到上传的目录,

dotnet NetCoreWebApp.dll --server.urls="http://localhost:6000;http://localhost:6001"//已";"分割.可以绑定多个 url。

启动完成,使用 curl http://localhost:6000 测试是否能正常访问。

第二步:配置nginx反向代理。nginx安装:http://www.cnblogs.com/calvinK/p/5604036.html

修改配置nginx.conf

location / {

#设置主机头和客户端真实地址,以便服务器获取客户端真实IP

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

#需要代理的地址。upstream 配置负责均衡

proxy_pass http://localhost:6000;

}

修改完成 使用nginx -t -c nginx.conf 验证配置是否修改有误问题,测试木有问题就可以restart后,通过nginx代理访问到我们绑定在http://localhost:6000的.net core demo程序啦。

当然,我们的服务器存在重启或者down掉等问题,不可能出了问题我们手动重启等

1.nginx 开机自动启动。新建服务

# vim /usr/lib/systemd/system/nginx.service

[Unit]

Description=nginx - high performance web server

Documentation=http://nginx.org/en/docs/

After=network.target remote-fs.target nss-lookup.target

[Service]

Type=forking

PIDFile=/nginxInstall/sbin/logs/nginx.pid

ExecStartPre=/nginxInstall/sbin/nginx -t -c /nginxInstall/conf/nginx.conf

ExecStart=/nginxInstall/sbin/nginx -c /nginxInstall/conf/nginx.conf

ExecReload=/bin/kill -s HUP $MAINPID

ExecStop=/bin/kill -s QUIT $MAINPID

PrivateTmp=true

[Install]

WantedBy=multi-user.target

编辑完成 使用命令 systemctl enable nginx.service 配置nginx服务为随开机启动。

> 需要注意的地方是:PIDFile=/nginxInstall/sbin/logs/nginx.pid 和 nginx.conf 中的 pid /nginxInstall/sbin/logs/nginx.pid 一定要一致

2.配置web app的监控程序。使用官方推荐的 supervisor

2.1.第一步安装 setuptools

# wget https://bootstrap.pypa.io/ez_setup.py -O - | python

如果提示木有python,那就安装一个ypthon就好。视网络情况而定,可能是漫长的下载等待。

当然也可以下载安装:https://pypi.python.org/pypi/setuptools

下载.gz压缩包,上传到centos,

解压:[root@localhost opt]# tar -xzvf setuptools-23.1.0.tar.gz

编译:[root@localhost setuptools-23.1.0]# sudo python setup.py build

安装:[root@localhost setuptools-23.1.0]# sudo python setup.py install

可以看到安装到/usr/bin下面啦。当然我们也可以使用configure 指定安装目录。

如果按照在自己的指定目录,可以使用

# sudo ln -s [your install path] /bin/easy_install

创建一个软连接,方便我们使用。

2.2.安装supervisor

# easy_install supervisor

配置supervisor: 参考:http://www.cnblogs.com/hamu/p/5587220.html

在/etc/supervisor目录下新建配置文件supervisord.conf,当然在这些目录下也是可以的 default paths (/usr/etc/supervisord.conf, /usr/supervisord.conf, supervisord.conf, etc/supervisord.conf, /etc/supervisord.conf, /etc/supervisor/supervisord.conf);

#vim /etc/supervisor/supervisord.conf

supervisord配置文件写入:

[supervisord]

logfile = /tmp/supervisord.log

logfile_maxbytes = 50MB 

logfile_backups=10 

loglevel = info 

pidfile = /tmp/supervisord.pid 

nodaemon = false 

minfds = 1024 

minprocs = 200 

umask = 022 

user = root 

identifier = supervisor 

directory = /tmp 

nocleanup = true 

childlogdir = /tmp 

strip_ansi = false

配置supervisor作为服务运行

#vim /usr/lib/systemd/system/supervisord.service

[Unit] 

Description=Supervisor daemon 

[Service]

Type=forking

ExecStart=/usr/bin/supervisord

ExecStop=/usr/bin/supervisorctl $OPTIONS shutdown

ExecReload=/usr/bin/supervisorctl $OPTIONS reload

KillMode=process

Restart=on-failure

RestartSec=42s [Install]

WantedBy=multi-user.target

增加监控

编辑我们上面创建的supervisord.conf,加入

[program:NetCoreWebAppFirst]

#启动命令

command=dotnet NetCoreWebApp.dll --server.urls=http://localhost:6000

#启动前要cd到的位置

directory=/saleSystem/NetCoreWebApp/

#是否自动启动

autorestart=true

#是否重定向程序的错误输出到标准输出

redirect_stderr=true

#延时启动时间

startsecs=10

#启动超时时间

stopwaitsecs=30

#日志

stdout_logfile=/var/log/netcorewebapp/error.log

stdout_logfile_maxbytes=50MB

#是否随supervisor一起启动

autostart=true

#管理页面

[inet_http_server]

port=9100

username=mon

password=mon

配置完成后,stop,在start服务

访问管理页面就能看到

 当然不忘记让我们增加的服务自动开机启动

systemctl enable nginx.servicve

systemctl enable supervisord.service

如此这样,我们做到了nginx和supervisord都随机启动并保证服务因意外中断也能自动重启。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016-06-29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
访问管理
访问管理(Cloud Access Management,CAM)可以帮助您安全、便捷地管理对腾讯云服务和资源的访问。您可以使用CAM创建子用户、用户组和角色,并通过策略控制其访问范围。CAM支持用户和角色SSO能力,您可以根据具体管理场景针对性设置企业内用户和腾讯云的互通能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档