centos7系统下搭建.net core2.0 nginx supervisor环境的示例-mile米乐体育

这篇文章主要介绍了centos7系统下搭建.net core2.0 nginx supervisor环境的示例,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

一、linux .net core简介

一直以来,微软只对自家平台提供.net支持,这样等于让这个“理论上”可以跨平台的框架在linux和macos上的支持只能由第三方项目提供(比如mono .net)。

直到微软推出完全开源的.net core。这个开源的平台兼容.net standard,并且能在windows、linux和macos上提供完全一致的api。虽然这个小巧的.net框架只是标准.net的一个子集,但是已经相当强大了。

一方面,这个小巧的框架可以让某些功能性应用同时运行在三个平台上(就像某些功能性的python脚本一样),另一方面,这也可以让服务器运维人员将asp .net服务程序部署在linux服务器上(特别是对于运行windows server较为吃力的服务器)。

米乐app官网登录官网参考资料:https://www.microsoft.com/net/core#linuxcentos

二、linux .net core2.0 环境部署前准备

1.环境说明:

服务器系统:centos 7.2.1511

2.安装前准备(关闭防火墙、关闭selinux)

1)关闭firewall:

systemctlstopfirewalld.service#停止firewall systemctldisablefirewalld.service#禁止firewall开机启动 firewall-cmd--state#查看默认防火墙状态(关闭后显示notrunning,开启后显示running)

2)关闭selinux

sed-i"s/selinux=enforcing/selinux=disabled/g"/etc/selinux/config

查看改后文件如下:

[root@localhost~]#cat/etc/selinux/config  #thisfilecontrolsthestateofselinuxonthesystem. #selinux=cantakeoneofthesethreevalues: #enforcing-selinuxsecuritypolicyisenforced. #permissive-selinuxprintswarningsinsteadofenforcing. #disabled-noselinuxpolicyisloaded. selinux=disabled #selinuxtype=cantakeoneofthreetwovalues: #targeted-targetedprocessesareprotected, #minimum-modificationoftargetedpolicy.onlyselectedprocessesareprotected. #mls-multilevelsecurityprotection. selinuxtype=targeted

3)重启centos

reboot

三、centos 部署.net core2.0 环境

1.添加dotnet产品

在安装.net核心之前,您需要注册微软产品提要。这只需要做一次。首先,注册微软签名密钥,然后添加微软产品提要。

rpm--importhttps://packages.microsoft.com/keys/microsoft.asc sh-c'echo-e"[packages-microsoft-com-prod]nname=packages-microsoft-com-prodnbaseurl=https://packages.microsoft.com/yumrepos/microsoft-rhel7.3-prodnenabled=1ngpgcheck=1ngpgkey=https://packages.microsoft.com/keys/microsoft.asc">/etc/yum.repos.d/dotnetdev.repo'

2.安装.net核心sdk

在下一步之前,请从您的系统中删除.net .net以前的任何预览版本。

以下命令更新用于安装的产品列表,安装.net核心所需的组件,然后安装.net核心sdk。

yumupdate yuminstalllibunwindlibicu-y yuminstalldotnet-sdk-2.0.0-y

3.检查dotnet是否安装成功与版本查看

dotnet--info dotnet--version

四、测试.net core2.0 环境

1.在home目录下初始化一个测试环境并输出”hello world “内容 (测试方式一,可忽略)

cd/home dotnetnewconsole-ohwapp cdhwapp dotnetrun

输出空内容如下:

[root@localhosthwapp]#dotnetrun helloworld!

2.上传.net core的实例页面进行测试 (测试方式二、推荐)

centos 下.net core 2 环境测试用例 (把它上传到/home目录下或自定义的目录)

下载地址:

http://down.51cto.com/data/2334968

执行以下命令

cd/home/webapplication1 dotnetrestore//如果使过用测试方式一,就需先执行这命令重新加载一下当前新的网站文件 dotnetrun

运行后如下图:

通过ie访问测试页

五、安装配置nginx对asp.net core应用的转发

1.安装nginx环境

[root@localhost~]#curl-onginx.rpmhttp://nginx.org/packages/centos/7/noarch/rpms/nginx-release-centos-7-0.el7.ngx.noarch.rpm [root@localhost~]#rpm-ivhnginx.rpm [root@localhost~]#yuminstallnginx-y

输入:systemctl start nginx 来启动nginx。

[root@localhost~]#systemctlstartnginx

输入:systemctl enable nginx 来设置nginx的开机启动(linux宕机、重启会自动运行nginx不需要连上去输入命令)

[root@localhost~]#systemctlenablenginx createdsymlinkfrom/etc/systemd/system/multi-user.target.wants/nginx.serviceto/usr/lib/systemd/system/nginx.service.

2.通过ie检查能否访问

[root@localhostnginx-1.8.1]#ps-ef|grepnginx root146261008:47?00:00:00nginx:masterprocessnginx nginx1462714626008:47?00:00:00nginx:workerprocess root146363269008:49pts/100:00:00grep--color=autonginx

nginx常用的操作命令

systemctl start nginx.service   #启动nginx服务

systemctl enable nginx.service #设置开机自启动

systemctl disable nginx.service #停止开机自启动

systemctl status nginx.service #查看服务当前状态

systemctl restart nginx.service  #重新启动服务

systemctl list-units –type=service #查看所有已启动的服务

4.防火墙配置(如果系统有防火墙就需要进行写入规则)

命令:firewall-cmd –zone=public –add-port=80/tcp –permanent(开放80端口)

命令:systemctl restart firewalld(重启防火墙以使配置即时生效)

5.配置nginx对asp.net core应用的转发

修改 /etc/nginx/conf.d/default.conf 文件。

将文件内容替换为

server{ listen80; location/{ proxy_passhttp://localhost:88; proxy_http_version1.1; proxy_set_headerupgrade$http_upgrade; proxy_set_headerconnectionkeep-alive; proxy_set_headerhost$host; proxy_cache_bypass$http_upgrade; } }

重新加载nignx

[root@localhostnginx]#nginx-sreload

nginx的配置己完成

6.开启dotnet run进行测试

[root@localhost~]#cd/home/webapplication1/ [root@localhostwebapplication1]#dotnetrun usinglaunchsettingsfrom/home/webapplication1/properties/launchsettings.json... hostingenvironment:development contentrootpath:/home/webapplication1 nowlisteningon:http://[::]:88 applicationstarted.pressctrl ctoshutdown.

通过ip 80端口访问

六、配置守护服务(supervisor)

目前存在三个问题

问题1:asp.net core应用程序运行在shell之中,如果关闭shell则会发现asp.net core应用被关闭,从而导致应用无法访问,这种情况当然是我们不想遇到的,而且生产环境对这种情况是零容忍的。

问题2:如果asp.net core进程意外终止那么需要人为连进shell进行再次启动,往往这种操作都不够及时。

问题3:如果服务器宕机或需要重启我们则还是需要连入shell进行启动。

为了解决这个问题,我们需要有一个程序来监听asp.net core 应用程序的状况。在应用程序停止运行的时候立即重新启动。这边我们用到了supervisor这个工具,supervisor使用python开发的。

1.安装supervisor

[root@localhost/]#yuminstallpython-setuptools-y [root@localhost/]#easy_installsupervisor

2.配置supervisor

[root@localhost/]#mkdir/etc/supervisor [root@localhost/]#echo_supervisord_conf>/etc/supervisor/supervisord.conf

修改supervisord.conf文件,将文件尾部的配置

[root@localhost/]#vi/etc/supervisor/supervisord.conf

将里面的最后两行:

;[include] ;files=relative/directory/*.ini

改为

[include] files=conf.d/*.conf

ps:如果服务已启动,修改配置文件可用“supervisorctl reload”命令来使其生效

3.配置对asp.net core应用的守护

创建一个 webapplication1.conf文件,内容大致如下

[root@localhost/]#viwebapplication1.conf [program:webapplication1] command=dotnetwebapplication1.dll;运行程序的命令 directory=/home/webapplication1/;命令执行的目录 autorestart=true;程序意外退出是否自动重启 stderr_logfile=/var/log/webapplication1.err.log;错误日志文件 stdout_logfile=/var/log/webapplication1.out.log;输出日志文件 environment=aspnetcore_environment=production;进程环境变量 user=root;进程执行的用户身份 stopsignal=int

将文件拷贝至:“/etc/supervisor/conf.d/webapplication1.conf”下

[root@localhost/]#mkdir/etc/supervisor/conf.d [root@localhost/]#cpwebapplication1.conf/etc/supervisor/conf.d/

运行supervisord,查看是否生效

[root@localhost/]#supervisord-c/etc/supervisor/supervisord.confsupervisord-c/etc/supervisor/supervisord.conf [root@localhost/]#ps-ef|grepwebapplication1 root2987829685009:57?00:00:00dotnetwebapplication1.dll root2989229363009:57pts/300:00:00grep--color=autowebapplication1

如果存在dotnet webapplication1.dll 进程则代表运行成功,这时候在使用浏览器进行访问。

至此关于asp.net core应用程序的守护即配置完成。

supervisor守护进程常用操作

【启动supervisord】确保配置无误后可以在每台主机上使用下面的命令启动supervisor的服务器端supervisordsupervisord

【停止supervisord】 supervisorctl shutdown

【重新加载配置文件】supervisorctl reload

七 、配置supervisor开机启动

新建一个“supervisord.service”文件

[root@localhost/]#visupervisord.service #dserviceforsystemd(centos7.0 ) #byet-cs(https://github.com/et-cs) [unit] description=supervisordaemon [service] type=forking execstart=/usr/bin/supervisord-c/etc/supervisor/supervisord.conf execstop=/usr/bin/supervisorctlshutdown execreload=/usr/bin/supervisorctlreload killmode=process restart=on-failure restartsec=42s [install] wantedby=multi-user.target

将文件拷贝至:“/usr/lib/systemd/system/supervisord.service”

[root@localhost/]#cpsupervisord.service/usr/lib/systemd/system/

执行命令:systemctl enable supervisord

[root@localhost/]#systemctlenablesupervisord createdsymlinkfrom/etc/systemd/system/multi-user.target.wants/supervisord.serviceto/usr/lib/systemd/system/supervisord.service.

执行命令:systemctl is-enabled supervisord #来验证是否为开机启动

[root@localhost/]#systemctlis-enabledsupervisord

重启系统看能否能成功访问

[root@localhost/]#reboot

感谢你能够认真阅读完这篇文章,希望小编分享的“centos7系统下搭建.net core2.0 nginx supervisor环境的示例”这篇文章对大家有帮助,同时也希望大家多多支持恰卡编程网,关注恰卡编程网行业资讯频道,更多相关知识等着你来学习!

展开全文
内容来源于互联网和用户投稿,文章中一旦含有米乐app官网登录的联系方式务必识别真假,本站仅做信息展示不承担任何相关责任,如有侵权或涉及法律问题请联系米乐app官网登录删除

最新文章

网站地图