1、什么是Nginx
Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,使用c语言编写的一款web服务软件.
Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
2、为什么使用Nginx
作用:反向代理,负载均衡,动静分离
3、如何使用Nginx
3.1安装nginx的依赖
- yum install -y gcc-c++
- yum install -y pcre pcre-devel
- yum install -y zlib zlib-devel
- yum install -y openssl openssl-devel
3.2上传nginx安装包并解压
/usr/local/soft/
tar -zxvf 安装包名
3.3创建一个nginx的安装目录
mkdir /usr/nginx
3.4进入nginx的解压目录并指定安装到/usr/nginx
./configure --prefix=/usr/nginx
3.5安装
make 编译
make install 安装
3.6启动nginx
1.进入nginx安装目录的sbin目录 /usr/nginx/sbin
2. ./nginx
3.7浏览器访问nginx
4、介绍nginx的目录结构
conf: 配置文件。
html: 静态资源,
logs: 日志。如果你nginx启动失败。查看该日志
sbin: 启动脚本。
./nginx 启动
./nginx -s stop 关闭
./nginx -s reload 重新加载配置文件
4.1nginx的配置文件的内容
5、反向代理
1. 正向代理: 代理的为客户端,对于互联网服务器来说,不知道真实的客户地址。
2. 反向代理: 代理的为服务端,对于客户来说,不知道访问的到底是那台服务器。
如何使用nginx完成反向代理
- nginx---->192.168.223.140 --------- web服务器--->192.168.223.157
- 在192.168.223.157服务部署咱们的项目并启动 ---------- java -jar 项目名
- 在192.168.223.140上修改nginx的配置 --------- 重新加载nginx的配置文件
- 访问nginx地址。
6、负载均衡
nginx---192.168.223.140 两台web应用服务器 【192.168.223.140 192.168.223.157】
步骤:在140和157部署并启动web应用服务器
修改nginx的配置内容
测试
负载均衡的策略默认为轮询策略
轮询策略
权重策略:
ip哈希策略
url哈希策略---依赖第三方插件
7、动静分离
动静分离: 把服务器端的静态资源和动态资源分开处理。
【动态资源:--->内容会随着服务器返回的结果而变化。-->jsp模板引擎】
【静态资源:--->css.js.image.html】
上面的请求可以发现: 我们每次发送请求动态资源时,服务端会把动态资源返回给客户,可以获取动态资源后,该动态资源可能依赖一些静态资源,客户拿到动态资源后,还有向服务发送请求静态资源。这是相当于服务处理了静态服务。这样明显服务压力太大。 而且服务如果是集群,那么服务器对静态资源的维护比较麻烦。 我们可以使用nginx实现服务器的动静分离。
如何配置动静分离
(1)把静态资源放入nginx的安装目录
(2)修改配置文件
(3) 启动nginx和tomcat
(4)访问nginx地址
8、Nginx的高可用
如何体现高可用
1. 两台: 140 Master 141 backup
2. 需要在每一个nginx服务器上安装keepalived 默认安装路径: /etc/keepalived
yum install keepalived 安装keepalived
rpm -q -a keepalived 检查是否安装keepalived
3. 修改keepalive的配置文件
4. 开启keepalived和nginx服务
1. ./nginx
2. sytemctl start keepalived.service
5. 测试访问
6. 测试主节点宕机