nginx介绍
nginx是一个轻量级的web服务器,也是一款高性能的反向代理服务器,另外nginx使用简单,易于维护扩展。
环境准备
centos6.5
tomcat7
nginx1.8.1
环境搭建
安装nginx依赖
下载nginx依赖包
1.gzip 模块需要 zlib 库,笔者所使用的版本: zlib-1.2.11.tar.gz( 下载: http://www.zlib.net/ )
2.rewrite 模块需要 pcre 库,笔者所使用的版本: pcre-8.38.tar.gz( 下载: http://www.pcre.org/ )
3.ssl 功能需要 openssl 库,笔者所使用的版本: openssl-1.0.0o.tar.gz ( 下载: http://www.openssl.org/ )
编译安装
安装c++编译环境:
#yum安装 yum install gcc-c++ yes
安装openssl:
#解压 tar -zxvf openssl-1.0.0o.tar.gz #进入解压目录 cd openssl-1.0.0o #编译安装 ./config && make && make install
安装zlib:
#解压 tar -zxvf zlib-1.2.11.tar.gz #进入解压目录 cd zlib-1.2.11
#编译安装 ./configure && make && make install
安装pcre:
#解压 tar -zxvf pcre-8.38.tar.gz #进入解压目录 cd pcre-8.38 #编译安装 ./configure && make && make install
安装nginx
下载安装包
1.nginx缓存模块需要搭配ngx_cache_purge,笔者所使用的版本:ngx_cache_purge-2.3.tar.gz(下载: http://labs.frickle.com/files/ )
2.nginx,笔者所使用的版本:nginx-1.8.1.tar.gz(下载: http://nginx.org/ )
编译安装
#解压ngx_cache_purge tar -zxxf ngx_cache_purge-2.3.tar.gz #解压nginx tar -zxvf nginx-1.8.1.tar.gz #进入nginx解压目录 cd nginx-1.8.1 #编译ngx_cache_purge模块 ./configure --add-module=../ngx_cache_purge-2.3 --prefix=/usr/local/nginx #安装 make && make install
异常解决
安装完成后,验证nginx:
/usr/local/nginx/sbin/nginx -t
发现报错了:
error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory...
先找到libpcre.so.1所在位置,然后做个软链接就可以了:
whereis libpcre.so.1 libpcre.so: /lib64/libpcre.so.0 /usr/local/lib/libpcre.so /usr/local/lib/libpcre.so.1 ln -s /usr/local/lib/libpcre.so.1 /lib64
再次验证:
/usr/local/nginx/sbin/nginx -t
安装jdk
下载安装包
笔者所使用的版本:jdk-7u79-linux-x64.tar.gz(下载: http://www.oracle.com/technetwork/java/javase/downloads/index.html )
安装配置
#解压 tar -zxvf jdk-7u79-linux-x64.tar.gz #将jdk添加到环境变量中 vim /etc/profile #在文件最后添加 export JAVA_HOME=/home/hadoop/jdk1.7.0_79 export PATH=$PATH:$JAVA_HOME/bin #刷新配置 source /etc/profile
安装tomcat
下载安装包
笔者所使用的版本:tomcat7(下载: http://tomcat.apache.org/download-70.cgi )
安装配置
#解压 tar -zxvf apache-tomcat-7.0.64.tar.gz #复制一个tomcat ... #修改其中一个tomcat中的server.xml为: <Server port="8005"shutdown="SHUTDOWN"> 改为 8006 <Connector port="8080"protocol="HTTP/1.1" 改为 8081 <Connector port="8009"protocol="AJP/1.3" 改为 8010
添加测试页面
1、新建test.jsp页面,放置tomcat1的demo项目下,内容如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Tomcat1</title> </head> <body> SessionID: <%= session.getId() %> </body> </html>
2、test.jsp中的title为Tomcat2,以便测试区分。
启动tomcat
1、启动tomcat1
#进入tomcat解压的bin目录 cd /home/hadoop/apache-tomcat-7.0.64_1/bin #启动tomcat ./catalina.sh
2、启动tomcat 2
配置负载均衡
添加集群、代理
#进入nginx安装的conf目录 cd /usr/local/nginx/conf/ #打开nginx.conf文件添加以下内容: upstream dynamic_server { server 192.168.1.111:8080 weight=1 max_fails=2 fail_timeout=30s; server 192.168.1.111:8081 weight=1 max_fails=2 fail_timeout=30s; } location / { proxy_pass http://dynamic_server; }
完整的配置文件
#工作进程个数:多开几个可以减少io带来的影响, #根据 lscpu查出来的cpus设置(一般为当前机器核心数的1-2倍,最大不超过8), worker_processes 2; #worker_cpu_affinity需要结合worker_processes使用,一个worker_processes绑定一个CPU, #比如两核是01,四核是0001,下面是2核绑定2个worker_processes的示例 worker_cpu_affinity 01 10; #nginx运行日志 #error_log logs/error.log error; events { #使用epoll模型提高性能 use epoll; #单个进程连接数(最大连接数=连接数*进程数) worker_connections 65535; } http { #文件扩展名与文件类型映射表 include mime.types; #默认文件类型 default_type application/octet-stream; #开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为 on, #如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载。 #注意:如果图片显示不正常把这个改成off sendfile on; #长连接超时时间,单位是秒 keepalive_timeout 65; #gzip 是告诉nginx采用gzip压缩的形式发送数据。这将会减少我们发送的数据量。 gzip on; gzip_min_length 1k; #最小1K gzip_buffers 16 64K; gzip_http_version 1.1; gzip_comp_level 6; gzip_types text/plain application/x- text/css application/xml application/; gzip_vary on; #header设置:用户真实的ip地址转发给后端服务器 proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Real-IP $remote_addr; #缓冲 client_body_buffer_size 512k; proxy_connect_timeout 5; proxy_read_timeout 60; proxy_send_timeout 5; proxy_buffer_size 16k; proxy_buffers 4 64k; proxy_busy_buffers_size 128k; proxy_temp_file_write_size 128k; ################################################集群 ################################################### #动态资源集群 upstream dynamic_server { #服务器配置 weight是权重的意思,权重越大,分配的概率越大。 server 192.168.1.111:8080 weight=1 max_fails=2 fail_timeout=30s; server 192.168.1.111:8081 weight=1 max_fails=2 fail_timeout=30s; } ################################################Nginx代理################################################### server { #监听80端口,可以改成其他端口 listen 80; #nginx服务的域名,通过域名就可以访问应用 server_name localhost; #反向代理:转发到后端的tomcat集群 location / { proxy_pass http://dynamic_server; } #错误提示页面 error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
View Code
本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:nginx二 之负载均衡搭建 - Python技术站