第八章----CentOS7 配置 Nginx 整合Tomcat集群

1.Nginx简介

  • 什么是nginx
    Nginx是一款使用C语言开发的高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。
  • Nginx的应用场景
    http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。
    虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
    反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用nginx做反向代理。并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况。
Nginx

2.安装Nginx

  • 安装依赖
1:gcc:nginx编译依赖gcc环境
   yum install gcc-c++
2:pcre:(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式
    yum install -y pcre pcre-devel
3:zlib:该库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip
    yum install -y zlib zlib-devel
4:openssl:一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。nginx不仅支持http协议,还支持https(即在ssl协议上传输http)
     yum install -y openssl openssl-devel
  • 下载配置Nginx

Nginx下载地址

  • rz , 上传到Linux服务器
  • tar -zxvf nginx-1.12.3.tar.gz , 解压
  • mv nginx-1.12.0 Java/nginx-1.12.0 , 移动到指定目录
  • vim configure , 进入Nginx目录,编辑Nginx指定的路径
  • ./configure , 执行生成相关信息
  • make && make install , 安装
  • mkdir logs , 进入Nginx目录,创建logs文件夹
  • ./nginx , 进入sbin目录,启动Nginx

3.Nginx常用命令

  • ./nginx , 启动Nginx
  • ./nginx -t , 测试配置文件是否有错误
  • ./nginx -v , 查看Nginx版本
  • ./nginx -V , 查看Nginx版本和编译安装时的编译参数
  • ./nginx -s stop , 强制停止Nginx服务
  • ./nginx -s quit , 优雅地停止Nginx服务(即处理完所有请求后再停止服务)
  • ./nginx -s reload , 重新加载Nginx配置文件,然后以优雅的方式重启Nginx

4.Nginx 配置 Tomcat 负载均衡

  • mv tomcat tomcat1 , 进入tomcat所在目录,重命名为tomcat1
  • cp -r tomcat1/ tomcat2 , 复制tomcat1 命名为 tomcat2
  • vim server.xml , 进入tomcat2/conf目录,修改端口号
                 端口:8005->9005

6060
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
               enableLookups="false" redirectPort="8443" acceptCount="100"
               connectionTimeout="20000" disableUploadTimeout="true" />

9009
               enableLookups="false" redirectPort="8443" protocol="AJP/1.3" />
  • yum install lsof , 安装lsof
  • lsof -i:端口号 , 查看端口号是否占用
  • 启动两个tomcat,查看是否可以正常访问
  • vim nginx.conf , 进入Nginx的conf目录 修改nginx.conf
#Nginx所用用户和组,window下不指定  
#user  niumd niumd;  

#工作的子进程数量(通常等于CPU数量或者2倍于CPU)  
worker_processes  2;  

#错误日志存放路径  
#error_log  logs/error.log;  
#error_log  logs/error.log  notice;  
error_log  logs/error.log  info;  

#指定pid存放文件  
pid        logs/nginx.pid;  

events {  
    #使用网络IO模型linux建议epoll,FreeBSD建议采用kqueue,window下不指定。  
    #use epoll;  

    #允许最大连接数  
    worker_connections  2048;  
}  

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  off;  
    access_log  logs/access.log;  

    client_header_timeout  3m;  
    client_body_timeout    3m;  
    send_timeout           3m;  

    client_header_buffer_size    1k;  
    large_client_header_buffers  4 4k;  

    sendfile        on;  
    tcp_nopush      on;  
    tcp_nodelay     on;  

    #keepalive_timeout  75 20;  

    #include    gzip.conf;  
    upstream localhost{  
    #Nginx是如何实现负载均衡的,Nginx的upstream目前支持以下几种方式的分配
    #1、轮询(默认)
    #每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
    #2、weight
    #指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
    #2、ip_hash
    #每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
    #3、fair(第三方)
    #按后端服务器的响应时间来分配请求,响应时间短的优先分配。
    #4、url_hash(第三方)
    #按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。  
      #ip_hash; 

      server 192.168.1.239:8080;  
      server 192.168.1.239:6060;
     }  

    server {  
            listen       80;  
            server_name  localhost;     

            location / {  
                   proxy_connect_timeout 3; #nginx跟后端服务器连接超时时间(代理连接超时) 
                   proxy_send_timeout 30; #后端服务器数据回传时间(代理发送超时) 
                   proxy_read_timeout 30; #连接成功后,后端服务器响应时间(代理接收超时) 
                   proxy_pass http://localhost;

   }  
}  
}
  • ./nginx -t , 加载配置文件
  • ./nginx , 启动Nginx

5.设置Tomcat、Nginx开机启动

  • 编辑/etc/rc.d/文件下的rc.local ,添加jdk路径和Tomcat路径
export JAVA_HOME=/app/Java/jdk1.8.0
export JRE_HOME=$JAVA_HOME/jre

sh /app/Java/tomcat1/bin/startup.sh
sh /app/Java/tomcat2/bin/startup.sh
  • 给rc.local文件添加执行权限
chmod +x rc.local
  • (方法一) 进入/etc/init.d/目录,创建Nginx执行文件
touch nginx
  • 编辑 nginx ,添加官网的配置
#!/bin/sh
#
# nginx - this script starts and stops the nginx daemon
#
# chkconfig:   - 85 15
# description:  NGINX is an HTTP(S) server, HTTP(S) reverse \
#               proxy and IMAP/POP3 proxy server
# processname: nginx
# config:      /etc/nginx/nginx.conf
# config:      /etc/sysconfig/nginx
# pidfile:     /var/run/nginx.pid

# Source function library.
. /etc/rc.d/init.d/functions

# Source networking configuration.
. /etc/sysconfig/network

# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0

nginx="/usr/sbin/nginx"
prog=$(basename $nginx)

NGINX_CONF_FILE="/etc/nginx/nginx.conf"

[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx

lockfile=/var/lock/subsys/nginx

make_dirs() {
   # make required directories
   user=`$nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
   if [ -z "`grep $user /etc/passwd`" ]; then
       useradd -M -s /bin/nologin $user
   fi
   options=`$nginx -V 2>&1 | grep 'configure arguments:'`
   for opt in $options; do
       if [ `echo $opt | grep '.*-temp-path'` ]; then
           value=`echo $opt | cut -d "=" -f 2`
           if [ ! -d "$value" ]; then
               # echo "creating" $value
               mkdir -p $value && chown -R $user $value
           fi
       fi
   done
}

start() {
    [ -x $nginx ] || exit 5
    [ -f $NGINX_CONF_FILE ] || exit 6
    make_dirs
    echo -n $"Starting $prog: "
    daemon $nginx -c $NGINX_CONF_FILE
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}

stop() {
    echo -n $"Stopping $prog: "
    killproc $prog -QUIT
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}

restart() {
    configtest || return $?
    stop
    sleep 1
    start
}

reload() {
    configtest || return $?
    echo -n $"Reloading $prog: "
    killproc $nginx -HUP
    RETVAL=$?
    echo
}

force_reload() {
    restart
}

configtest() {
  $nginx -t -c $NGINX_CONF_FILE
}

rh_status() {
    status $prog
}

rh_status_q() {
    rh_status >/dev/null 2>&1
}

case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart|configtest)
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    force-reload)
        force_reload
        ;;
    status)
        rh_status
        ;;
    condrestart|try-restart)
        rh_status_q || exit 0
            ;;
    *)
        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
        exit 2
esac
  • 修改对应Nginx安装路径和配置文件路径
第一处:
nginx="/app/Java/nginx-1.12.0/sbin/nginx"
第二处:
NGINX_CONF_FILE="/app/Java/nginx-1.12.0/conf/nginx.conf"
  • 给nginx文件增加执行权限
chmod a+x /etc/init.d/nginx
  • 将nginx服务加入chkconfig管理列表
chkconfig --add /etc/init.d/nginx
  • 设置开机启动
chkconfig nginx on
  • (方法二) 进入/lib/systemd/system/这个目录 新建nginx.service
touch nginx.service   
  • 编辑nginx.service文件,修改对应路径
[Unit]    
Description=nginx    
After=network.target    
     
[Service]    
Type=forking    
ExecStart=/app/Java/nginx-1.12.0/sbin/nginx   
ExecReload=/app/Java/nginx-1.12.0/sbin/nginx -s reload    
ExecStop=/app/Java/nginx-1.12.0/sbin/nginx -s stop  
PrivateTmp=true    
     
[Install]    
WantedBy=multi-user.target  
  • 设置开机启动
systemctl enable nginx.service 

注:方法二如果是通过yum安装的直接执行最后一步即可,如果是.tar.gz安装的需要自己创建nginx.service文件

  • 重启服务
reboot

6.配置Nginx动静分离

  • 修改ngxin.conf文件(简洁版,后期如有需要再进行详细更改)
server {    
        listen       80;#端口号    
        server_name  localhost;#本机    
        charset utf-8;    

        location ~ .*\.(gif|jpg|jpeg|png)$ {
            root /app/Java/data/img/;#指定图片存放路径    
        }      
    
        location ~ .*\.(zip|ppt|html|pptx)$ {      
            root /app/Java/data/file/;#指定文件存放路径     
        } 
       location / {
          proxy_pass http://localhost;#其他访问Tomcat
       }
}  

恭喜你Nginx+Tomcat负载均衡配置成功


纵然浮生若梦,也要过好这一生

你可能感兴趣的:(第八章----CentOS7 配置 Nginx 整合Tomcat集群)