• Nginx+Tomcat实现负载均衡!


    设备:安装两台Tomcat一台Nginx

    tomcat1:IP为192.168.200.130

    tomcat2:IP为192.168.200.122

    nginx:IP为192.168.200.111

    两台tomcat操作一致

    一:安装配置Tomcat

     上传jdk源码包

    [root@localhost ~]rz -E

    jdk-8u191-linux-x64.tar.gz 

    [root@localhost ~]#tar  xf  jdk-8u191-linux-x64.tar.gz                                

    [root@localhost ~]#mv  jdk-8u191-linux-x64/ /usr/local/java                       //解压放到/usr/local/下取名为java

     上传tomcat源码包

    [root@localhost ~]rz -E

    apache-tomcat-8.5.40.tar.gz

    [root@localhost ~]#tar xf  apache-tomcat-8.5.40.tar.gz                                                   

    [root@localhost ~]#mv apache-tomcat/  /usr/local/tomcat                            //将解包的目录放到/usr/local/取名为tomcat 

    环境配置

    [root@localhost ~]#vim  /etc/profile                                                                                                                  

    在末尾添加  如下代码:   

    export JAVA_HOME=/usr/local/java
    export JRE_HOME=/usr/local/java/jre
    export PATH=$PATH:/usr/local/java/bin
    export CLASSPATH=./:/usr/local/java/lib:/usr/local/java/jre/lib

    [root@localhost ~]#source /etc/profile                              //source执行文件

    [root@localhost ~]#java  -version                                      //查看JAVA旧版本号

    [root@localhost ~]# rm -rf /usr/bin/java                             //删除JAVA旧版本号

    [root@localhost ~]#source /etc/profile                              //source执行文件

    [root@localhost ~]#java  -version                                      //查看JAVA新版本号

    [root@localhost ~]# cd /usr/local/tomcat/webapps/ROOT/
    [root@localhost ROOT]# ls
    asf-logo.png            bg-nav-item.png     favicon.ico            tomcat.css     tomcat.svg
    asf-logo-wide.gif     bg-nav.png             index.jsp                tomcat.gif       WEB-INF
    bg-button.png         bg-upper.png          tomcat.png
    bg-middle.png        build.xml                RELEASE-NOTES.txt      tomcat-power.gif

     [root@localhost ROOT]# cp index.jsp index.jsp.bak                                        

    [root@localhost ROOT]# echo "192.168.200.130" > index.jsp                 #第一台tomcat

    [root@localhost ROOT]# echo "192.168.200.122" > index.jsp                #第二台tomcat

    开启Tomcat服务

    [root@localhost ~]#/usr/local/tomcat/bin/startup.sh   

    Tomcat端口为8080                   

    [root@localhost ~]# netstat -lnpt | grep :8080 

    关闭防火墙

    [root@localhost ~]# systemctl stop firewalld

    [root@localhost ~]# iptables -F

    [root@localhost ~]# setenforce 0

                                 

    安装Nginx

    安装Nginx依赖包 openssl-devel是安装ssl必要的模块

    [root@localhost ~]#yum install  gcc gcc-c++ openssl-devel pcre-devel zlib-devel make -y     

    创建用户是必做的,nginx通过用户来操作文件 

    [root@localhost ~]#useradd -M -s /sbin/nologin nginx 

    上传Nginx源码包

    [root@localhost ~]# rz -E
    z waiting to receive.**B0100000023be50                                             

    [root@localhost ~]# tar xf nginx-1.14.2.tar.gz -C /usr/src
    [root@localhost ~]# cd /usr/src/nginx-1.14.2/                                     

    [root@localhost ~nginx-1.14.2/]#./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module  && make && make install                                                

     --prefix 设定Nginx的安装目录

     --user和--group 指定Nginx运行用户和组

     --with-http_stub_status_module 启用http_stub_status_module模块以支持状态统计

     --with-http_ssl_module 启用SSL模块

     --with-http_flv_module 启用FLV模块,提供寻求内存使用基于时间的偏移量文件

    为主程序 nginx  创建链接文件
    [root@localhost ~]# ls /usr/local/nginx/
    conf   html  logs     sbin

    [root@localhost ~]#ln -sf /usr/local/nginx/sbin/nginx  /usr/local/sbin/                   //做Nginx的软连接,为了更方便的找到配置文件位置

     [root@localhost ~]# ll /usr/local/sbin/nginx 
    lrwxrwxrwx. 1 root root 27 9月 10 17:12 /usr/local/sbin/nginx -> /usr/local/nginx/sbin/nginx

    编写便于service管理的脚本

    [root@localhost ~]# vim /etc/init.d/nginx

    #!/bin/bash
    # chkconfig: 2345 99 20
    # description: Nginx Server Control Scripts shell
    PROG="/usr/local/nginx/sbin/nginx"
    PIDF="/usr/local/nginx/logs/nginx.pid"
    
    
    case "$1" in
    start)
    $PROG
    ;;
    stop)
    kill -s QUIT $(cat $PIDF)
    ;;
    restart)
    $0 stop
    $0 start
    ;;
    reload)
    kill -s HUP $(cat $PIDF)
    ;;
    *)
    echo "Usage: $0 {start|stop|restart|reload}"
    exit 1
    esac
    exit 0

     [root@localhost ~]# chmod +x /etc/init.d/nginx

    [root@localhost ~]# cd /usr/local/nginx/conf/
    [root@localhost conf]# ls
    fastcgi.conf                  koi-utf      nginx.conf        scgi_params.default
    fastcgi.conf.default      koi-win     uwsgi_params
    fastcgi_params           mime.types    nginx.conf.default      uwsgi_params.default
    fastcgi_params.default    mime.types.default       scgi_params   win-utf

    [root@localhost conf]# cp nginx.conf nginx.conf.bak                                

    Nginx  修改主配置文件

    [root@localhost ~]# vim /usr/local/nginx/conf/nginx.conf

    user  nginx nginx;
    worker_processes  2;
    
    #error_log  logs/error.log;
    #error_log  logs/error.log  notice;
    error_log  logs/error.log  info;
    
    pid        logs/nginx.pid;
    
    
    events {
        use epoll;
        worker_connections  10240;
    }
    
    
    http {
        include       mime.types;
        default_type  application/octet-stream;
    
        log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                          '$status $body_bytes_sent "$http_referer" '
                          '"$http_user_agent" "$http_x_forwarded_for"';
    
        access_log  logs/access.log  main;
    
        sendfile        on;
        #tcp_nopush     on;
    
        #keepalive_timeout  0;
        keepalive_timeout  65;
    
        #gzip  on;
    
       upstream tomcat_server {                                  #线程池规定IP号及权重
        server 192.168.200.130:8080 weight=2;                    #weight表示权重,权重越高,越高被分配的几率越高
        server 192.168.200.122:8080 weight=1;                
    
    }
    
    
        server {
            listen       80;
            server_name  localhost;
    
            charset utf-8;
    
            access_log  logs/host.access.log  main;
    
            location / {
                root   html;
                index  index.html index.htm;
           proxy_pass http://tomcat_server;                         #线程池名
            proxy_set_header Host $http_host;                       #此处要添加host头,将头信息返回服务器,不加host可能报400错误
    
            }
    
            #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   html;
            }
    
        }
    
    }

    [root@localhost conf]# nginx -t
    nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
    nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

    [root@localhost conf]# nginx
    [root@localhost conf]# nginx -HUP nginx

    [root@localhost conf]# netstat -anpt | grep :80
    tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 16275/nginx: master

    关闭防火墙

    [root@localhost ~]# systemctl stop firewalld

    [root@localhost ~]# iptables -F

    [root@localhost ~]# setenforce 0

    测试两台tomcat同时运行:

  • 相关阅读:
    UML常识
    我的一些冒出来的想法
    那些我接触过的软件
    对PL/SQL的认识
    JavaScrip笔记
    万丈高楼平地起
    HTML DOM和JavaScrip的关系
    拾起荒废的英语
    Tomcat文件映射路径
    Access-Control-Allow-Origin
  • 原文地址:https://www.cnblogs.com/CMX_Shmily/p/11589430.html
Copyright © 2020-2023  润新知