介绍
Nginx是一款轻量级的web服务器/反向代理服务器及电子邮件(INAP/POP3)代理服务器。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx的网站有:百度、京东、新浪、网易、腾讯、淘宝等。
- Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文: Paw6nep)开发的,第一个公开版本0.1.0发布于2004年10月4日。
- 官网:nginx.org/
- 可以到Nginx官方网站下载Nginx的安装包,地址为: nginx.org/en/download…
下载和安装
安装过程:
- 安装依赖包 yum -y install gcc pcre-devel zlib-devel openssl openssl-devel
- 下载Nginx安装包wget nginx.org/download/ng…
- 先查看是否安装转wget:wget
- 没有安装则:yum install wget
- 或者直接上传安装包
- 先查看是否安装转wget:wget
- 解压tar -zxvf nginx-1.16.1.tar.gz
- cd nginx-1.16.1
- ./configure --prefix=/usr/local/nginx
- make && make install
目录结构
重点目录/文件:
- conf/nginx.conf nginx配置文件
- html 存放静态文件(html、css、s等)
- logs 日志目录,存放日志文件
- sbin/nginx 二进制文件,用于启动、停止Nginx服务
Nginx常用命令
- 查看版本号:./nginx -v
- 检查配置文件的正确性:./nginx -t (启动nginx之前那可以使用此命令检查配置文件)
- 启动nginx服务器,再查看服务进程:
- ./nginx
- ps -ef | grep nginx
- 关闭防火墙:systemctl stop firewall
- 浏览器访问ip地址
- 关闭nginx服务:./nginx -s stop
- 重新加载配置文件(修改了配置文件):./nginx -s reload
注意:以上命令需要进入sbin目录执行,否则需要使用绝对路径,需要在任何路径都是用的话添加环境变量,如下:
- 打开系统配置文件:vim /etc/profile
- 加入path: PATH=/usr/local/nginx/sbin:PATH
- 重新加载配置文件:source /etc/profile
后续可以直接再任何目录下执行nginx命令,只需要将前面的./去掉即可
Nginx配置文件结构
Nginx配置文件(conf/nginx.conf)整体分为三部分:
- 全局块: 和Nginx运行相关的全局配置
- events块: 和网络连接相关的配置
- http块: 代理、缓存、日志记录、虚拟主机配置
- http全局块
- Server块
- Server全局块
- location块
注意: http块中可以配置多个Server块,每个Server块中可以配置多个location块。
Nginx具体应用
1. 部署静态资源
Nginx可以作为静态web服务器来部署静态资源。静态资源指在服务端真实存在并且能够直接展示的一些文件,比如常见的html页面、css文件、js文件、图片、视频等资源。相对于Tomcat,Nginx处理静态资源的能力更加高效,所以在生产环境下,一般都会将静态资源部署到Nginx中。将静态资源部署到Nginx非常简单,只需要将文件复制到Nginx安装目录下的html目录中,之后启动服务器,浏览器访问文件即可。
2. 反向代理
- 正向代理:
是一个位于客户端和原始服务器(origin server)之间的服务器
为了从原始服务器取得内容,客户端向代理发送一个
请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。
正向代理的典型用途是为在防火墙内的局域网客户端提供访问Internet的途径。
正向代理一般是在客户端设置代理服务器,通过代理服务器转发请求,最终访问到目标服务器。
- 反向代理:
反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源,反向代理服务器负责将请求转发给目标服务器。
用户不需要知道目标服务器的地址,也无须在用户端作任何设定(隐藏服务器)。
反向代理的作用是为了方便统一管理客户端请求,因为通常情况我们的web程序都有多台服务器。并且服务器通常是在公司内网当中,需要通过代理服务器才能被外界访问,而Nginx是对外开放的。
- 配置反向代理:进入到nginx安装目录下的conf目录下,
- 修改文件:vim nginx.cof
- 把以下代码粘贴到http块中( proxy_pass 对应的地址是目标服务器的ip)
- 刷新配置文件:nginx -s reload
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://192.168.138.101:8080;#反向代理配置,将请求转发到指定服务
}
}
- 之后通过本机的 “ip+监听的端口号(80)+路径”就可以访问ip地址为192.168.138.101端口号为8080的服务器
3. 负载均衡
早期的网站流量和业务功能都比较简单,单台服务器就可以满足基本需求,但是随着互联网的发展,业务流量越来越大并且业务逻辑也越来越复杂,单台服务器的性能及单点故障问题就凸显出来了,因此需要多台服务器组成应用集群,进行性能的水平扩展以及避免单点故障出现(基于反向代理实现)。
- 应用集群:将同一应用部署到多台机器上,组成应用集群,接收负载均衡器分发的请求,进行业务处理并返回响应数据
- 负载均衡器:将用户请求根据对应的负载均衡算法分发到应用集群中的一台服务器进行处理
- 配置负载均衡:进入到nginx安装目录下的conf目录下
- 修改文件:vim nginx.cof
- 把以下代码粘贴到http块中( proxy_pass 对应的地址是目标服务器的ip)
- 刷新配置文件:nginx -s reload
- 配置负载均衡策略(默认为各个服务器轮询响应)
upstream targetserver{#upstream指令可以定义一组服务器
server 192.168.138.101:8080;
server 192.168.138.100:8081;
#server 192.168.138.101:8080 weight=10;
#server 192.168.138.100:8081 weight=5;这样配置按照2:1分配请求
}
server {
listen 8080;
server_name localhost;
location / {
proxy_pass http://targetserver; #此处和上面的upstream定义的名称一致即可
}
}