一块儿学ASP.NET Core 2.0学习笔记(一): CentOS下 .net core2 sdk nginx、supervisor、mysql环境搭建

做为.neter,看到.net core 2.0的正式发布,内心是有点小激动的,火烧眉毛的体验了一把,发现速度确实是快了不少,其中也遇到一些小问题,因此整理了一些学习笔记:html

环境说明

服务器系统:CentOS 7.3 64位mysql

相关工具:putty、Xftplinux

服务器软件软件:.netcore、nginx、supervisor、mysqlnginx

安装CentOS7

这个就不细说了,网上教程不少,我这边是阿里云的ecs服务器,操做系统为centos 7.3 x64git

安装.NET Core SDK for CentOS7

sudo yum install libunwind libicu(安装libicu依赖)
curl -sSL -o dotnet.tar.gz https://aka.ms/dotnet-sdk-2.0.0-linux-x64 (下载sdk压缩包)
mkdir -p ~/dotnet && tar zxf dotnet.tar.gz -C ~/dotnet 解压缩)
sudo ln -s /opt/dotnet/dotnet /usr/local/bin(建立连接) 

参见官方文档, 须要注意的地方是第四行跟官方文档有点出入,这是创建链接,而官方文档的是添加path(只在当前session有效:export PATH=$PATH:$HOME/dotnet)github

,执行这些操做以前请务必卸载旧版本及预览版本(我是直接删除旧版本的文件,执行 dotnet --info 能够查看已安装版本信息),当执行dotnet --version  xianshi 2.0.0时表示安装.net core 2.0成功web

 

参考资料: https://www.microsoft.com/net/core#linuxcentossql

搭建ftp环境

安装vsftpd

一、以管理员(root)身份执行如下命令shell

  1. yum install vsftpd

二、设置开机启动vsftpd ftp服务

  1. chkconfig vsftpd on

三、启动vsftpd服务

  1. service vsftpd start

管理vsftpd相关命令:

中止vsftpd:  service vsftpd stop

重启vsftpd:  service vsftpd restart

配置防火墙

在 CentOS 7.3中

暂时开放 ftp 服务
# firewall-cmd --add-service=ftp

永久开放 ftp 服务
# firewall-cmd --add-service=ftp --permanent
永久关闭
# firewall-cmd --remove-service=ftp --permanent
success

让设定生效
# systemctl restart firewalld

添加ftp用户

下面是添加ftpuser用户,设置根目录为/home/wwwroot/ftpuser,禁止此用户登陆SSH的权限,并限制其访问其它目录(当不存在指定目录时须要建立相关目录)。

1、修改/etc/vsftpd/vsftpd.conf

vim /etc/vsftpd/vsftpd.conf

如需禁用匿名登陆把第一行的 anonymous_enable=YES ,改成NO

将底下三行

  1. #chroot_list_enable=YES
  2. # (default follows)
  3. #chroot_list_file=/etc/vsftpd.chroot_list

改成

  1. chroot_list_enable=YES
  2. # (default follows)
  3. chroot_list_file=/etc/vsftpd/chroot_list

三、增长用户farmhome,指向目录/home/wwwroot/farmhome,禁止登陆SSH权限。

useradd -d /home/wwwroot/farmhome -g ftp -s /sbin/nologin farmhome

四、设置用户口令

passwd farmhome

五、编辑文件chroot_list:

  1. vim  /etc/vsftpd/chroot_list

内容为ftp用户名,每一个用户占一行,如:

farmhome

六、从新启动vsftpd

service vsftpd restart

7.用xftp等客户端软件应该就能访问到该目录了;

安装mysql

1、官网下载mysql

# wget https://repo.mysql.com//mysql57-community-release-el7-11.noarch.rpm (去mysql官网获取最新的rpm包 https://dev.mysql.com/downloads/repo/yum/)
# rpm -ivh mysql-community-release-el7-5.noarch.rpm
# yum install mysql-community-server

安装完成后重启mysql服务

service mysqld restart
2、mysql相关配置

初次安装mysql,root帐户没有密码。

[root@yl-web yl]# mysql -u root 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.6.26 MySQL Community Server (GPL)

Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+
rows in set (0.01 sec)

mysql>

  设置密码

mysql> set password for 'root'@'localhost' =password('password');
Query OK, 0 rows affected (0.00 sec)

mysql> 

 不须要重启数据库便可生效。

mysql新建用户(用户farmhome,密码123456):

mysql>create user 'farmhome'@'%' identified by '123'; 

mysql远程链接设定(把在全部数据库的全部表的全部权限赋值给位于全部IP地址的root用户)

1 mysql> grant all privileges on *.* to root@'%'identified by 'password';                                                  

部署asp.net core

1.防火墙配置

运行、中止、禁用firewalld

启动:# systemctl start  firewalld

查看状态:# systemctl status firewalld 或者 firewall-cmd --state

中止:# systemctl disable firewalld

禁用:# systemctl stop firewalld

将接口添加到区域,默认接口都在public

# firewall-cmd --zone=public --add-interface=eth0 --permanent 

永久生效再加上 --permanent 而后reload防火墙

设置默认接口区域

# firewall-cmd --set-default-zone=public --permanent 

当即生效无需重启

打开端口

加入一个端口到区域:

# firewall-cmd --zone=public --add-port=5000/tcp --permanent 

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

查看全部打开的端口:

# firewall-cmd --zone=dmz --list-ports

2.用xftp上传程序到指定目录即上的

进入指定目录运行程序

View Code

如出现不能绑定ipv6等错误时,请修改Program.cs,添加UseUrls("http://0.0.0.0:50");

View Code

配置Nginx

安装Nginx

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

image

rpm -ivh nginx.rpm

yum install nginx

image

安装成功!

输入:systemctl start nginx 来启动nginx。

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

测试nginx是否能够访问。

image

配置nginx对ASP.NET Core应用的转发

修改  

View Code

将文件内容替换为

server {
    listen 80;
    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;
    }}

再次运行程序

donet /home/wwwroot/farmhome/famrhome.dll

如出现502错误时因为SELinux保护机制所致使,咱们须要将nginx添加至SELinux的白名单。

接下来咱们经过一些命令解决这个问题:

yum install policycoreutils-python

sudo cat /var/log/audit/audit.log | grep nginx | grep denied | audit2allow -M mynginx sudo semodule -i mynginx.pp

配置守护服务(Supervisor)

目前存在三个问题

问题1:ASP.NET Core应用程序运行在shell之中,若是关闭shell则会发现ASP.NET Core应用被关闭,从而致使应用没法访问,这种状况固然是咱们不想遇到的,并且生产环境对这种状况是零容忍的。

问题2:若是ASP.NET Core进程意外终止那么须要人为连进shell进行再次启动,每每这种操做都不够及时。

问题3:若是服务器宕机或须要重启咱们则仍是须要连入shell进行启动。

为了解决这个问题,咱们须要有一个程序来监听ASP.NET Core 应用程序的情况。在应用程序中止运行的时候当即从新启动。这边咱们用到了Supervisor这个工具,Supervisor使用Python开发的。

安装Supervisor

yum install python-setuptools

easy_install supervisor

配置Supervisor

mkdir /etc/supervisor

echo_supervisord_conf > /etc/supervisor/supervisord.conf

修改supervisord.conf文件,

 

vim  /etc/supervisor/supervisord.conf

 

将文件尾部的配置(表示加载配置文件目录下的配置文件)

image

修改成

image

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

配置对ASP.NET Core应用的守护

建立一个 farmhomeapp.conf文件

View Code

 

,内容大体以下

[program:farmhomewebapp]
command=dotnet farmhome.dll ; 运行程序的命令
directory=/home/wwwroot/farmhome/ ; 命令执行的目录
autorestart=true ; 程序意外退出是否自动重启
stderr_logfile=/var/log/WebApplication1.err.log ; 错误日志文件
stdout_logfile=/var/log/WebApplication1.out.log ; 输出日志文件
environment=ASPNETCORE_ENVIRONMENT=Production ; 进程环境变量
user=root ; 进程执行的用户身份
stopsignal=INT

运行supervisord,查看是否生效

supervisord -c /etc/supervisor/supervisord.conf

ps -ef 

如存在指定进程表示成功

至此关于ASP.NET Core应用程序的守护即配置完成。

配置Supervisor开机启动

新建一个“supervisord.service”文件

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

内容以下

# dservice for systemd (CentOS 7.0+)
# by ET-CS (https://github.com/ET-CS)
[Unit]
Description=Supervisor daemon

[Service]
Type=forking
ExecStart=/usr/bin/supervisord -c /etc/supervisor/supervisord.conf
ExecStop=/usr/bin/supervisorctl shutdown
ExecReload=/usr/bin/supervisorctl reload
KillMode=process
Restart=on-failure
RestartSec=42s

[Install]
WantedBy=multi-user.target

执行命令:systemctl enable supervisord 设定开机启动

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

本文是环境搭建完后依据记忆写的博客,可能会有错误,欢迎指正,不知不觉已经凌晨了,明天继续上asp.net core2 及EF Core Fluent API 及 EF Core for MySql 相关介绍

相关内容参考:

将ASP.NET Core应用程序部署至生产环境中(CentOS7)

 CentOS开启FTP及配置用户

centos7 mysql数据库安装和配置

相关文章
相关标签/搜索