client和nginx简易交互过程

client和nginx简易交互过程

# client和nginx简易交互过程

– step1:client发起http请求
– step2:dns服务器解析域名得到主机ip
– step3:默认端口为80,通过ip+port建立tcp/ip链接
– step4:建立连接的tcp/ip三次握手,建立成功发送数据包
– step5:nginx匹配请求

  – case .html: 静态内容,分发静态内容响应
  – case .php: php脚本,转发请求内容到php-fpm进程,分发php-fpm返回的内容响应

– step6:断开连接的tcp/ip四次握手,断开连接

# nginx和php简易交互过程

– 背景:web server和服务端语言交互依赖的是cgi(Common Gateway Interface)协议,由于cgi效率不高(每次请求都需要重新起一个php-cgi解析器进程,
        这中间会进行加载php.ini配置等一系列的操作)所以后期产生了fastcgi协议(一种常驻型的cgi协议),php-cgi实现了fastcgi,但是相比php-cgi,php-fpm提供
        了更好的PHP进程管理方式,可以有效控制内存和进程并可以平滑重载PHP配置
– 流程:

  – step1:nginx接收到一条http请求,会把环境变量,请求参数转变成php能懂的php变量

    “`
    // nginx 配置资料
    location ~ \.php$ {

        include snippets/fastcgi-php.conf; //step1
        fastcgi_pass unix:/run/php/php7.0-fpm.sock;
    }
    “`

  – step2:nginx匹配到.php结尾的访问通过fastcgi_pass命令传递给php-fpm.sock文件,其实这里 的ngnix发挥的是反向代理的角色,把http协议请求转到fastcgi协议请求

    “`
    // nginx 配置资料
    location ~ \.php$ {

        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/run/php/php7.0-fpm.sock;// step2
    }
    “`

  – step3:php-fpm.sock文件会被php-fpm的master进程所引用,这里nginx和php-fpm使用的是 linux的进程间通信方式unix domain socks,是一种基于文件而不是网络底册协议的通信方式

  – step4:php-fpm的master进程接收到请求后,会把请求分发到php-fpm的子进程,每个php-fpm 子进程都包含一个php解析器
  – step5:php-fpm进程处理完请求后返回给nginx

 # 附录

 – php-fpm进程管理的三种方式
    + static: 静态方式,php-fpm启动时及启动最大子进程数,优点是不需要额外的fork子进程过程,适合专门的服务器
        – 参数:
            – pm.max_children: 最大子进程数
    + dynamic: 动态方式,配置最大数和启动数,空闲数,实际使用过程fork进程,优点灵活节省内存,缺点fork过程有性能消耗
        – 参数:
            – pm.max_children: 最大进程数
            – pm.start_servers: 启动数,等于min_spare_servers + (max_spare_servers – min_spare_servers)/2
            – pm.min_spare_servers: 最小空闲进程数,如果空闲进程(idle)数小于该值,启动一个子进程
            – pm.max_spare_servers: 最大空闲进程数,如果空闲进程(idle)数大于该值,kill一个子进程
    + ondemand: 按需方式, 不启动子进程,按需fork,优点节省资源
        – 参数:
            – pm.max_children:
            – pm.process_idle_timeout: 子进程空闲多少秒后被kill

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113824.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 撸明白分布式事务(四)

    撸明白分布式事务(四)前言在分布式系统中,消息队列在服务端的架构中的地位非常重要,主要解决异步处理、系统解耦、流量削峰等场景。多个系统之间如果同步通信很容易造成阻塞,同时会将这些系统会耦合在一起。因此,引入了消息队列,一方面解决了同步通信机制造成的阻塞,另一方面通过消息队列进行业务解耦。简单的服务间调用引入mq如下图所示可靠事件模式可靠事件模式,通过引入可靠的消息队列,只要保证当前的可靠事件投递并且消息队列确保事件传递至少一次,那么订阅这个事件的消费者保证事件能够在自己的业务内被消费即可。这里,请读者思考,是否.

    2022年8月22日
    6
  • 分析哲学_怎样查看bugreport

    分析哲学_怎样查看bugreportGetLogfromAndroidSystemadbbugreport>bugreport.txtcopybugreporttothecurrentdirectory.b

    2022年8月1日
    5
  • ConcurrentHashMap

    ConcurrentHashMap

    2021年8月28日
    55
  • FC游戏 《三国志2-霸王的大陆》攻略「建议收藏」

    FC游戏 《三国志2-霸王的大陆》攻略「建议收藏」《三国志2-霸王的大陆》是日本南梦宫公司研发的一款历史战略模拟游戏,于1992年06月10日在红白机平台上发行。在开始游戏选择君主时(一定要在君主未出现前的画面时进行第二步),按住1P的START不要放,按住START同时,连续依次按上,下,左,右,按满3次,听到“乒”一下的声音后再开始游戏,这时再选君主:君主城金钱、兵马、宝等全满。一、武将1)武将出场时间189年-190…

    2025年8月19日
    3
  • idea打包java项目生成jar_idea打包项目

    idea打包java项目生成jar_idea打包项目Idea打包java项目、点击加号Artifacts工件一定要双击加入到左侧再运行jar包java-jardemo.jar包名.jar

    2022年9月27日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号