CentOS 7.4 下 如何部署 AspNetCore 结合 consul

      上篇我们讲到consul的概念,以及在WIN下如何使用:http://www.cnblogs.com/szlblog/p/9162557.html

步骤如下:

1、安装虚拟机VM

2、下载安装 CentOS 7.4(地址就不提供了)

    这是安装示例: VM虚拟机安装CentOS 示例  https://www.jb51.net/article/108088.htm

 

3、配置网络环境(确保网络通)

4、下载安装dotnet 运行环境

  4.1注册Microsoft密钥、注册产品存储库和安装所需的依赖项:每个机器执行一次

    执行命令如下:

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

    如下图所示

    

  4.2、安装.net SDK            

    执行命令如下:

    # sudo yum install dotnet-sdk-2.1  你想用哪个版本就换成哪个版本

    如下图所示

    

  4.3、查看是否安装成功:       

    执行命令如下:

    # dotnet –version

    如下图所示

    

5、把我们在windows下创建的项目生成发布上传到Linux

   操作步骤如下:

  5.1把项目生成发布:

     

  5.2、找到发布的文件夹打包成ZIP格式的压缩文件

    

  5.3、下载安装一个工具(哪种都行我用的是Xftp 5)用来上传文件到Linux中

  5.4、进行项目发布压缩包上传:        

    上传之前:我先使用命令创建了一个文件夹:命令如下:  

    # mkdir ~/AspNetCore

    开始上传:如下图

    

  5.5、执行命令解压:

    解压命令:# unzip /root/AspNetCore/MyFrameworkCore.zip

    如下图所示:

     

  5.6、在当前解压的文件夹下运行项目

    如下图所示:

    

    5.7我们来运行一下查看结果如下:

    

6、在Linux下安装Consul 

  6.1下载Linux版本的consul

    上篇 文章开始时我们提供过地址:

   

  6.2、发送到Linux中进行安装

   1):这是第一种方法:

     

  2):第二种方法:命令下载:

    执行命令:Wget https://releases.hashicorp.com/consul/1.1.0/consul_1.1.0_linux_amd64.zip

     

  6.3、解压文件:命令解压

    执行命令:# unzip consul_1.1.0_linux_amd64.zip

    如图所示

    

  6.4、运行启动consul :命令运行

    执行命令:  ./consul  可以查看版本

    如图:

     

    执行命令: ./consul agent -dev 开发者运行

     

   6.5、页面访问:地址为 127.0.0.1:8500

    结果如图所示:

     

   6.6、我们通过命令行在运行项目注册服务

    因为我们的端口是通过命令行去读取的所以需要我们 在命令行中需要输入相关命令

    命令行如下:

    

    注意如果我们在运行项目的时候一定要启动Consul

     

7、安装配置守护进程: 

    安装守护进程的意义:为了在我们退出命令界面的时候使我们的网站继续运行,就比如我们在VS中运行项目一样,当VS停止运行的时候,项目也就无法运行了

  7.1、安装 Supervisor 

    官方文档了解更多:http://supervisord.org/

    为什么选择用这个去做:因为微软官方推荐

    执行命令进行下载:  Supervisor 

    yum install python-setuptools

    

  7.2、进行安装

    执行命令:安装

    命令:easy_install supervisor

    

  7.3、查看 Supervisor 配置文件

    输入命令:echo_supervisord_conf

    结果如下:

    

     我们可以在终端的输出的信息中最后一行看到如下图所示:

    

    在这句话是我们需要替换一下新增也行:目的是为了方便读取我们的配置文件:首先我们创建一个文件夹:移动  echo_supervisord_conf 文件

    命令如下:mkdir /etc/supervisor

    

  7.4、移动命令文件到新建文件夹中

    执行命令:echo_supervisord_conf > /etc/supervisor/supervisord.conf

    如下图所示

    

  7.5、新增配置:在/etc/supervisor/supervisord.conf中

    注意 不要加 ; 空格

    添加内容: [include]files=conf.d/*.conf

    执行命令:vim /etc/supervisor/supervisord.conf

    内容如下图所示:

    

  7.6、新建配置文件添加配置信息

    新建文件夹命令:mkdir conf.d

    切换到文件夹下:cd conf.d

    新建配置文件命令:touch AspNetCore.conf

    打开编译配置文件命令:vim AspNetCore.conf

    如图所示:新加配置信息:

    

    注释如下:注释一定要去掉

   

  7.7、重新加载配置信息:/etc/supervisor/supervisord.conf

    方法一:sudo supervisorctl shutdown && sudo supervisord -c /etc/supervisor/supervisord.conf

    这里启动的时候已经在运行了我们的私有配置:因为配置文件中我们加入了  [include]files=conf.d/*.conf

    

    方法二:

    #停止: sudo service supervisor stop

    #启动:sudo service supervisor start

  7.8、运行结果:

    当 supervisor重新启动的时候我们的配置已经生效了

    1)、首先我们访问一下我们通过配置文件启动的站点:

    

    2)、在查看我们的consul中是注册了服务

    

 

  有关 supervisorctl的一些简单命令:

    supervisorctl stop project停止某一个进程(programxxx)

    supervisorctl start project:启动某个进程

    supervisorctl restart project:重启某个进程

    supervisorctl stop groupworker:重启所有属于名为groupworker的进程

    supervisorctl stop all:停止全部进程

    supervisorctl reload:重新载入配置文件

    supervisorctl update:修改某个进程:

 8、安装Negix

   

  8.1、首先我们需要安装PRCE

  意义:PCRE 作用是让 Nginx 支持 Rewrite 功能,因为nginx rewrite依赖于PCRE库

     执行命令下载

            wget http://downloads.sourceforge.net/project/pcre/pcre/8.35/pcre-8.35.tar.gz

            结果如下:

    

    

  在SRC文件夹下 输入命令 ll 进行查看我们可以看到下载结果

   执行解压命令:tar zxvf pcre-8.35.tar.gz  解压如下图所示

  

 

  8.2、进行PCRE安装:

  在我们解压的时候,可以看到我们的解压目录是:pcre-8.35 切换到该目录 下进行安装:具体步骤如下

  1)、执行命令切换目录:cd ./pcre-8.35 

  注意:当你找不到文件路径的时候使用 find -name 文件名称进行查找

  结果如下:

  

  

  2)、执行安装命令进行安装:

  命令:./configure

  结果如下

  

     执行命令:make && make install

          命令完成后,PCRE完成安装

         查看版本命令:pcre-config --version

 8.3Negix下载安装:

 

  1)、执行命令下载:

  wget http://nginx.org/download/nginx-1.6.2.tar.gz

   这个版本想换掉就更改一下版本

   

  2)、执行命令解压:

  命令:tar zxvf nginx-1.6.2.tar.gz

      结果如下:

   

  3)、进行安装

    执行命令:

    ./configure

      命令最后会输出我们Nginx的路径,日志等文件信息

    

  然后执行:make

   最后是:make install

       查看版本:/usr/local/nginx/sbin/nginx -v

  

  

  4)、启动的时候,注意切换到我们的Nginx目录下

       输入命令:cd /usr/local/nginx/sbin

       输入启动命令: ./nginx

       如图所示:

    

              这里配置文件所在目录,请看第 4)、小节点进行安装时的输出(截图中有) 

   5)、如何查看我们的安装结果

         命令行运行:curl http://127.0.0.1 结果如下

    

    在浏览器中查看:

     

  6)、有关Nginx的配置

    命令打开配置文件:

     

  

    具体配置信息如下:

               我们把cunsul的注册到配置中

   server {

                    listen      0.0.0.0:10000;

                    server_name  szlconsul.com;

              location / {

                    proxy_pass http://localhost:8500;

                    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;

                 }

  8)、重新加载Nginx配置

    切换到配置目录下

    执行命令:.nginx -s reload 重新加载

    执行命令:.nginx -s reopen 重新打开

    执行命令:.nginx -s stop   关闭

    

    运行结果:如下图所示;

    

 

 

9、开放centos 的端口外部访问:

  我们要保证虚机的端口是可以被外部访问的,因为Linux系统对我来说很陌生,在使用的过程中,都是要学,有时候一个命令我就要查询很多的资料,中间收货确实不小,建议每一个初接触Linux的千万不要别人给个命令咱逮住就用,万一命令是删除什么的就不好了,  保持谨慎。

  在张善友老师整理 文档中我们也可以看出大佬对命令的态度:张老师整理文档地址

  Github: https://github.com/geffzhang/opendotnet 

 

  1.1、:关闭firewall 防火墙:(7.0以后都是firewall

        为什么关闭firewall防火墙

  1)在使用Docker时,启用centos7默认的firewall,启动端口映射时,防火墙规则不生效。docker默认使用了iptables防火墙机制。所以需要关闭firewall使用iptables解决

  2)、还有的人说是因为习惯,之前centos5  centos6使用iptables 防火墙相关规则习惯了iptables,亦或者其他的第三方软件使用防火强规则也是iptables的。

  3)、也可能是firewall没用习惯。

  4)、使用命令:

    1)、关闭firewall防火墙:

    命令:systemctl stop firewalld.service 关闭防火墙

    命令:systemctl disable firewalld.service关闭防火墙开机启动

 

    2)、安装iptables防火墙:

      命令:yum install iptables  安装

      命令:vim /etc/sysconfig/iptables

    添加配置信息:

     

    

    命令:service iptables restart 重新启动iptables 防火墙

    命令:systemctl enable iptables.service 设置防火墙开机自启

    外部运行:结果如下:

    

 

                   有不足之处 希望大家指出相互学习,

                                     本文原创:转载请注明出处 谢谢!

 

 

posted @ 2018-06-10 21:13 乐途 阅读(...) 评论(...) 编辑 收藏