docker运行nginx容器

快速安装运行

  • docker-hub文档

    https://hub.docker.com/_/nginx
  • 拉取nginx1.6.0 docker pull nginx:1.16.0
  • 快速运行 docker run --name mynginx -d -p 80:80 ae893c58d83f
  • 外部访问80端口验证

关键文件目录挂载

  • 进入容器内部查看配置目录 docker exec -it mynginx /bin/bash

    默认的关键目录位置:

    • 主(配置)目录 /etc/nginx
    • 页面目录 /usr/share/nginx/html
    • 日志目录 /var/log/nginx
  • 新运行容器,挂载上面目录容器数据卷
    docker run --name mynginx -d -p 80:80 \
    -v /usr/local/dcv/nginx/html:/usr/share/nginx/html \
    -v /usr/local/dcv/nginx/conf:/etc/nginx \
    ae893c58d83f
  • 运行失败:

    本地fs有挂载目录,但是 docker ps 没有记录。

    查看容器运行日志 docker logs mynginx :

    2019/09/05 03:03:46 [emerg] 1#1: open() "/etc/nginx/nginx.conf" failed (2: No such file or directory)

    nginx: [emerg] open() "/etc/nginx/nginx.conf" failed (2: No such file or directory)

    容器内目录原有的东西被外部fs同步覆盖清空了..=_=

  • 解决:先从容器拷贝出需要的信息,然后子目录挂载
    • 先简单运行一个容器,从其中拷贝出配置文件和页面的目录文件
      //运行容器
      docker run --name mynginx -d -p 80:80 ae893c58d83f
      docker ps
      //本地fs建立相关目录
      mkdir -p /usr/local/dcv/nginx/conf
      mkdir -p /usr/local/dcv/nginx/html
      mkdir -p /usr/local/dcv/nginx/log
      //从容器内copy文件和目录到宿主机
      docker cp mynginx:/etc/nginx/nginx.conf /usr/local/dcv/nginx/conf
      docker cp mynginx:/etc/nginx/conf.d /usr/local/dcv/nginx/conf
      docker cp mynginx:/usr/share/nginx/html /usr/local/dcv/nginx
      docker cp mynginx:/var/log/nginx /usr/local/dcv/nginx/log
      //移动外部日志目录
      cp -rf $(pwd)/log/nginx/* $(pwd)/log
      rm -rf $(pwd)/log/nginx
    • 重新挂载运行
      docker rm -f mynginx
      //新挂载运行一个容器
      docker run --name mynginx -d -p 80:80 \
      -v /usr/local/dcv/nginx/html:/usr/share/nginx/html \
      -v /usr/local/dcv/nginx/log:/var/log/nginx \
      -v /usr/local/dcv/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
      -v /usr/local/dcv/nginx/conf/conf.d:/etc/nginx/conf.d \
      ae893c58d83f
      //验证
      docker ps
    • 宿主机修改index.html 外部访问81验证效果

nginx容器代理宿主机的springboot服务(即tomcat)

简单的springboot包

  • 新建一个极简的springboot应用,只有一个/hello接口返回JSON串,其他默认
    @RestController
    public class HellowCtrller {
    @ResponseBody
    @RequestMapping("/hello")
    public String hello() {
    return "hello docker @" + LocalDateTime.now();
    }
    }
  • cmd到pom.xml目录,mvn package 打jar包,上传宿主机hello.jar
  • 宿主机运行hello.jar nohup java -jar hello-0.0.1-SNAPSHOT.jar &
  • 宿主机8080访问验证 curl http://localhost:8080/hello,OK

nginx代理配置

  • nginx容器内访问宿主机ip的问题

    • 直接在nginx容器内配置localhost:8080是访问不到外部tomcat的
    • 因为nginx容器有自己的ip,外部使用 docker inspect mynginx可以看到如下信息:
      "Gateway": "172.17.0.1",
      "GlobalIPv6Address": "",
      "GlobalIPv6PrefixLen": 0,
      "IPAddress": "172.17.0.2",
      "IPPrefixLen": 16,
      "IPv6Gateway": "",
      "MacAddress": "02:42:ac:11:00:02",
      "Networks": {
      "bridge": {
      "IPAMConfig": null,
      "Links": null,
      "Aliases": null,
      "NetworkID": "77b4c6b988b085d697f896ec4d19493294c0296dc99e20e6492b2cf79d7a6682",
      "EndpointID": "3933c9ccb7de29d19d82247bd1c0b4a5ed971e505fdce4455acb0df3d48a64b1",
      "Gateway": "172.17.0.1",
      "IPAddress": "172.17.0.2",
      "IPPrefixLen": 16,
      "IPv6Gateway": "",
      "GlobalIPv6Address": "",
      "GlobalIPv6PrefixLen": 0,
      "MacAddress": "02:42:ac:11:00:02",
      "DriverOpts": null
      }
      }
    • 其中的IPAddress就是容器自己的ip,Gateway则是外部docker安装是产生的虚拟网关docker0,外部使用 ip addr可以看到。
    • 通过docker0的地址(即上面Gateway地址),容器内可以访问宿主机
    • docker0网关的地址值在Linux上一般是固定的172.17.0.1,Mac系统则不同,移植时需要注意下。
  • 修改/usr/local/dcv/nginx/conf/conf.d下的 default.conf
    #后端负载集群
    upstream hello_server {
    ip_hash; #session绑定节点
    server 172.17.0.1:8080 weight=1;
    #server 172.17.0.1:8081 weight=1;
    #keepalive 100; #for长连接
    }
    server {
    listen 80;
    server_name localhost; #charset koi8-r;
    #access_log /var/log/nginx/host.access.log main; location / {
    root /usr/share/nginx/html;
    index index.html index.htm;
    } location /api/ {
    proxy_pass http://hello_server/;
    #for 后端获取远程客户端真实ip
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    #自定义添加header
    #proxy_set_header applicationto blog;
    #proxy_http_version 1.1; #for后端返回状态拦截 >> 后端404自定义错误页面
    #proxy_intercept_errors on;
    }
    #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容器内验证配置+重启
    docker exec -t mynginx nginx -t
    docker exec -t mynginx nginx -s reload
  • 外部访问验证 curl http://localhost/api/hello

nginx容器代理springboot容器服务

制作springboot镜像运行

  • 简单的DockerFile文件(为方便名字就叫DockerFile)
    FROM java:8
    add hello-0.0.1-SNAPSHOT.jar app.jar
    expose 8080
    entrypoint ["java","-jar","/app.jar"]
  • build该文件为镜像 hello_img docker build -t hello_img .
  • 运行两个hello容器 端口分别8080和8081
    docker run -d --name hello1 -p 8080:8080 hello_img
    docker run -d --name hello2 -p 8081:8080 hello_img
  • 访问两个hello容器服务
    curl http://localhost:8080/hello
    curl http://localhost:8081/hello

nginx配置代理访问hello容器

  • 运行nginx容器时使用 docker run 的--link参数传递hello容器ip
  • 重新运行mynginx容器
    //停掉
    docker stop mynginx
    docker rm mynginx
    //加--link运行
    docker run --name mynginx \
    --link=hello1:hello1ip --link=hello2:hello2ip \
    -v /usr/local/dcv/nginx/html:/usr/share/nginx/html \
    -v /usr/local/dcv/nginx/log:/var/log/nginx \
    -v /usr/local/dcv/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
    -v /usr/local/dcv/nginx/conf/conf.d:/etc/nginx/conf.d \
    -p 80:80 -d ae893c58d83f
    //查看
    docker ps
  • 修改 default.conf 中的后端负载集群配置
    upstream hello_server {
    ip_hash; #session绑定节点
    server hello1ip:8080 weight=1;
    server hello2ip:8081 weight=1;
    #keepalive 100; #for长连接
    }
  • 验证重启nginx
    docker exec -t mynginx nginx -t
    docker exec -t mynginx nginx -s reload
  • 外部访问验证 curl http://localhost/api/hello OK!

碰到的问题

外部访问虚拟机的springboot8080端口

关掉防火墙:

直接关闭防火墙: systemctl stop firewalld.service

禁止firewall开机启动: systemctl disable firewalld.service

重启docker(不然后面可能有问题):systemctl restart docker

容器内无法使用ping

apt-get update

apt install iputils-ping #for ping

//apt install net-tools #for ifconfig

容器中nginx访问日志问题

  • docker logs mynginx 命令 stdout 出来的时间不对
  • 原因:原生容器系统的时区为0时期,而国内系统为东八区,相差8小时
  • 其他容器估计也会有这个问题
  • 解决,关键要使容器时区和宿主机一致

    主参考:https://blog.lqdev.cn/2018/07/15/docker/docker-time-diff/

    1. 运行容器时挂载宿主机的时区 -v /etc/localtime:/etc/localtime:ro
    2. 运行后cp宿主机的时区到容器 docker cp /etc/localtime mynginx:/etc/localtime

      执行出错=_=:具体原因还不知道,应该是容器内已经有的文件/夹不能通过docker cp覆盖。。还是使用第一种挂载吧

      Error response from daemon: Error processing tar file(exit status 1): invalid symlink "/usr/share/zoneinfo/UCT" -> "../usr/share/zoneinfo/Asia/Shanghai"
    3. 使用DockerFile,生产上,建议有一个base_image,里面直接定义好时区等信息,后面的from base_img构建官方镜像,DockerFile待有时间单独整理文章。

感受

  • 咔咔咔一顿操作下来(DockerFile待深入),使用体验并没有预期的辣么爽。
  • 环境一层套一层,碰到问题和疑惑也就多了一个层次,在细节效果配置时难免会碰到一些壁垒(比如nginx更复杂的配置),解决下来的时间成本不小。
  • 所以,在公司或者个人开发上没有docker刚需时,不用急着整治,但是整套环境打包镜像,解决换环境又得重新安装、环境配置的烦恼还是很爽的(比如mysql)。

docker使用nginx反向代理springboot的更多相关文章

  1. 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器

    Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...

  2. 使用python自动生成docker nginx反向代理配置

    由于在测试环境上用docker部署了多个应用,而且他们的端口有的相同,有的又不相同,数量也比较多,在使用jenkins发版本的时候,不好配置,于是想要写一个脚本,能在docker 容器创建.停止的时候 ...

  3. nginx反向代理docker registry报”blob upload unknown"解决办法

    问题症状:keepalived+nginx反向代理后端docker registry群集时,使用docker客户机向registry push镜像时出现 "blob upload unkno ...

  4. 为docker私有registry配置nginx反向代理

    公司的Docker私有registry已经搭建好了,用官方的registry image很容易就搭建好了.现在就是要用nginx的反向代理把它放出来,以便在外网可以访问. 我的上一篇blog 讲了如何 ...

  5. docker,构建nginx反向代理tomcat

    Nginx实现负载均衡是通过配置nginx.conf来实现的,nginx.conf的全部内容如下: user nginx; worker_processes 1; error_log /var/log ...

  6. Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)

    上一节演示如何安装Docker,链接:Docker学习笔记之-在CentOS中安装Docker 本节演示 将.net core 3.1 部署到docker容器当中,并使用 Nginx反向代理,部署平台 ...

  7. nginx反向代理部署springboot项目报404无法加载静态资源

    问题:nginx反向代理部署springboot项目报404无法加载静态资源(css,js,jpg,png...) springboot默认启动端口为8080,如果需要通过域名(不加端口号)直接访问s ...

  8. nginx 反向代理及 https 证书配置

    nginx 反向代理及 https 证书配置 author: yunqimg(ccxtcxx0) 1. 编译安装nginx 从官网下载 nginx源码, 并编译安装. ./configure --pr ...

  9. Nginx反向代理访问内网服务器

    Nginx反向代理访问内网服务器 问题描述 ​ 公司给配的台式机太垃圾了,不能访问外部网络就算了,还没有maven私服.近期项目不光得使用maven还得使用内网中的数据库之类,台式机太卡只能用自己的笔 ...

随机推荐

  1. linuk下proftpd安装

    Linux下Proftpd安装与配置 1.下载 下载地址:ftp://ftp.proftpd.org/distrib/source/proftpd-1.3.6rc1.tar.gz 文件下载到/soft ...

  2. 解决Vuex持久化插件-在F5刷新页面后数据不见的问题

    页面刷新后,想保存页面未保存的数据.我们总是习惯于放在浏览器的sessionStorage和localStorage中.但是用了vue后,vuex便可以被应用了. vuex优势:相比sessionSt ...

  3. .net持续集成sonarqube篇之 sonarqube与jenkins集成(插件模式)

    系列目录 Jenkins通过插件集成Sonarqube 通过上一节我们了解了如何配置以使jenkins ci环境中可以执行sonarqube构建,其实Sonarqube官方也提供了jenkins插件以 ...

  4. SPFA队列优化

    spfa队列优化(用来求最短路) 实现方法: 1.存入图.可以使用链式前向星或者vocter. 2.开一个队列,先将开始的节点放入. 3.每次从队列中取出一个节点X,遍历与X相通的Y节点,查询比对   ...

  5. Python开发异步任务Celery的使用教程!

    1. 生产者消费者设计模式 最常用的解耦方式之一,寻找中间人(broker)搭桥,保证两个业务没有直接关联.我们称这一解耦方式为:生产者消费者设计模式 2.中间人broker 示例:此处演示Redis ...

  6. NLP(十三)中文分词工具的使用尝试

      本文将对三种中文分词工具进行使用尝试,这三种工具分别为哈工大的LTP,结巴分词以及北大的pkuseg.   首先我们先准备好环境,即需要安装三个模块:pyltp, jieba, pkuseg以及L ...

  7. JS节流和防抖函数

    一. 实现一个节流函数 // 思路:在规定时间内只触发一次function throttle (fn, delay) {  // 利用闭包保存时间  let prev = Date.now()  re ...

  8. HackBar收费版绕过

    一段时间没用HackBar,近期做渗透,打开火狐浏览器,按F12键调出HackBar,发现居然需要收费买license才能使用. 经过研究,整理了以下两个绕过HackBar收费版的方法. 第一种:用其 ...

  9. 【Java例题】7.5 文件题2-学生成绩统计

    5.学生成绩统计.已有一个学生成绩文件,含有多位学生的各三门课的成绩:读取这个文件中的每位学生的三门课成绩,然后计算均分:最后对这些均分按照大于或小于75分的界限,分别写到另两个文件中. packag ...

  10. 暴风雨中的 online :.net core 版博客站点遭遇的高并发问题进展

    今天暴风雨袭击了杭州,而昨天暴风雨(高并发问题)席卷了园子,留下一片狼藉. 在前天傍晚,我们进行了 .net core 版博客站点的第二次发布尝试,在发布后通过 kestrel 直接监听取代 ngin ...