简介
是一个高性能的 HTTP 和反向代理服务器,特点是占有内存少,并发能力强,事实上 nginx 的并发能力确实在同类型的网页服务器中表现较好。
Nginx 可以作为静态页面的 web 服务器,同时还支持 CGI 协议的动态语言,比如 perl、php 等。但是不支持 Java。Java 程序只能通过与 tomcat 配合完成。Nginx 专为性能优化而开发, 性能是其最重要的考量,实现上非常注重效率 ,能经受高负载的考验,有报告表明能支持高达 50,000 个并发连接数。
安装
安装编译工具及库文件
yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel
在下载的过程中提示
正 在 尝 试 其 它 镜 像
的话,就继续等待吧,总会有成功的一次。
安装 PCRE
PCRE 作用是让 Nginx 支持 Rewrite 功能。
下载 PCRE 安装包,下载地址:https://nchc.dl.sourceforge.net/project/pcre/pcre/8.45/pcre-8.45.tar.gz
网盘下载地址
wget https://nchc.dl.sourceforge.net/project/pcre/pcre/8.45/pcre-8.45.tar.gz
-rw-r--r--. 1 root root 2096552 6月 22 2021 pcre-8.45.tar.gz
解压安装包
[root@localhost src]# tar zxvf pcre-8.45.tar.gz
进入安装包目录编译安装
[root@localhost src]# cd pcre-8.45
[root@localhost pcre-8.45]# ./configure
[root@localhost pcre-8.45]# make && make install
查看 pcre 版本
[root@localhost pcre-8.45]# pcre-config --version
8.45
安装 Nginx
下载地址:https://nginx.org/download/nginx-1.21.6.tar.gz
[root@localhost local]# wget https://nginx.org/download/nginx-1.21.6.tar.gz
解压安装包
[root@localhost local]# tar zxvf nginx-1.21.6.tar.gz
编译安装
[root@localhost local]# cd nginx-1.21.6
[root@localhost nginx-1.21.6]# ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --with-pcre=/usr/src/pcre-8.45
[root@localhost nginx-1.21.6]# make
[root@localhost nginx-1.21.6]# make install
查看 Nginx 版本
[root@localhost sbin]# /usr/local/nginx/sbin/nginx -v
nginx version: nginx/1.21.6
常用命令
启动 Nginx
[root@localhost /]# /usr/local/nginx/sbin/nginx
检查配置文件的准确性
[root@localhost nginx]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
重新载入配置文件
[root@localhost nginx]# /usr/local/nginx/sbin/nginx -s reload
重启 Nginx
[root@localhost nginx]# /usr/local/nginx/sbin/nginx -s reopen
停止 Nginx
[root@localhost nginx]# /usr/local/nginx/sbin/nginx -s stop
配置文件解读
#user nobody;
# 这是 Nginx 服务器并发处理服务的关键配置,worker_processes 值越大,可以支持的并发处理量也越多,但是会受到硬件、软件等设备的制约
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
# events 涉及的指令主要影响 Nginx 服务器与用户的网络连接
events {
# 支持的最大连接数是多少
worker_connections 1024;
}
# 包含 http 全局块和 server 块
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
# 监听的端口号
listen 80;
# 主机名称
server_name localhost;
location / {
root html;
index index.html index.htm;
}
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
配置文件正则表达式
location [ = | ~ | ~* | ^~ ] uri {
}
- = :用于不含正则表达式的 uri 前,要求请求字符串与 uri 严格匹配,如果匹配 成功,就停止继续向下搜索并立即处理该请求。
- ~ :用于表示 uri 包含正则表达式,并且区分大小写。
- ~* :用于表示 uri 包含正则表达式,并且不区分大小写。
- ^~ :用于不含正则表达式的 uri 前,要求 Nginx 服务器找到标识 uri 和请求字 符串匹配度最高的 location 后,立即使用此 location 处理请求,而不再使用 location 块中的正则 uri 和请求字符串做匹配。
注意:如果 uri 包含正则表达式,则必须要有 ~ 或者 ~ 标识。*
正反向代理
正向代理代理客户端,反向代理代理服务器,正向代理跟客户端同一局域网,反向代理跟服务器在同一局域网。
正向代理
如果把局域网外的Internet想象成一个巨大的资源库,则局域网中的客户端要访问Internet,则需要通过代理服务器来访问,这种代理服务就称为正向代理。
反向代理
反向代理,其实客户端对代理是无感知的,因为客户端不需要任何配置
就可以访问,我们只 需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器
获取数据后,再返回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器 IP 地址。
案例展示
简单案例
配置文件修改
server {
# 监听的端口
listen 80;
# 监听的地址名称
server_name 192.168.3.40;
location / {
root html;
# 代理的地址
proxy_pass http://192.168.3.28:2222;
index index.html index.htm;
}
}
根据路径跳转到不同的代理上
配置文件修改
server {
listen 8001;
server_name 192.168.3.40;
location ~ /buy_goods2 {
proxy_pass http://192.168.3.28:2222;
}
location ~ /buy_goods1 {
proxy_pass http://192.168.3.28:1111;
}
}
负载均衡
单个服务器解决不了,我们增加服务器的数量,然后将请求分发到各个服务器上,将原先请求集中到单个服务器上的情况改为将请求分发到多个服务器上,将负载分发到不同的服务器,也就是我们 所说的负载均衡。
案例展示
http 块中增加一下配置信息:
upstream myserver {
server 192.168.3.28:1111;
server 192.168.3.28:2222;
}
server 块中增加如下配置信息:
server {
listen 80;
server_name 192.168.3.40;
location / {
root html;
proxy_pass http://myserver;
index index.html index.htm;
}
负载均衡的策略
轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除。
weight
weight 代表权重,默认为 1,权重越高被分配的客户端越多。
指定轮询几率,weight 和访问率成正比,用于后端服务器性能不均的情况。
upstream myserver {
server 192.168.3.28:1111 weight=10;
server 192.168.3.28:2222 weight=5;
}
ip_hash
每个请求按访问 ip 的 hash 结果分配,这样每个访客固定访问一个后端服务器,可以解决 session 的问题
。
upstream myserver {
ip_hash;
server 192.168.3.28:1111;
server 192.168.3.28:2222;
}
fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
upstream myserver {
server 192.168.3.28:1111;
server 192.168.3.28:2222;
fair
}
动静分离
为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度。降低原来单个服务器的压力。
Nginx 动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离。严格意义上说应该是动态请求跟静态请求分开,可以理解成使用 Nginx 处理静态页面,Tomcat 处理动态页面。动静分离从目前实现角度来讲大致分为两种:
一种是纯粹把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案;
另外一种方法就是动态跟静态文件混合在一起发布,通过 nginx 来分开。
通过 location 指定不同的后缀名实现不同的请求转发。通过 expires 参数设置,可以使浏览器缓存过期时间,减少与服务器之前的请求和流量。
具体 Expires 定义:是给一个资源设定一个过期时间,也就是说无需去服务端验证,直接通过浏览器自身确认是否过期即可, 所以不会产生额外的流量。此种方法非常适合不经常变动的资源。(如果经常更新的文件, 不建议使用 Expires 来缓存),我这里设置 3d,表示在这 3 天之内访问这个 URL,发送一个请求,比对服务器该文件最后更新时间没有变化,则不会从服务器抓取,返回状态码 304,如果有修改,则直接从服务器重新下载,返回状态码 200。
来源:https://www.cnblogs.com/lhnstart/p/16065054.html
本站部分图文来源于网络,如有侵权请联系删除。