1.Nginx简介
- 什么是nginx
Nginx是一款使用C语言开发的高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。 - Nginx的应用场景
http服务器。Nginx是一个http服务可以独立提供http服务。可以做网页静态服务器。
虚拟主机。可以实现在一台服务器虚拟出多个网站。例如个人网站使用的虚拟主机。
反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用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负载均衡配置成功
纵然浮生若梦,也要过好这一生