概述
Nginx
- 简介
- 下载与安装
- nginx常用命令
- nginx配置文件
- 第一部分:全局块
- 第二部分: events 块
- 第三部分: http 块
- 反向代理
- 实例一
- 实例二
- location 指令说明
- 负载均衡
- 限流
- 动静分离
- 高可用
简介
Nginx ("engine x)是一个高性能的HTTP和反向代理服务器,特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好
Nginx.专为性能优化而开发,性能是其最重要的考量,实现上非常注重效率,能经受高负载的考验,有报告表明能支持高达50,000个并发连接数
Nginx主要涉及的概念
- 反向代理
- 负载均衡
- 动静分离
反向代理
反向代理,其实客户端对代理是无感知的,因为客户端不需要任何配置就可以访问,我们只需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,在返回给客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址。
负载均衡
单个服务器解决不了,我们增加服务器的数量,然后将请求分发到各个服务器上,将原先请求集中到单个服务器上的情况改为将请求分发到多个服务器上,将负载分发到不同的服务器,也就是我们所说的负载均衡
动静分离
为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度。降低原来单个服务器的压力。|I
下载与安装
官网地址http://nginx.org/,下载地址http://nginx.org/en/download.html
下载完直接解压
启动,第1种:直接双击nginx.exe文件
启动,第2种(推荐):nginx.exe文件目录下cmd,执行命令nginx.exe或者nginx,没报错那就是启动成功(即使一点信息都没有输出),如图所示
访问http://localhost/
因为默认监听的是80端口,如图所示
退出,nginx.exe文件目录下cmd,执行命令nginx -s stop,如图所示
nginx常用命令
如果没有配置环境变量的话,那么cmd要在nginx的目录
命令 | 说明 |
---|---|
nginx -v | 查看版本号 |
start nginx或者nginx | 启动nginx |
nginx -s stop | 关闭,快速停止nginx,可能并不保存相关信息 |
nginx -s quit | 关闭,完整有序的停止nginx,并保存相关信息 |
nginx.exe -s reload | 当配置信息修改,需要重新载入这些配置时使用此命令 |
nginx.exe -s reopennginx.exe -s reopen | 重新打开日志文件 |
nginx配置文件
nginx配置文件路径为:(nginx安装目录)confnginx.conf,必须以分号;结尾
配置文件中的内容包含三部分内容:
- 第一部分:全局块
- 第二部分: events 块
- 第三部分: http 块
第一部分:全局块
#user nobody;
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 服务器整体运行的配置指令,主要包括:
- 配置运行 Nginx 服务器的用户(组)、
- 允许生成的 worker process 数,
- 进程 PID 存放路径、
- 日志存放路径和类型
- 配置文件的引入
- …
比如上面第一行配置的:
worker_processes 1;
这是Nginx服务器并发处理服务的关键配置,worker_processes 值越大,可以支持的并发处理量也越多,但是会受到硬件、软件等设备的制约
第二部分: events 块
events {
worker_connections 1024;
}
上述例子就表示每个 work process 支持的最大连接数为 1024
events 块涉及的指令主要影响 Nginx 服务器与用户的网络连接,常用的设置包括是否开启对多 work process 下的网络连接进行序列化,是否允许同时接收多个网络连接,选取哪种事件驱动模型来处理连接请求,每个 work process 可以同时支持的最大连接数等。这部分的配置对 Nginx 的性能影响较大,在实际中应该灵活配置。
第三部分: http 块
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 logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html;
index index.html index.htm;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ .php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ .php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /.ht {
# deny all;
#}
}
# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias;
# location / {
# root html;
# index index.html index.htm;
# }
#}
# HTTPS server
#
#server {
# listen 443 ssl;
# server_name localhost;
# ssl_certificate cert.pem;
# ssl_certificate_key cert.key;
# ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 5m;
# ssl_ciphers HIGH:!aNULL:!MD5;
# ssl_prefer_server_ciphers on;
# location / {
# root html;
# index index.html index.htm;
# }
#}
}
这算是 Nginx 服务器配置中最频繁的部分,代理、缓存和日志定义等绝大多数功能和第三方模块的配置都在这里。需要注意的是: http 块也可以包括:
- http 全局块
- server 块
http 全局块
http 全局块配置的指令包括文件引入、 MIME-TYPE 定义、日志自定义、连接超时时间、单链接请求数上限等
server 块
这块和虚拟主机有密切关系,虚拟主机从用户角度看,和单一独立的硬件主机是完全一样的,该技术的产生是为了节省互联网服务器硬件成本。每个 http 块可以包括多个 server 块,而每个 server 块就相当于一个虚拟主机。而每个 server 块也分为:
- 全局 server 块
- 多个 locaton 块
全局 server 块
最常见的配置是本虚拟机主机的监听配置和本虚拟主机的名称或 IP 配置
多个 locaton 块
一个 server 块可以配置多个 location 块。这块的主要作用是基于 Nginx 服务器接收到的请求字符串(例如 server_name/uri-string),对虚拟主机名称(也可以是 IP 别名)之外的字符串(例如 前面的 /uri-string)进行匹配,对特定的请求进行处理。地址定向、数据缓存和应答控制等功能,还有许多第三方模块的配置也在这里进行。
反向代理
实例一
实现效果:通过一个地址代理到我们的服务器,访问http://localhost:6677/test,跳转到http://127.0.0.1:8081/test
我们的服务正常访问
通过反向代理,访问另一个地址访问到我们的服务,nginx配置文件
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
#监听地址和端口
listen 6677;
server_name localhost;
location / {
root html;
#代理到我们真实的地址
proxy_pass http://127.0.0.1:8081/;
index index.html index.htm;
}
}
}
代理结果,访问我们的代理地址,可以访问的我们的真实地址
实例二
实现效果:通过反向代理,根据访问的路径跳转到不同端口的服务中
- 访问 http://127.0.0.1:6677/test1,跳转到 127.0.0.1:8081/test1
- 访问 http://127.0.0.1:6677/test2,跳转到 127.0.0.1:8082/test2
我们的服务正常访
nginx配置文件
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
#监听地址和端口
listen 6677;
server_name localhost;
location ~ /test1 {
proxy_pass http://127.0.0.1:8081/;
}
location ~ /test2 {
proxy_pass http://127.0.0.1:8082/;
}
}
}
注意,http://127.0.0.1:8082后不要添加路径,如http://127.0.0.1:8082/test2,否则,ngnix启动失败,抛出异常[emerg] 7288#6368: “proxy_pass” cannot have URI part in location given by regular expression, or inside named location, or inside “if” statement, or inside “limit_except” block in D:SoftwareDevelopmentnginxnginx-1.18.0/conf/nginx.conf:21
Nginx会将域名后的路径自动添加到反代理的域名后,例如浏览器地址输入http://127.0.0.1:6677/test1反向代理到http://127.0.0.1:8081/test1
运行结果
- 地址栏输入http://127.0.0.1:6677/test1则返回http://127.0.0.1:8081/test1的结果
- 地址栏输入http://127.0.0.1:6677/test2则返回http://127.0.0.1:8082/test2的结果
location 指令说明
该指令用于匹配 URL,语法如下:
location [ = | ~ | ~* | ^~ ] uri {
}
- = :用于不含正则表达式的 uri 前,要求请求字符串与 uri 严格匹配,如果匹配成功,就停止继续向下搜索并立即处理该请求。
- ~:用于表示 uri 包含正则表达式,并且区分大小写。
- ~*:用于表示 uri 包含正则表达式,并且不区分大小写。
- ^~:用于不含正则表达式的 uri 前,要求 Nginx 服务器找到标识 uri 和请求字符串匹配度最高的 location 后,立即使用此 location 处理请求,而不再使用 location块中的正则 uri 和请求字符串做匹配。
负载均衡
实现效果:浏览器地址栏输入地址http://127.0.0.1:6677/test,负载均衡效果,平均 8081和 8082 端口中。
我们的服务正常访
nginx配置文件
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
# upstream是负载均衡的标识,myServer是负载均衡的定义名字,名字随便取,下面会用到
upstream myServer{
server 127.0.0.1:8081;
server 127.0.0.1:8082;
}
server {
#监听地址和端口
listen 6677;
server_name localhost;
location / {
# 负责用到负载均衡的配置,myServer是上面定义的名字
proxy_pass http://myServer;
root html;
index index.html index.htm;
}
}
}
负载均衡分配策略
负载均衡(load balance)即是将负载分摊到不同的服务单元,既保证服务的可用性,又保证响应足够快,给用户很好的体验。快速增长的访问量和数据流量催生了各式各样的负载均衡产品,很多专业的负载均衡硬件提供了很好的功能,但却价格不菲,这使得负载均衡软件大受欢迎,nginx 就是其中的一个,在 linux 下有 Nginx、 LVS、 Haproxy 等等服务可以提供负载均衡服务,而且 Nginx 提供了几种分配方式(策略)
轮询:
这是Ngnix负载均衡默认分配策略。每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除。
加权:
weight 代表权,重默认为 1,权重越高被分配的客户端越多。指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。例如:
upstream myServer{
server 127.0.0.1:8081 weight=8;
server 127.0.0.1:8082 weight=2;
}
ip_hash:
每个请求按访问 ip 的 hash 结果分配,这样每个访客固定访问一个后端服务器,可以解决 session 的问题。 例如:
upstream myServer{
ip_hash;
server 127.0.0.1:8081;
server 127.0.0.1:8082;
}
fair:
这是Ngnix负载均衡第三方分配策略。按后端服务器的响应时间来分配请求,响应时间短的优先分配。
upstream myServer{
server 127.0.0.1:8081;
server 127.0.0.1:8082;
fair;
}
可能需要额外安装,否则就抛出异常[emerg] 7032#7120: unknown directive “fair” in D:SoftwareDevelopmentnginxnginx-1.18.0/conf/nginx.conf:18
限流
限流我觉得这个 说的不错http://www.360doc.com/content/20/0528/10/70177275_915097945.shtml
动静分离
Nginx 动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离。严格意义上说应该是动态请求跟静态请求分开,可以理解成使用 Nginx 处理静态页面, Tomcat 处理动态页面。动静分离从目前实现角度来讲大致分为两种:
一种是纯粹把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案;
另外一种方法就是动态跟静态文件混合在一起发布,通过 nginx 来分开。
通过 location 指定不同的后缀名实现不同的请求转发。通过 expires 参数设置,可以使浏览器缓存过期时间,减少与服务器之前的请求和流量。具体 Expires 定义:是给一个资源设定一个过期时间,也就是说无需去服务端验证,直接通过浏览器自身确认是否过期即可,所以不会产生额外的流量。此种方法非常适合不经常变动的资源。(如果经常更新的文件,不建议使用 Expires 来缓存)若将其设置 3d,表示在这 3 天之内访问这个 URL,发送一个请求,比对服务器该文件最后更新时间没有变化,则不会从服务器抓取,返回状态码304,如果有修改,则直接从服务器重新下载,返回状态码 200。
先看我们的静态资源目录
我们动态服务正常访问
nginx配置
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
#监听地址和端口
listen 6677;
server_name localhost;
# 主要配置内容
location /image {
alias D:/Data/image/;
autoindex on;
}
location ~ /test {
proxy_pass http://127.0.0.1:8081;
}
}
}
实现动态访问
实现动静态访问
高可用
为什么要配置nginx高可用?以防单一nginx挂了,另一个nginx能担当重任。这个需要 keepalived
这个我一个后端时间有限,能力有限,各位看官见谅了,还望自己去百度,等我有时间了再补上哈。
最后
以上就是听话康乃馨为你收集整理的nginx,一个高性能和反向代理服务器简介下载与安装nginx常用命令nginx配置文件反向代理负载均衡限流动静分离高可用的全部内容,希望文章能够帮你解决nginx,一个高性能和反向代理服务器简介下载与安装nginx常用命令nginx配置文件反向代理负载均衡限流动静分离高可用所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复