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. Via板载声卡底噪严重、播放卡顿及耳机与扬声器音源切换问题【解决方法】

    HD VDeck[VIA威盛HD audio系列音频驱动] 关闭音效增强之后,一切正常............ 默默骂一句VIA沙雕 另外附上:开启耳机和扬声器独立音源的设置 注册表 Computer ...

  2. WPF DataGrid 鼠标对表格双击导致客户端崩溃

    该问题是由于在创建DataGrid时没有设置为只读属性 解决:             <DataGrid Name="switchInfoList" MouseLeftBu ...

  3. 阅读java编程思想的总结(一)

    学而不思则罔,思而不学则殆 一.对象(Object) 1.机器模型(方案空间),实际解决问题的问题模型(问题空间). 2.我们将问题空间中的元素以及它们在方案空间的表示物称为“对象”(Object). ...

  4. 热情组——项目冲刺 Day2

    项目相关 作业相关 具体描述 班级 班级链接 作业要求 链接地址 团队名称 热情组 作业目标 实现软件的生成,以及在福大的传播 Github链接 链接地址 SCRUM部分: 成员昵称 昨日目标 开始时 ...

  5. 调试MATLAB代码

    1.在子函数设置的断点,在运行时,不起作用: 因为在主函数开始时,使用了clear all,在运行时,会把断点给删除.

  6. vuejs怎么和thinkphp结合

    vue在服务端部署时,我们都知道通过npm run build 指令打包好的dist文件,通过http指定是可以直接浏览的,Thinkphp通过域名指向index.php文件才可以浏览.要使前端正常调 ...

  7. 使用semaphore写一个显示锁

    /** * 这里只是将Semaphore包装了一下,注意当Semaphore的构造参数是1时,本身就是一个显示锁 */ public class SemaphoreLock { ); public v ...

  8. pod的yaml例子

    apiVersion: apps/v1beta2 kind: Deployment metadata: name: nginx-deployment spec: replicas: 3 selecto ...

  9. jquery validate 动态生成的多个同名input的验证

    我的应用场景是,添加和修改入库单的明细,明细是以表格的形式呈现,可以动态添加商品,用jquery.validate插件做数据验证. 由于jquery.validate插件验证同名的input时只验证第 ...

  10. C# 常用工具方法之DataTable(一)

    1.DataTable 转 泛型T的List /// <summary> /// 数据集DataTable转换成List集合 /// </summary> /// <ty ...