docker使用nginx反向代理springboot
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/helloOK!
碰到的问题
外部访问虚拟机的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/- 运行容器时挂载宿主机的时区
-v /etc/localtime:/etc/localtime:ro - 运行后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" - 使用DockerFile,生产上,建议有一个base_image,里面直接定义好时区等信息,后面的
from base_img构建官方镜像,DockerFile待有时间单独整理文章。
- 运行容器时挂载宿主机的时区
感受
- 咔咔咔一顿操作下来(DockerFile待深入),使用体验并没有预期的辣么爽。
- 环境一层套一层,碰到问题和疑惑也就多了一个层次,在细节效果配置时难免会碰到一些壁垒(比如nginx更复杂的配置),解决下来的时间成本不小。
- 所以,在公司或者个人开发上没有docker刚需时,不用急着整治,但是整套环境打包镜像,解决换环境又得重新安装、环境配置的烦恼还是很爽的(比如mysql)。
docker使用nginx反向代理springboot的更多相关文章
- 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器
Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...
- 使用python自动生成docker nginx反向代理配置
由于在测试环境上用docker部署了多个应用,而且他们的端口有的相同,有的又不相同,数量也比较多,在使用jenkins发版本的时候,不好配置,于是想要写一个脚本,能在docker 容器创建.停止的时候 ...
- nginx反向代理docker registry报”blob upload unknown"解决办法
问题症状:keepalived+nginx反向代理后端docker registry群集时,使用docker客户机向registry push镜像时出现 "blob upload unkno ...
- 为docker私有registry配置nginx反向代理
公司的Docker私有registry已经搭建好了,用官方的registry image很容易就搭建好了.现在就是要用nginx的反向代理把它放出来,以便在外网可以访问. 我的上一篇blog 讲了如何 ...
- docker,构建nginx反向代理tomcat
Nginx实现负载均衡是通过配置nginx.conf来实现的,nginx.conf的全部内容如下: user nginx; worker_processes 1; error_log /var/log ...
- Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)
上一节演示如何安装Docker,链接:Docker学习笔记之-在CentOS中安装Docker 本节演示 将.net core 3.1 部署到docker容器当中,并使用 Nginx反向代理,部署平台 ...
- nginx反向代理部署springboot项目报404无法加载静态资源
问题:nginx反向代理部署springboot项目报404无法加载静态资源(css,js,jpg,png...) springboot默认启动端口为8080,如果需要通过域名(不加端口号)直接访问s ...
- nginx 反向代理及 https 证书配置
nginx 反向代理及 https 证书配置 author: yunqimg(ccxtcxx0) 1. 编译安装nginx 从官网下载 nginx源码, 并编译安装. ./configure --pr ...
- Nginx反向代理访问内网服务器
Nginx反向代理访问内网服务器 问题描述 公司给配的台式机太垃圾了,不能访问外部网络就算了,还没有maven私服.近期项目不光得使用maven还得使用内网中的数据库之类,台式机太卡只能用自己的笔 ...
随机推荐
- linuk下proftpd安装
Linux下Proftpd安装与配置 1.下载 下载地址:ftp://ftp.proftpd.org/distrib/source/proftpd-1.3.6rc1.tar.gz 文件下载到/soft ...
- 解决Vuex持久化插件-在F5刷新页面后数据不见的问题
页面刷新后,想保存页面未保存的数据.我们总是习惯于放在浏览器的sessionStorage和localStorage中.但是用了vue后,vuex便可以被应用了. vuex优势:相比sessionSt ...
- .net持续集成sonarqube篇之 sonarqube与jenkins集成(插件模式)
系列目录 Jenkins通过插件集成Sonarqube 通过上一节我们了解了如何配置以使jenkins ci环境中可以执行sonarqube构建,其实Sonarqube官方也提供了jenkins插件以 ...
- SPFA队列优化
spfa队列优化(用来求最短路) 实现方法: 1.存入图.可以使用链式前向星或者vocter. 2.开一个队列,先将开始的节点放入. 3.每次从队列中取出一个节点X,遍历与X相通的Y节点,查询比对 ...
- Python开发异步任务Celery的使用教程!
1. 生产者消费者设计模式 最常用的解耦方式之一,寻找中间人(broker)搭桥,保证两个业务没有直接关联.我们称这一解耦方式为:生产者消费者设计模式 2.中间人broker 示例:此处演示Redis ...
- NLP(十三)中文分词工具的使用尝试
本文将对三种中文分词工具进行使用尝试,这三种工具分别为哈工大的LTP,结巴分词以及北大的pkuseg. 首先我们先准备好环境,即需要安装三个模块:pyltp, jieba, pkuseg以及L ...
- JS节流和防抖函数
一. 实现一个节流函数 // 思路:在规定时间内只触发一次function throttle (fn, delay) { // 利用闭包保存时间 let prev = Date.now() re ...
- HackBar收费版绕过
一段时间没用HackBar,近期做渗透,打开火狐浏览器,按F12键调出HackBar,发现居然需要收费买license才能使用. 经过研究,整理了以下两个绕过HackBar收费版的方法. 第一种:用其 ...
- 【Java例题】7.5 文件题2-学生成绩统计
5.学生成绩统计.已有一个学生成绩文件,含有多位学生的各三门课的成绩:读取这个文件中的每位学生的三门课成绩,然后计算均分:最后对这些均分按照大于或小于75分的界限,分别写到另两个文件中. packag ...
- 暴风雨中的 online :.net core 版博客站点遭遇的高并发问题进展
今天暴风雨袭击了杭州,而昨天暴风雨(高并发问题)席卷了园子,留下一片狼藉. 在前天傍晚,我们进行了 .net core 版博客站点的第二次发布尝试,在发布后通过 kestrel 直接监听取代 ngin ...