docker实战之通过nginx镜像来部署SPA项目

docker实战之通过nginx镜像来部署SPA项目
    nginx+tomcat实现反向代理及均衡
    nginx+html静态服务器

    1.创建nginx容器
      docker run \
       --name mynginx \
       -d -p 80:80 \
       -v /data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
       -v /data/nginx/log:/var/log/nginx \
       -v /data/nginx/html:/usr/share/nginx/html \
       nginx:latest

注:需要先注释掉nginx配置文件中动态集群访问

       注1: 因为在nginx镜像中没有安装vi或vim编辑器(安装太麻烦了),无法编辑nginx配置文件,所以所有数据和配置都是通过数据卷挂载
            第一个-v:挂载nginx的主配置文件,以方便在宿主机上直接修改容器的配置文件
            第二个-v:挂载容器内nginx的日志,容器运行起来之后,可以直接在宿主机的这个目录中查看nginx日志
            第三个-v:挂载静态页面目录
            注意命令之间的换行与空格

       注2:如果容器创建失败,可通过如下命令,查看在docker容器启动日志
            docker logs -f -t --tail 行数 容器名
            docker logs -f -t --tail 100 mynginx

       注3:如果要进入容器内部,这里是bash而非sh,要根据实际的基础镜像来
            docker exec -it mynginx /bin/bash

       注4:Nginx相关命令见附录二


4.nginx.conf讲解
  1.所有配置必须以“;”结尾 
  2.nginx发布java项目
    nginx+tomcat实现反向代理及均衡
    upstream  tomcats{
      #TODO:172.17.0.3是docker容器的IP 
      server    172.17.0.3:8080  weight=1;#服务器配置   weight是权重的意思,权重越大,分配的概率越大。    
      server    172.17.0.4:8080  weight=2;
    }

    location / {
      proxy_pass http://tomcats;
      proxy_redirect default;
    }    

  3.nginx发布静态vue项目


附录一:ip地址后边加个/8(16,24,32)是什么意思?
是子网掩码的位数,由于255相当于二进制的8位11111111,所以也缩写成“/8”,表示网络号占了8位
192.168.0.1/8
A类IP地址的默认子网掩码为255.0.0.0(/8)

B类的为255.255.0.0(/16);

C类的为255.255.255.0(/24)

/30就是255.255.255.252

/32就是255.255.255.255
例如:
xx.xx.xx.0/24 ——>表示一个网段,并且24告诉了当前具体的子网掩码

举例说吧,192.168.0.0/24”就表示,这个网段的IP地址从192.168.0.1开始,到192.168.0.254结束
(192.168.0.0和192.168.0.255有特殊含义,不能用作IP地址);子网掩码是255.255.255.0

附录二: nginx.conf配置常用命令
vim /usr/local/nginx/conf/nginx.conf  # 编辑主配置文件

# 测试Nginx配置是否正确命令,先进入主程序的安装目录
cd /usr/local/nginx/conf               
/usr/local/nginx/sbin/nginx -t        # 判断Nginx配置是否正确命令
tail -100f /var/log/nginx/access.log  # 查看Nginx访问日志,必须以nginx.conf配置文件的目录一致

service nginx start                   # 启动
service nginx stop                    # 停止
service nginx restart                 # 重新启动
service nginx reload                  # 重新加载配置,平滑启动
service nginx status                  # 查看nginx状态


ps -ef | grep nginx                   # 查看Nginx安装目录,master process后面的就是nginx的目录
cd /usr/sbin                          # 进入nginx主程序的安装目录
/usr/sbin/nginx -V                    # -v 显示 nginx 的版本,本示例安装版本为:nginx version: nginx/1.14.2 (Ubuntu)
/usr/sbin/nginx -V                    # -V 显示 nginx 的版本,编译器版本和配置参数

附录三:hbuilderX打包vue项目白屏问题
将项目目录下的config文件夹里的index.js文件中,将build对象下的assetsPublicPath中的“/”,改为“./”后,再打包生成的 dist 文件


附录四:springboot中如何解决跨域访问
见:资料/CorsConfiguration.java

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值