Docker + Nginx + Tomcat 实现负载均衡

环境

[root@pinyoyougou-docker ~]# docker -v
Docker version 1.12.6, build 85d7426/1.12.6
[root@pinyoyougou-docker ~]# rpm -qi centos-release
Name : centos-release
Version : 7
Release : 3.1611.el7.centos
Architecture: x86_64
Install Date: 2017年09月03日 星期日 14时07分06秒
Group : System Environment/Base
Size : 37000
License : GPLv2
Signature : RSA/SHA256, 2016年11月30日 星期三 02时57分12秒, Key ID 24c6a8a7f4a80eb5
Source RPM : centos-release-7-3.1611.el7.centos.src.rpm
Build Date : 2016年11月30日 星期三 02时12分59秒
Build Host : c1bm.rdu2.centos.org
Relocations : (not relocatable)
Packager : CentOS BuildSystem <http://bugs.centos.org>
Vendor : CentOS
Summary : CentOS Linux release file
Description :
CentOS Linux release files

Docker 配置

2个 Tomcat 容器,1个 Nginx 容器。

[root@pinyoyougou-docker ~]# docker ps -a
IMAGE STATUS PORTS NAMES
nginx Up 40 seconds 0.0.0.0:80->80/tcp pinyougou_nginx
tomcat:7-jre7 Up 50 seconds 0.0.0.0:9002->8080/tcp pinyougou_tomcat2 # 172.17.0.2
tomcat:7-jre7 Up 46 seconds 0.0.0.0:9001->8080/tcp pinyougou_tomcat1 # 172.17.0.3

Nginx 配置

upstream tomcatserver1 {
server 172.17.0.2:8080;
server 172.17.0.3:8080;
} server {
listen 80;
server_name passport.pinyougou.com;
location / {
proxy_pass http://tomcatserver1/;
index index.html index.htm;
}
charset utf-8;
}

应用结构

[root@pinyoyougou-docker ~]# tree tomcat-webapp-2
tomcat-webapp-2
└── frblog
├── css
│   ├── blog.css
│   ├── jdreset.css
│   └── reset.css
├── img
│   ├── banner.jpg
│   ├── lion.jpg
│   ├── pic01.jpg
│   ├── pic02.jpg
│   ├── pic03.jpg
│   ├── \347\210\261\345\277\203.svg 中文名称
│   ├── \347\250\213\345\272\217.svg
│   ├── \345\220\221\344\270\212\347\256\255\345\244\264.svg
│   └── \351\222\273\347\237\263.svg
├── index.html
└── js
├── jquery-3.3.1.js
└── show.js

Bugs

502 Bad Gateway

Nginx 配置中 server 错误地使用了宿主机的地址和端口号。tomcat 在 docker 容器中,server 应该使用 tomcat 对应的 docker 容器的地址和端口。

upstream tomcatserver1 {
server 192.168.211.134:9001; # 错误, tomcat 在 docker 容器中,应该使用 docker 容器的地址和端口。
server 192.168.211.134:9002; # 错误, tomcat 在 docker 容器中,应该使用 docker 容器的地址和端口。
} server {
listen 80;
server_name passport.pinyougou.com;
location / {
proxy_pass http://tomcatserver1/;
index index.html index.htm;
}
charset utf-8;
}

刷新网页浏览器总是使用缓存

刷新网页浏览器总是使用缓存,导致无法观察到 Nginx 负载均衡的效果。需要每次刷新网页时,浏览器都向 Nginx 请求网页。

方案:ctrl + f5  强制刷新,则每次浏览器都会重新发送请求。

docker WARNING: IPv4 forwarding is disabled. 解决方法

https://blog.csdn.net/deeplearnings/article/details/81639153

# 在宿主机上面执行:
echo net.ipv4.ip_forward=1 >> /usr/lib/sysctl.d/00-system.conf # 重启network和docker服务
systemctl restart network && systemctl restart docker

tomcat nginx URL 中文地址无法解析

# 项目结构如下,其中网页可以正常打开,但是中文名称的图片资源 404 。
[root@pinyoyougou-docker ~]# tree tomcat-webapp-2
tomcat-webapp-2
└── frblog
├── css
│   ├── blog.css
│   ├── jdreset.css
│   └── reset.css
├── img
│   ├── banner.jpg
│   ├── lion.jpg
│   ├── pic01.jpg
│   ├── pic02.jpg
│   ├── pic03.jpg
│   ├── \347\210\261\345\277\203.svg 【中文图片】
├── index.html
└── js
├── jquery-3.3.1.js
└── show.js

查看 Linux 的字符集

root@c24a4d7f35bc:/usr/local/tomcat/conf# echo $LANG
C.UTF-8

1.在Nginx 的 nginx.conf 设置字符集。

server {
charset utf-8;
}

2.在 Tomcat 的 server.xml 设置字符集

<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
URIEncoding="UTF-8"/>

网页正常访问,但是总是有部分 css img js 报 404 。

原因:我被负载均衡的2个应用文件结构不一样,负载均衡将所有的请求轮询,所以造成了有些文件找不到的情况。

示例:网页访问 http://passport.pinyougou.com/frblog/index.html 。如果请求的是复杂的那个应用,则需要加载 js css img 资源。这些请求都是被轮询,如果轮询到简单应用,没有对应的资源,报 404 。

# 172.17.0.3:8080
[root@pinyoyougou-docker ~]# tree tomcat-webapp-1/frblog/
tomcat-webapp-1/frblog/
└── index.html # 172.17.0.2:8080
[root@pinyoyougou-docker ~]# tree tomcat-webapp-2
tomcat-webapp-2
└── frblog
├── css
│   ├── blog.css
│   ├── jdreset.css
│   └── reset.css
├── img
│   ├── banner.jpg
│   ├── lion.jpg
│   ├── pic01.jpg
│   ├── pic02.jpg
│   ├── pic03.jpg
│   ├── \347\210\261\345\277\203.svg 【中文图片】
├── index.html
└── js
├── jquery-3.3.1.js
└── show.js

使用 nginx 服务器对应域名访问正常,使用 nginx 服务器对应 ip 报 404 Not Found

http://192.168.211.134/frblog   报错,404 Not Found
http://passport.pinyougou.com/frblog/ 正常访问
192.168.211.134 passport.pinyougou.com # hosts 文件内容

nginx.conf 配置文件配置的是域名。所以如果 url 中使用的是 nginx 服务器的 ip 地址,而不是 nginx 服务器对应的域名时,虽然能够请求到 nginx 服务器。但是因为 url 匹配不成功不会代理。会报 404 not found 。

upstream tomcatserver1 {
server 172.17.0.2:8080;
server 172.17.0.3:8080;
} server {
listen 80;
server_name passport.pinyougou.com;
location / {
proxy_pass http://tomcatserver1/;
index index.html index.htm;
}
}

Docker + Nginx + Tomcat 实现负载均衡简单演示的更多相关文章

  1. Docker+Nginx+Tomcat实现负载均衡

    环境检测: 1.Docker没有安装的小伙伴请查看https://www.cnblogs.com/niuniu0108/p/12372531.html 2.没有创建Nginx容器的小伙伴请查看http ...

  2. 简单的 Nginx+Tomcat 配置负载均衡集群

    简单 Nginx+Tomcat 配置负载均衡集群 前期准备 解压两个tomcat,修改端口号 server1:8081 server:8082 同时启动 nginx官网下载解压版nginx 创建一个简 ...

  3. nginx+tomcat实现负载均衡以及双机热备

    还记得那些年吗? 还记得更新代码之后,服务器起不来被领导训斥吗?还记得更新代码,需要停机过多的时间被渠道部们埋怨吗?还记得更新代码,代码出错时自己吓个半死吗?于是我们聪明勤快的程序员,看着电影待到夜深 ...

  4. Ubuntu下实现Nginx+Tomcat实现负载均衡

    先说一下为什么写这个文章,在性能测试过程中,我们可能会关注很多指标,比如CPU.IO.网络.磁盘等,通过这些指标大致可以判断哪个环节遇到了性能瓶颈,但是当这些指标无法判断出性能瓶颈时,我们可能就需要对 ...

  5. Nginx+Tomcat+Memcached负载均衡集群服务搭建

    操作系统:CentOS6.5  本文档主要讲解,如何在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群服务器,Nginx负责负载均衡,Tomcat负责实际服务,Memc ...

  6. nginx+tomcat+redis负载均衡及session共享

    概述 本文档是用来详细描述 nginx+tomcat+redis负载均衡实现session共享 所需软件及下载地址 软件名称 下载地址 功能说明 Nginx-v1.6.0 http://nginx.o ...

  7. 使用 Nginx + Tomcat 搭建负载均衡

    负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽.增加吞吐量.加强网络数据处理能力.提高网络的灵活性和可用性. 负载均衡,英文名称为Load Balance, ...

  8. Nginx+Tomcat 实现负载均衡 ,动静分离集群部署

    Nginx + Tomcat 实现负载均衡,动静分离集群部署 1.Nginx实现负载均衡原理 2.Nginx配置反向代理主要参数 3.实验 1.Nginx实现负载均衡原理: Nginx服务器作为前端, ...

  9. Nginx+Tomcat搭建负载均衡

    一.       工具 nginx-1.8.0 apache-tomcat-6.0.33 二.    目标 实现高性能负载均衡的Tomcat集群: 三.    步骤 1.首先下载Nginx,要下载稳定 ...

随机推荐

  1. 《30天自制操作系统》笔记2 --- 初步了解汇编产生的二进制(Day1)

    nask.exe应该就是nas kit(nas开发工具的意思),由于这个编译器是作者自己写的,所以这种汇编语言应该是作者改造出来的,所以我叫它nas汇编语言. 作者说nask是模仿nasm语法的,关于 ...

  2. [******] java多线程连续打印abc

    题目描述 建立三个线程A.B.C,A线程打印10次字母A,B线程打印10次字母B,C线程打印10次字母C,但是要求三个线程同时运行,并且实现交替打印,即按照ABCABCABC的顺序打印. 5种方法 使 ...

  3. 用户增长模型AARRR模型

    用户增长模型AARRR模型

  4. Java程序进行调优及监控

    Java 应用性能的瓶颈点非常多,比如磁盘.内存.网络 I/O 等系统因素,Java 应用代码,JVM GC,数据库,缓存等.笔者根据个人经验,将 Java 性能优化分为 4 个层级:应用层.数据库层 ...

  5. ReentrantLock 锁释放源码分析

    ReentrantLock 锁释放源码分析: 调用的是unlock 的方法: public void unlock() { sync.release(1); } 接下来分析release() 方法: ...

  6. nginx 指向本地目录

    # 必须配置此目录 location /upload { root D:\\upload\\; rewrite break; }

  7. log4j2记录日志到数据库(完美支持mysql使用DruidDataSource)

    引用 log4j-core-2.12.1.jar log4j-web-2.12.1.jar 1:配置数据源 2:调用类 3:写入

  8. 【02】Jenkins:第一个项目

    写在前面的话 通过上一节我们成功的搭建起来 Jenkins,那么接下来就是体验如何构建我们的第一个项目了.当然在这之前我们得专门针对 Java 环境就行简单的配置. 全局工具配置 其实这次配置的主要还 ...

  9. 使用Redis实现中英文自动补全功能详解

    1.Redis自动补全功能介绍: ​ Redis可以帮我们实现很多种功能,今天这里着重介绍的是Redis的自动补全功能的实现.我们使用有序集合,并score都为0,这样就按元素值的字典序排序.然后我们 ...

  10. C语言语法教程-结构体

    2018-09-30 结构体中成员变量地址是连续的,结构体用于描述记录. Create a struct //---------------------------- //struct1.c //创建 ...