一. Nginx介绍
1.1 什么是Nginx?
Nginx是一款轻量级的Web 服务器、反向代理服务器及电子邮件(IMAP/POP3)代理服务器,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
1.2 Nginx的特点
反向代理: 代替tomcat服务器接收用户请求
负载均衡:将请求分发到多个tomcat服务器
动静分离 : 将静态资源交给nginx处理
1.2.1 什么是反向代理?(代理服务可简单的分为正向代理和反向代理: )
反向代理:
与正向代理相反, 反向代理是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器
所谓的反向代理就是代替服务器接受用户的请求,从目标服务器中取得用户的需求资源,然后发送给用户
1.2.2 什么是负载均衡?
负载均衡:数据流量分摊到多个服务器上执行,减轻每台服务器的压力,多台服务器共同完成工作任务,从而提高了数据的吞吐量。
1.2.3 什么是动静分离?
动静分离:将静态的资源放到反向代理服务器,节省用户的访问时间
Web服务器分2类:
- web应用服务器,如:
- tomcat
- resin
- web服务器,如:
- Apache 服务器
区分:web服务器不能解析jsp等页面,只能处理js、css、html等静态资源。
并发:web服务器的并发能力远高于web应用服务器。
二. 安装Nginx
2.1 下载Nginx
官方网站:nginx news
2.2. 安装nginx
- 安装nginx的依赖库--基于c语言开发
yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel
- 解压安装包
tar -zxvf nginx-1.10.0.tar.gz
- 配置nginx安装包
cd nginx-1.10.0
./configure --prefix=/usr/java/nginx
注意:./configure配置nginx安装到/usr/java/nginx目录下
- 编译并安装
make && make install
2.3 目录结构
├── client_body_temp # 临时目录
├── conf # Nginx所有配置文件的目录
│ ├── nginx.conf # Nginx主配置文件
├── fastcgi_temp # fastcgi临时数据目录
├── html # Nginx默认站点目录
│ ├── 50x.html # 错误页面优雅替代显示文件,例如当出现502错误时会调用此页面
│ └── index.html # 默认的首页文件
├── logs # Nginx日志目录
│ ├── access.log # 访问日志文件
│ ├── error.log # 错误日志文件
│ └── nginx.pid # pid文件,Nginx进程启动后,会把所有进程的ID号写到此文件
├── proxy_temp # 临时目录
├── sbin # Nginx命令目录
│ └── nginx # Nginx的启动命令
├── scgi_temp # 临时目录
└── uwsgi_temp # 临时目录
2.4 配置文件介绍
#user nobody;
#工作进程
worker_processes 1;events {
#连接池连接数
worker_connections 1024;
}
#请求方式
http {
#媒体类型
include mime.types;
#默认媒体类型 二进制
default_type application/octet-stream;
#上传文件
sendfile on;
#超时时间
keepalive_timeout 65; #gzip on;
#服务器配置
server {
#监听端口
listen 80;
#监听域名
server_name localhost;
#请求头信息
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
#请求映射规则,/代表所有请求路径
location / {
#请求转发地址
#root html;
proxy_pass http://manage.powershop.com:8080;
#欢迎页
#index index.html index.htm;
#转发连接超时时间
proxy_connect_timeout 600;
#转发读取超时时间
proxy_read_timeout 600;
}
}
}
2.5. Nginx的启动及关闭
- 启动
#在nginx目录下有一个sbin目录,sbin目录下有一个nginx可执行程序 ./nginx
- 测试
- 关闭nginx
#在nginx目录下有一个sbin目录,sbin目录下有一个nginx可执行程序
#关闭nginx
./nginx -s stop
#可以不关闭nginx的情况下更新配置文件
./nginx -s reload
三. Nginx开启自启动
3.1 编写开机启动文件
- 添加nginx.service文件
vim /lib/systemd/system/nginx.service
- 文件内容如下:
[Unit]
Description=nginx
After=network.target[Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s quit
PrivateTmp=true[Install]
WantedBy=multi-user.target
3.2 设置开机启动
systemctl daemon-reload #重新加载服务配置
systemctl enable nginx.service #设置为开机启动
systemctl start nginx.service #启动服务
systemctl status nginx.service #查看服务状态
systemctl stop nginx.service #停止服务
四.Nginx代理tomcat
4.1 在linux中安装两台tomcat
- 解压两个tomcat到/usr/java,分别命名为tomcat1,tomcat2
- 修改tomcat的配置文件,将端口进行修改:
- 将资料中的test.war项目分别发布到两个tomcat中并测试
4.2 代理一台tomcat(反向代理)
- 修改nginx/conf/nginx.conf文件:
4.3 代理多台tomcat(负载均衡)
- 在http节点上添加一个upstream
- 修改location /下的反向代理
五. Nginx负载均衡策略
5.1 6种负载均衡策略
负载均衡策略 | 说明 |
轮询 | 默认 |
weight | 权重方式 |
ip_hash | 依据ip分配方式 |
least_conn | 按连接数 |
fair | 按响应时间 |
url_hash | 依据URL分配 |
5.2 权重
5.3 Tomcat集群的session共享
问题:
- 方法一:保证一个ip地址永远的访问一台tomcat服务器,就不存在session共享问题了(只支持linux)
即:upstream中添加 ip_hash;
- 方法二:session的共享
一种使用tomcat广播机制完成session的共享(只支持windows,不推荐的方式)
一种使用redis服务器的方式完成session的共享(推荐的方式)
5.4 动静分离
- 在虚拟机中新建images文件夹,并上传图片
- 配置nginx的nginx.conf
location ~* \.(gif|jpg|png|jpeg)$ {
root /usr/upload/images;
}
- 测试(这里我就不测试,谢谢)