Nginx是一款高性能的HTTP和反向代理、负载均衡web服务器。本次在Docker容器中部署三个tomcat,Nginx代理三个tomcat服务(以下称节点)来模拟实现负载均衡效果,配置check模块,在前台查看各个节点的状态。

准备资料

1、创建容器

  • -i 交互模式
  • -d 后端运行
  • -h 容器的hostname
  • --name 容器名
  • --network 网卡
  • --ip IP地址
  • -p 端口映射
  • --privileged=true 和 /usr/sbin/init 为特权模式参数
[root@localhost Tools]# docker run -i -d -h nginx --name nginx --net docker-br0 --ip 172.127.0.205 -p 1580:80 --privileged=true centos:7 /usr/sbin/init

2、上传资料 或者用wget命令下载

  • 进入容器
[root@localhost Tools]# docker exec -it nginx /bin/bash

  • 创建资料存放文件夹
[root@nginx /]# mkdir Tools

  • 更新yum源
[root@nginx /]# yum -y update

  • 安装常用命令及网络相关依赖包(vim zip unzip wget net-tools )
[root@nginx /]# yum -y install vim zip unzip wget net-tools

  • 使用wget下载master、nginx
[root@localhost Tools]# wget https://codeload.github.com/yaoweibin/nginx_upstream_check_module/zip/master
[root@localhost Tools]# wget http://nginx.org/download/nginx-1.20.1.tar.gz
[root@nginx Tools]# wget https://dlcdn.apache.org/tomcat/tomcat-10/v10.0.18/bin/apache-tomcat-10.0.18.tar.gz

  • jdk下载需要Oracle账户登录,免费注册后即可下载,上传jdk安装包
  • docker cp 需在宿主机执行
[root@localhost Tools]# docker cp jdk-8u321-linux-x64.tar.gz nginx:/Tools/

3、安装jdk

  • 解压

    • -C 指定解压后的目录
[root@nginx Tools]# tar -zxvf jdk-8u321-linux-x64.tar.gz -C /usr/local/

  • 配置环境变量,使之生效
[root@nginx Tools]# vim /etc/profile
[root@nginx Tools]# source /etc/profile
[root@nginx Tools]# cat /etc/profile | grep export

  • 验证
[root@nginx Tools]# java -version

4、安装3个Tomcat服务

  • 解压后复制三份
[root@nginx Tools]# tar -zxvf apache-tomcat-10.0.18.tar.gz
[root@nginx Tools]# cp -R apache-tomcat-10.0.18 /usr/local/tomcat01
[root@nginx Tools]# cp -R apache-tomcat-10.0.18 /usr/local/tomcat02
[root@nginx Tools]# cp -R apache-tomcat-10.0.18 /usr/local/tomcat03
  • 修改配置文件,主要是调整端口,三个tomcat的端口不一致即可
[root@nginx Tools]# vim /usr/local/tomcat01/conf/server.xml
[root@nginx Tools]# vim /usr/local/tomcat02/conf/server.xml
[root@nginx Tools]# vim /usr/local/tomcat03/conf/server.xml
[root@nginx Tools]# cat /usr/local/tomcat01/conf/server.xml

  • 启动三个tomcat服务
[root@nginx Tools]# /usr/local/tomcat01/bin/startup.sh
[root@nginx Tools]# /usr/local/tomcat02/bin/startup.sh
[root@nginx Tools]# /usr/local/tomcat03/bin/startup.sh

  • 验证
[root@nginx Tools]# ps -ef | grep tomcat

5、安装Nginx

  • 安装依赖包
[root@nginx Tools]# yum -y install gcc gcc-c++ make automake autoconf libtool pcre* zlib openssl openssl-devel patch

  • 解压
[root@nginx Tools]# tar -zxvf nginx-1.20.1.tar.gz
[root@nginx Tools]# unzip master

check模块非官方程序,需选择对应版本的补丁进行更新

  • 打补丁,必须在解压后的文件目录
[root@nginx Tools]# cd nginx-1.20.1
[root@nginx nginx-1.20.1]# patch -p1 < /Tools/nginx_upstream_check_module-master/check_1.20.1+.patch

  • 配置

    • --prefix 指定安装Nginx的路径
    • --with-http_stub_status_module 增加stub模块,用来检测集群节点的请求状态
    • --add-module=/Tools/nginx_upstream_check_module-master/ check模块,主动检测集群状态模块
[root@nginx nginx-1.20.1]# ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --add-module=/Tools/nginx_upstream_check_module-master/

  • 编译及安装
[root@nginx nginx-1.20.1]# make && make install

  • 配置nginx.conf,一般在安装文件的conf目录下,本例为/usr/local/nginx/conf/nginx.conf
[root@nginx nginx-1.20.1]# vim /usr/local/nginx/conf/nginx.conf
worker_processes  1;          # 进程数
events {
worker_connections 1024; # 连接数
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
# 集群配置
upstream tomcat {
server 172.127.0.205:8080 weight=1 max_fails=3 fail_timeout=30s ;
server 172.127.0.205:8081 weight=1 max_fails=3 fail_timeout=30s ;
server 172.127.0.205:8081 weight=1 max_fails=3 fail_timeout=30s ;
check interval=3000 rise=2 fall=5 timeout=1000 type=http;
}
server {
listen 80;
server_name localhost;
location / {
root html;
index index.html index.htm;
proxy_pass http://tomcat; # 代理配置
}
# check模块配置
location /check_status {
check_status;
access_log off;
}
# stub模块配置
location /stub_status {
stub_status;
access_log off;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
  • 启动nginx
[root@nginx nginx-1.20.1]# /usr/local/nginx/sbin/nginx
  • 验证nginx
[root@nginx nginx-1.20.1]# ps -ef | grep nginx

6、代理、负载状态check、stub模块验证

  • 代理验证

  • 负载状态check

  • stub模块验证

Docker容器Nginx负载均衡配置、check及stub模块安装的更多相关文章

  1. Docker 安装 Nginx 负载均衡配置

    Docker 安装 # 1)安装依赖包 yum install -y yum-utils device-mapper-persistent-data lvm2 # 2)添加Docker软件包源(否则d ...

  2. nginx高性能WEB服务器系列之六--nginx负载均衡配置+健康检查

    nginx系列友情链接:nginx高性能WEB服务器系列之一简介及安装https://www.cnblogs.com/maxtgood/p/9597596.htmlnginx高性能WEB服务器系列之二 ...

  3. Tomcat服务部署与Nginx负载均衡配置

    一.中间键产品介绍 目前来说IBM的WebSphere,Oracle的Weblogic占据了市场上java语言Web站点的部分份额,该两种软件都是商业化的软件,由于性能优越,可靠性高等优点应用于大型互 ...

  4. Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群

    Tomcat集群,Nginx集群,Tomcat+Nginx 负载均衡配置,Tomcat+Nginx集群 >>>>>>>>>>>> ...

  5. Nginx负载均衡配置简单配置方法

    http://www.jb51.net/article/121235.htm Nginx作为负载均衡服务器,用户请求先到达nginx,再由nginx根据负载配置将请求转发至不同的Web服务器.下面通过 ...

  6. Mall电商项目总结(二)——nginx负载均衡配置和策略

    1. nginx配置文件 用户在浏览器上输入,http://www.xwld.site/ 实际上是在访问服务器80端口,nginx 监听80端口,将用户的请求转发到8080和9080端口 . upst ...

  7. docker 搭建 nginx负载均衡

    本文描述如何在一台机器上搭建nginx负载均衡,我将会启动3个nginx的docker,分别是1台前置nginx负责分发,后面2台负责处理请求. 首先我切换到/usr/local/docker/文件夹 ...

  8. Nginx负载均衡配置实例详解

    负载均衡是我们大流量网站要做的一个东西,下面我来给大家介绍在Nginx服务器上进行负载均衡配置方法,希望对有需要的同学有所帮助哦. 负载均衡 先来简单了解一下什么是负载均衡,单从字面上的意思来理解就可 ...

  9. Nginx负载均衡配置实例详解(转)

    负载均衡是我们大流量网站要做的一个东西,下面我来给大家介绍在Nginx服务器上进行负载均衡配置方法,希望对有需要的同学有所帮助哦. 负载均衡 先来简单了解一下什么是负载均衡,单从字面上的意思来理解就可 ...

随机推荐

  1. 视频Video放器的部分实例方法

    ***创建一个视频播放器实例 let myPlayer = this.$video(myVideo, { controls: true, autoplay: 'muted', preload: &qu ...

  2. caioj 1031: [视频]递归1(全排列)【DFS】【全排列】

    题目大意:先给一个正整数 n( 1 < = n < = 10 ),输出1到n的所有全排列. 题解:这道题目我们可以用递归来实现,递归在图论中又称为"深度优先搜索"(De ...

  3. 实现call、apply 及 bind 函数

    今日学习内容: (1)call 函数的实现步骤: 判断调用对象是否为函数,即使是定义在函数的原型上的,但是可能出现使用 call 等方式调用的情况. 判断传入上下文对象是否存在,如果不存在,则设置为 ...

  4. Thinkphp3.2.3 where注入 浅分析漏洞原理及修复

    0x01引子 0x02分析 找到截断方法 找到_parseType的入口 找到生成sql语句的代码 0x03 poc链 0x04 利用示范 payload: http://localhost:3000 ...

  5. Istio实践(1)-环境搭建及应用部署

    1. Istio简介 Istio是最初由IBM,Google和Lyft开发的服务网格的开源实现.它可以透明地分层到分布式应用程序上,并提供服务网格的所有优点,例如流量管理,安全性和可观察性. 它旨在与 ...

  6. 基于Vue的v-charts导出图片并下载

    依赖 npm install file-saver 页面 <ve-chart ref="chart"></ve-chart> <el-button t ...

  7. 理解ASP.NET Core - 授权(Authorization)

    注:本文隶属于<理解ASP.NET Core>系列文章,请查看置顶博客或点击此处查看全文目录 之前,我们已经了解了ASP.NET Core中的身份认证,现在,我们来聊一下授权. 老规矩,示 ...

  8. 通知:PostgreSQL证书申报退税请抓紧!

    2021年个税申报已于3月开始为了确保PostgreSQL证书能顺利退税中心特调研了学员中仅针对证书一项做退税申请没几天就得到结果2021年取得的PostgreSQL职业 技术证书确定可以退税!   ...

  9. 企业级 Web 开发的挑战

    本文翻译自土牛Halil ibrahim Kalkan的<Mastering ABP Framework>,是系列翻译的起头,适合ABP开发人员或者想对ABP框架进行深入演进的准架构师. ...

  10. Bugku CTF练习题---社工---信息查找

    Bugku CTF练习题---社工---信息查找 flag:KEY{462713425} 解题步骤: 1.观察题目,思考题目内容,了解答案是群号 2.这里涉及到好多的信息,首先有网址,第二个是今日头条 ...