Docker+Nginx+Tomcat实现负载均衡
环境检测:
1、Docker没有安装的小伙伴请查看https://www.cnblogs.com/niuniu0108/p/12372531.html
2、没有创建Nginx容器的小伙伴请查看https://www.cnblogs.com/niuniu0108/p/12372709.html
3、没有创建Tomcat容器的小伙伴请查看https://www.cnblogs.com/niuniu0108/p/12373067.html
4、完成上述操作后,输入docker ps,回车后将会有一下内容(一个Tomcat容器、一个Nginx容器)

负载均衡部署:
1、在创建两个Tomcat容器,执行以下命令
docker run -itd --name myTomcat2 -p 8087:8080 tomcat:latest /bin/bash
docker run -itd --name myTomcat3 -p 8088:8080 tomcat:latest /bin/bash
执行完成后,进入容器操作(按照上面环境检测步骤3)
2、分别访问:http://IP:8087和http://IP:8088,出现以下界面说明Tomcat容器部署成功。


3、还记得自己的Nginx容器部署的时候映射的端口吧,对的,就是8081,现在访问http://IP:80801,出现下面的界面说明Nginx没问题。

4、现在我们来实现访问Nginx的时候,跳转到Tomcat
进入Nginx容器:docker exec -it fb1773fc6bcd /bin/bash

进入Nginx配置server的文件夹
cd /etc/nginx/conf.d
编辑server配置文件
vim default.conf (会发现vim命令找不着,怎么办呢?只能把文件拷贝到宿主机中,改完之后然后在拷贝回来是不是就好了)

记住这个文件路径(/etc/nginx/conf.d/default.conf),然后退出容器:exit
进入usr下的local文件夹
cd /usr/local/
在此文件夹中建立一个文件夹dockerNginx8082
mkdir dockerNginx8082
查看所有启动的容器并找到myNginx容器的ID
docker ps

开始拷贝文件
将myNginx中的(/etc/nginx/conf.d)的文件(default.conf)拷贝到宿主机(/usr/local/dockerNginx8082)
命令(红色字体就是myNginx对应的容器ID):docker cp fb1773fc6bcd:/etc/nginx/conf.d/default.conf /usr/local/dockerNginx8082
将myNginx中的(/etc/nginx)的文件(nginx.conf)拷贝到宿主机(/usr/local/dockerNginx8082)
命令(红色字体就是myNginx对应的容器ID):docker cp fb1773fc6bcd:/etc/nginx/nginx.conf /usr/local/dockerNginx8082

然后输入命令:ls,回车就回看到文件default.conf和nginx.conf已经拷贝过来了

现在开始修改default.conf文件:
vim default.conf

然后按键盘i键,就会看到下面的内容

加入下面的东西(其中192.168.91.128,这个IP是我的,你们要换成你们自己的IP)
location / {
proxy_pass http://myProxy;
}

然后按esc键,跟着输入英文冒号:,然后输入wq,最后回车
这样default.conf就文件修改完成了,
继续修改nginx.conf文件
vim nginx.conf
然后输入键i,在倒数第二行将下面的代码粘贴进去,如下图所示:
upstream myProxy{
server 192.168.91.128:8086;
server 192.168.91.128:8087;
server 192.168.91.128:8088;
}

然后按esc键,输入英文冒号:,然后输入wq,最后回车,修改完成。
然后重启容器:
docker restart fb1773fc6bcd(myNginx容器ID)
现在将这两个文件在拷贝回去
执行命令 :docker cp /usr/local/dockerNginx8082/default.conf fb1773fc6bcd:/etc/nginx/conf.d
执行命令 :docker cp /usr/local/dockerNginx8082/nginx.conf fb1773fc6bcd:/etc/nginx
然后我们进入myNginx容器:docker exec -it fb1773fc6bcd /bin/bash
然后启动nginx
输入命令cd usr/sbin,回车
输入命令./nginx,回车
现在我们再访问myNginx的网站试试,有没有跳转到tomcat去,http://ip:8081 发现可以跳转到Tomcat,但是不知道是哪个Tomcat,下面我们可以向每个Tomcat中都放入应用。

下面我们开始想tomcat中放入war包,首先先要知道war放在什么地方,他就放在tomcat容器内/usr/local/tomcat/webapps文件夹下面,现在我们将主机中的war拷贝到这个文件夹下面,一共三个tomcat容器,所以要执行三条命令,三条命令唯一不同就是要更换容器ID
备注:紫色的是你自己的war包路径,红色的是你自己的容器ID
docker cp usr/local/receiveFtp/loadbalancing_1.war 0632aa789b09:/usr/local/tomcat/webapps
docker cp usr/local/receiveFtp/loadbalancing_1.war 26f0a02b06ee:/usr/local/tomcat/webapps
docker cp usr/local/receiveFtp/loadbalancing_1.war 2924f33228b5:/usr/local/tomcat/webapps

到现在就拷贝完了,先依次进入先搁tomcat容器,将tomcat程序重启
我这里就列举一个,其他的都一样
进入容器:docker exec -it 0632aa789b09 /bin/bash

进入bin文件夹:cd bin

停止tomcat程序:./shutdown.sh

启动tomcat程序:./startup.sh

依次操作剩余的两个tomcat容器
我的操作完成之后就是这个样子的:

提示:我的只有8088端口是好的,其他的不能访问不知道为什么,我又重新新建了其他端口的容器是ok的,里面的IP刷新一次变化一次,这个问题目前还在排查中,不过操作是没有问题的!请各位放心!
如果遇到和我一样的已经解决的请留言告知我一下,谢谢!
经过测试,好像有的端口可以有的端口不行,但具体原因还有待查证。。。。。(有一点要提醒一下,我在宿主机上装的nginx是可以的,可以访问到所有的Tomcat,还没有发现端口有问题的情况!!!!!!)
Docker+Nginx+Tomcat实现负载均衡的更多相关文章
- Docker + Nginx + Tomcat 实现负载均衡简单演示
Docker + Nginx + Tomcat 实现负载均衡 环境 [root@pinyoyougou-docker ~]# docker -v Docker version 1.12.6, buil ...
- Nginx+Tomcat+Memcached负载均衡集群服务搭建
操作系统:CentOS6.5 本文档主要讲解,如何在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群服务器,Nginx负责负载均衡,Tomcat负责实际服务,Memc ...
- nginx+tomcat+redis负载均衡及session共享
概述 本文档是用来详细描述 nginx+tomcat+redis负载均衡实现session共享 所需软件及下载地址 软件名称 下载地址 功能说明 Nginx-v1.6.0 http://nginx.o ...
- 使用 Nginx + Tomcat 搭建负载均衡
负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽.增加吞吐量.加强网络数据处理能力.提高网络的灵活性和可用性. 负载均衡,英文名称为Load Balance, ...
- nginx+tomcat实现负载均衡以及双机热备
还记得那些年吗? 还记得更新代码之后,服务器起不来被领导训斥吗?还记得更新代码,需要停机过多的时间被渠道部们埋怨吗?还记得更新代码,代码出错时自己吓个半死吗?于是我们聪明勤快的程序员,看着电影待到夜深 ...
- Ubuntu下实现Nginx+Tomcat实现负载均衡
先说一下为什么写这个文章,在性能测试过程中,我们可能会关注很多指标,比如CPU.IO.网络.磁盘等,通过这些指标大致可以判断哪个环节遇到了性能瓶颈,但是当这些指标无法判断出性能瓶颈时,我们可能就需要对 ...
- 简单的 Nginx+Tomcat 配置负载均衡集群
简单 Nginx+Tomcat 配置负载均衡集群 前期准备 解压两个tomcat,修改端口号 server1:8081 server:8082 同时启动 nginx官网下载解压版nginx 创建一个简 ...
- Nginx+Tomcat 实现负载均衡 ,动静分离集群部署
Nginx + Tomcat 实现负载均衡,动静分离集群部署 1.Nginx实现负载均衡原理 2.Nginx配置反向代理主要参数 3.实验 1.Nginx实现负载均衡原理: Nginx服务器作为前端, ...
- Nginx+Tomcat搭建负载均衡
一. 工具 nginx-1.8.0 apache-tomcat-6.0.33 二. 目标 实现高性能负载均衡的Tomcat集群: 三. 步骤 1.首先下载Nginx,要下载稳定 ...
随机推荐
- 第3章 JDK并发包(二)
3.1.2 重入锁的好搭档:Condition条件 它和wait()和notify()方法的作用是大致相同的.但是wait()和notify()方法是和synchronized关键字合作使用的,而Co ...
- Nice to meet you for the first time .Why do I write blog!
他们说我不修边幅,因为他们没看到我对细节的追求,他们说我技术宅,因为他们看不懂我的悲欢,他们说我无趣,是因为她们不知道,我在让世界变得更有趣,我把误解拿来自黑,我用工作承载兴趣,我是程序员,是用代码编 ...
- 苹果系统iOS、macOS应用管理机制
iOS.macOS系统应用管理机制 苹果系统包括:iOS.macOS.watchOS.tvOS.应用软件的生命周期为:开发.上线.安装.使用.卸载.这篇文档将从应用生命周期的各个环节介绍苹果系统对应用 ...
- JAVA中voltatile关键字的使用
1.首先要明白一个概念 JAVA中主内存和线程工作内存的概念. 如果有一个static的变量,值会存储在主内存.如果多个线程访问这个变量,每个线程都会将变量的值拷贝到自己的工作内存,之后的操作就是针对 ...
- 吴恩达deepLearning.ai循环神经网络RNN学习笔记_没有复杂数学公式,看图就懂了!!!(理论篇)
本篇文章被Google中国社区组织人转发,评价: 条理清晰,写的很详细! 被阿里算法工程师点在看! 所以很值得一看! 前言 目录: RNN提出的背景 - 一个问题 - 为什么不用标准神经网络 - RN ...
- 面试题|手写JSON解析器
这周的 Cassidoo 的每周简讯有这么一个面试题:: 写一个函数,这个函数接收一个正确的 JSON 字符串并将其转化为一个对象(或字典,映射等,这取决于你选择的语言).示例输入: fakePars ...
- MySQL 什么是索引?
该文为< MySQL 实战 45 讲>的学习笔记,感谢查看,如有错误,欢迎指正 一.索引简介 索引就类似书本的目录,作用就是方便我们更加快速的查找到想要的数据. 索引的实现方式比较多,常见 ...
- python基础练习,循环、列表、字典、数组
# encoding: utf-8 ''' @author: mark @file: 20200214.py @time: 2020/2/14 14:21 @software: PyCharm ''' ...
- Nginx 和Apache 中的虚拟主机的概念
在部署环境的时候,有时候会引用到虚拟主机的概念,什么是虚拟主机呢,博主之前一直把虚拟主机的概念没搞清楚,导致在部署的时候,一直动不动就404 ,或者500,或者服务器不通 所以,什么是虚拟主机呢? 虚 ...
- 题解 Luogu P3370
讲讲这题的几种做法: 暴力匹配法 rt,暴力匹配,即把字符串存起来一位一位判相等 时间复杂度$ O(n^2·m) $ 再看看数据范围 \(n\le10^5,m\le10^3\) 当场爆炸.当然有暴力分 ...