随笔 - 576  文章 - 3  评论 - 12640  1

背景:

上一篇:ASP.Net Core on Linux (CentOS7) 共享第三方依赖库部署

已经交待了背景,这篇就省下背景了。

折腾的过程分两步:

第一步是:本机跑虚拟机部署试一下;

第二步是:买了个云服务器部署了上去。

折腾完,感觉DotNetCore,虽然普及率不高,但整体还算是比较成熟了。

下面,就和大伙分享一下这两步的过程及遇到的坑吧,让大伙也方便进入NetCore的世界。

 

测试环境跑:ASPNETCore on Linux(CentOS7)步骤:

1:下载:虚拟机VMware、CentOS7系统

VMware 下载地址:https://www.cr173.com/soft/81088.html

CentOS7 下载地址:https://www.centos.org/download/

为什么选CentOS7?

主要是上各大云平台,看他们提供最多的Linux版本就是这个了,比较大众化。

地址里有两个版本:DVD ISO (全家桶版本)和 Min ISO(最小版本)

为了避免麻烦,下载了DVD版本。

2:安装:VMware Workstation

如果是第一次安装:应该没啥情况好说。

如果是二次安装,如我的情况比较坑:

以前装了好多年的,重新运行时,发现要重新输入注册码。

于是网上找了几个注册码重新输入,结果不管用哪个码,都无效,甚至下载了注册机,都过不去了。

最后,想到重新安装,却连重新安装都提示无法安装。

解决方法:把注册表里和WMware相关的项都删除了,再重新安装,安装过程输入注册码就可以了。

在“运行”输入:regedit 打开 HKEY_LOCAL_MACHINE 选择 SOFTWARE找到VMware的键。删除即可。

之后就可以重新安装了,再输入注册码就正常了。

3:安装:CentOS7系统

按着别人的教程,以为安装的没界面的版本,没想到装完也是带KDE界面的。

找了两篇:

https://www.cnblogs.com/wcwen1990/p/7630545.html

http://baijiahao.baidu.com/s?id=1599601257937774752&wfr=spider&for=pc

我遇到的坑是:安装完后,界面就黑屏了,一直进不去。

解决方法:是BIOS的设置虚拟化没开(笔记本开机时的BIOS曾经重置到默认过)

https://blog.csdn.net/weixin_41196185/article/details/79574494

接下来,你需要熟悉一下Linux系统,先了解一下 Linux目录结构

为了少点折腾,直接先用root账号玩吧,新创建的普通账号根本玩不来。

4:安装:NET Core SDK

跟着微软的教程走:https://www.microsoft.com/net/learn/get-started/linuxcentos

其中一条:sudo yum update 这条更新系统组件(可选,200M左右,看网络是否方便)

哥当时网络差,结果这一步卡了1个多小时,结果还失败了,后来直接跳过它了。

5:发布部署并运行:Taurus.MVC 项目和 Aries 项目。

你可以在GitHub上下载 Taurus.MVC 的源码项目,运行:Taurus.MVC_NetCore.sln 然后右键发布。

由于当年VS2017装的比较早,发布的选项里是木有:部署模式 的。

现在在VS 2017 的 视图-通知 菜单里,升级了一下,才有这东西。

如果是运行自己的项目,注意发布前,需要提前设置好要监听的端口:

public class Program
    {
        public static void Main(string[] args)
        {
            BuildWebHost(args).Run();
        }

        public static IWebHost BuildWebHost(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
                .UseStartup<Startup>()
                .UseUrls(GetUrl())
                .Build();
        public static string GetUrl()
        {
            string url = AppConfig.GetApp("Host", "[http|https]://*:8888");//这里弄成了可以配置的形式,不配置默认就是8888端口
            return url;
        }
    }

我在/home/目录下创建了web目录,如:

 

/home/web/taurus/

/home/web/aries/

将发布后的目录下的所有东西,包括100多个Microsoft.XXXX.dll,都复制粘贴到taurus目录或aries目录下。

当然,你也可以参考上一篇文章,将第三方的dll移到单独的目录去。

在虚拟机中有界面可以直接复制粘贴,所以暂时也不用搞ssh的工具和ftp了。

这里你得会基本的linux命令,cd  切换目录总得会:

切到项目目录,如 cd /home/web/taurus/

然后运行:

dotnet Taurus.View.dll (program.cs所在的dll名称)

PS:按Ctrl+C 可退出程序

现在可以用:http://ip:8888 访问了。

我这里遇到的坑:

提示找不到:libuv库

百度半年无所得,后来看到runtime目录,里面发现linux-64目录下有libuv.so,把它给copy到根目录,才运行起来。

PS:VS 2017 升级后,再发布时会自动把libuv.so给弄到根目录。

6:安装: Ngnix

默认 dotnet xxx.dll 运行的是 kestrel 服务器,不支持域名绑定,所以得弄一个支持域名绑定的来配合一下。

而这个支持负载均衡的反向代理服务器,简单又实用,大伙都爱用它。

网上有些很复杂的教程坑死人:

就是下载源码,然后运行编绎的那些教程,结果我照着运行编绎,结果报错了,然后一脸朦B。

在坑里转了半天,最后找到一个最简单的,就两行命令:

1、添加Nginx到YUM源,添加CentOS 7 Nginx yum资源库,打开终端,使用以下命令:

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

2、安装Nginx,在你的CentOS 7 服务器中使用yum命令从Nginx源服务器中获取来安装Nginx:

sudo yum install -y nginx

Nginx将完成安装在你的CentOS 7 服务器中。

3、启动Nginx,刚安装的Nginx不会自行启动。运行Nginx:

sudo systemctl start nginx.service

直接输入本机IP,默认80端口,即可访问,看到Welcome...。

参考:https://blog.csdn.net/u012486840/article/details/52610320

7、关闭Selinux

关闭本地IP自循环的这个限制,Ngnix才能指向Kestrel服务器,不然会报以下错:

502 Bad gateway错误

打开文件:/etc/selinux/config,把SELINUX=enforcing 改成如下的disabled

# This file controls the state of SELinux on the system.
# SELINUX= can take one of these three values:
#     enforcing - SELinux security policy is enforced.
#     permissive - SELinux prints warnings instead of enforcing.
#     disabled - No SELinux policy is loaded.
SELINUX=disabled
# SELINUXTYPE= can take one of three two values:
#     targeted - Targeted processes are protected,
#     minimum - Modification of targeted policy. Only selected processes are protected. 
#     mls - Multi Level Security protection.
SELINUXTYPE=targeted

改完保存,要重启才能生效,可是哥不想重启,找了半年也没找到可以有即时生效的命令,坑啊。

后来找到另一个方法,把Ngnix加入Selinux的白名单,就不用关它了。

运行以下三条命令就好了:

yum install policycoreutils-python
cat /var/log/audit/audit.log | grep nginx | grep denied | audit2allow -M mynginx
semodule -i mynginx.pp

8:Nginx配置网站:

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;
}

不过这个文件可以不用动,因为它的服务配置include 指向了/etc/nginx/conf.d/*.conf。

所以,只要在conf.d目录下创建自己的网站配置文件即可,可以把default.conf 移除或改个后缀先:

然后新建:taurus.conf 的配置(这里少了三个基本的配置:Domain替换、负载均衡、动静分离,在下一篇介绍):

server {
    listen       80;
    server_name  mvc.taurus.cyqdata.com;//绑定域名
location / { proxy_pass http://localhost:8888/;//跳转地址 proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;    proxy_set_header Cookie $http_cookie; } #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } }

接着,刷新配置即可:

nginx -s reload

访问效果:

总结:

进入NetCore的世界:

1、NetCore的技术学习成本还算是比较低的:

因为Taurus和Aries在window和linux的开发方式和代码都是同一套,

根本不需要学习NetCore下的MVC、EF以及一大堆有的没的消费时间。

2、整体的学习成本,更多的还是熟悉Linux系统及命令行花的时间多。

Aries on CentOS7:mvc.aries.cyqdata.com

Taurus on CentOS7:mvc.taurus.cyqdata.com

下一篇,介绍正式往服务器上部署的过程。

 

posted on 2019-03-18 14:35  路过秋天  阅读(...)  评论(...编辑  收藏
路过秋天