php是一门编程语言,可以编写很多程序,但是只有php的话,你的php只能在你的服务器里孤立的运行,比如你用php写了一个可以通过身高计算人的标准体重的程序,虽然这个程序可以在服务器运行,但是他还不能和客户交互,因为客户现在还不能访问你的php程序,他也不会去下载你的php程序到自己电脑里运行,他只想默默的通过浏览器告诉你他的身高,然后得到这个程序返回的体重,那么谁来得到这个用户发送过来的请求呢,又怎么把请求数据转发给对应的php程序呢 ?

  nginx就是为了解决上述问题而出现的,nginx是一个已经写好的程序,需要安装配置,作用是专门接收处理客户通过浏览器等发送来的请求,并和你写的php程序交互,就这么简单,但是nginx不仅可以和你写的php程序交互,也可以和你写的其他程序交互,比如C,python,因为不是所有人都用php来写web程序,简单点说nginx是一个可以监听处理http请求(浏览器请求)的程序,会装会配置,知道流程就可以用了,当然深入了解下就更好了。

  这样的话,nginx就可以比喻处理成处理http请求业务的部门,是服务器和外部千千万万浏览器等客户端进行沟通的关口。php是服务器内部一个数据加工部门,可以加工生成各种页面。客户端发送的http请求历经层层路由到达你的服务器,然后被nginx逮个正着,统一听候nginx大人的调度,如果客户请求的是其他静态资源,比如txt文本,图片等,nginx直接找到该资源,并返回给客户端,如果客户请求的是php程序,就找到对应的php程序,然后把客户数据给这个程序,让这个php程序运行一遍,再把这个程序运行的结果返回给客户端。

PHP的sapi有fpm的运行模式,或者说接口,就是一种访问PHP这个软件的方式,nginx配合fpm这个接口,访问PHP程序,实现和PHP的配合。

  1. 启动php-fpm后,监听一个端口,默认监听9000(见配置文件listen = 127.0.0.1:9000)
  2. 然后nginx配置,如果是PHP文件,则转发给php-fpm程序处理。
  3. 接下来,当nginx软件收到一个客户端的请求后,根据配置文件判断是否是PHP文件,如果是,则转发给fpm程序,fpm处理完之后返回结果给nginx,nginx再返回结果给客户端。

PHP-FPM,Nginx,FastCGI 之间的关系

FastCGI 是一个协议,它是应用程序和 WEB 服务器连接的桥梁。Nginx 并不能直接与 PHP-FPM 通信,而是将请求通过 FastCGI 交给 PHP-FPM 处理。

location ~ \.php$ {
try_files $uri /index.php =404;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_buffers 16 16k;
fastcgi_buffer_size 32k;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}

这里 fastcgi_pass 就是把所有 php 请求转发给 php-fpm 进行处理。通过 netstat 命令可以看到,127.0.0.1:9000 这个端口上运行的进程就是 php-fpm.

Nginx 反向代理

Nginx 反向代理最重要的指令是 proxy_pass,如:

location ^~ /seckill_query/ {
proxy_pass http://ris.xxmail.gdrive:8090/;
proxy_set_header Host ris.xxmail.gdrive;
} location ^~ /push_message/ {
proxy_pass http://channel.xxmail.gdrive:8090/;
proxy_set_header Host channel.xxmail.gdrive;
} location ^~ /data/ {
proxy_pass http://ds.xxmail.gdrive:8087/;
proxy_set_header Host ds.xxmail.gdrive;
}

通过 location 匹配 url 路径,将其转发到另外一个服务器处理。

通过负载均衡 upstream 也可以实现反向代理。

Nginx 负载均衡

介绍一下 upstream 模块:

负载均衡模块用于从”upstream”指令定义的后端主机列表中选取一台主机。nginx先使用负载均衡模块找到一台主机,再使用upstream模块实现与这台主机的交互。

负载均衡配置:

upstream php-upstream {
ip_hash; server 192.168.0.1;
server 192.168.0.2;
} location / {
root html;
index index.html index.htm;
proxy_pass http://php-upstream;
}

该例定义了一个 php-upstream 的负载均衡配置,通过 proxy_pass 反向代理指令应用这个配置。这里用的 ip_hash 算法,负载均衡的算法有多种,就不一一列举了。

负载均衡也可以用在 fastcgi_pass 上。

如:

fastcgi_pass http://php-upstream

如果使用负载均衡,可能存在一个 session 失效的问题,你的每次请求可能分配到不同的服务器,一个解决方法是把 Memcached 或 Redis 作为 session 存储的方式,而且还可以提高性能。

一些问题

反向代理和负载均衡是什么关系

反向代理和负载均衡这两个词经常出现在一起,但他们实际上是不同的概念,负载均衡它更多的是强调的是一种算法或策略,将请求分布到不同的机器上,因此实际上也起到了反向代理的作用。

proxy_pass 和 fastcgi_pass 的区别

一个是反向代理模块,一个是转发给 factcgi 后端处理。

最新文章

  1. ssh整合问题总结--使用HibernateTemplate实现数据分页展示
  2. TeXmacs 中输入狄拉克 braket 符号
  3. delphi数据类型及占用的字节数 C++ 对应数据类型
  4. Fortify
  5. WPA破解原理简要——无线网络破解续
  6. MS sql server 基础知识回顾(二)-表连接和子查询
  7. Quiz(贪心,快速幂乘)
  8. Matlab实现加性高斯白噪声信道(AWGN)下的digital调制格式识别分类
  9. DESCryptoServiceProvider加密、解密
  10. jQuery Validate 插件[表单验证 属性介绍]
  11. node学习第一篇
  12. repeater控件自定义Url分页带参数
  13. cron任务解释
  14. [转] KVM虚拟化技术生态环境介绍
  15. python使用tcp实现一个简单的下载器
  16. 基于CC2530/CC2430 的光强采集系统--ADC实验
  17. 潭州课堂25班:Ph201805201 django 项目 第三十六课 后台文章管理(课堂笔记)
  18. Request参数值自动去空格
  19. centos7.2部署vnc服务记录
  20. PL/SQL学习笔记之函数

热门文章

  1. 2017.10.2 国庆清北 D2T1 (a*b)|x
  2. mysql开放远程连接
  3. HTTP与RPC(Thrift)
  4. ubuntu之路——day11.7 end-to-end deep learning
  5. js DOM之基础详解
  6. 【转】理解Docker容器网络之Linux Network Namespace
  7. InvalidSelectorError: Compound class names not permitted报错处理
  8. 012-Shell 提示确认(Y / N,YES / NO)
  9. 顶部导航TabBar、TabBarView、DefaultTabController
  10. Cannot start service WMSvc on computer '.'.