欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP多人模块开发原理解析

程序员文章站 2022-05-26 10:58:34
作为世界上最“好”的语言,在web里占据着大概80%的份额,中小公司基本都说 lnmp 架构。当一个仓库开发人员大于1,20人的时候,每个人可能开发不同的模块和功能,用代码...

作为世界上最“好”的语言,在web里占据着大概80%的份额,中小公司基本都说 lnmp 架构。当一个仓库开发人员大于1,20人的时候,每个人可能开发不同的模块和功能,用代码版本控制工具比如 git 开不同的分支,流程大概是先在本地搭一套完整的环境,开发好部署在测试环境,自测或者测试人员测试好之后部署在预发布环境,预发布基本和线上环境一样,然后给产品验收,验收完成后再发布上线。

由于是并行开发,肯定存在好几个功能同时验收或者测试的情况,这个时候预发环境到底部署谁的代码呢?切换到a的分支,b就不能验收了。所以希望存在一个多人开发环境,每个人的开发流程互不影响。

php运行原理

首先我们来分析下 php 的运行原理,看看 php 的语言特点。当我们从浏览器发起一个请求,我们的web服务器(nginx、apache等)监听了80或者443端口,我们来看一个最简单的 nginx 的 vhost 配置:

server {
 listen    80;
 server_name test.com;
 
 root /data/gateway/html;
 index  index.php;

 location ~ \.php$ {
  fastcgi_pass  127.0.0.1:9001; #unix:/users/run/php-fcgi.sock;
  fastcgi_index index.php;
  fastcgi_param script_filename $document_root$fastcgi_script_name;
  include    fastcgi_params;
 }
}

nginx 监听80端口,当匹配到用户访问的域名是test.com后使用对应的 vhost 配置。在服务器里php-fpm起一个服务,监听一个端口(比如9001)或者一个unix socket,nginx通过fastcgi_pass配置,将请求传递给 php-fpm 来解析php代码,php解析器每次从index.php开始解析,一路处理下去、做一系列的逻辑处理、查询数据库或者缓存等操作,返回一个 html 或者其他结果给 nginx,nginx 再返回给浏览器。流程如下图:

PHP多人模块开发原理解析

cgi:是 nginx 与 php_fpm 之间数据交换的一种协议。

fastcgi:同 cgi,是一种通信协议,但比 cgi 在效率上做了一些优化。

php-cgi:是 php 对 nginx 提供的 cgi 协议的接口程序。

php-fpm:是 php 对 nginx 提供的 fastcgi 协议的接口程序,额外还提供了相对智能一些任务管理。

多人开发环境

从 php 原理我们可以看到,php其实只是一个解释型的脚本语言,每次请求都要从index.php解析一次,那我们是不是可以在服务器根据不同开发者的名字,命名很多个文件夹,在各自文件夹里,clone 好代码仓库,切换到自己的分支。再让 nginx 处理每个人目录下的index就可以了。比如直接访问http://wulv.test.com/,在 nginx 获取到 wulv,把 root 设置到 wulv 这个目录,这样就访问到 wulv 这个目录下的代码了。可以让 nginx 这样设置:

set $who www;
if ($http_who != "") {
  set $who $http_who;
}
root /data/gateway/$who/html;

我们可以让 url 里携带用户的目录,在 nginx 截取下来,可以在一下几个地方携带:

host: http://wulv.test.com

path: http://www.test.com/wulv

query: http://www.test.com?http_who=wulv

这样大体上可以实现需求了,但还是有点问题,比如页面里有些链接是写死的,没有使用相对路径,你一点击就又跑 www.test.com 去了,或者有些第三方应用比如 oauth 等需要校验域名,你和线上域名不一致根本无法登陆。所以需要其他方式来实现,比如:

http request header

cookie

我们可以使用modify headers这个浏览器插件,修改http request 头信息,设置一个参数 http_who 为 wulv,然后在 nginx 获取。

拓展

如果有条件的话,其实还可以做一个网关服务器,做一个配置页面,在配置页面里配置一下需要访问的目录,下次访问,网关就直接帮你设置http header,代理到对应服务器。这样连浏览器插件都不需要装了,对运营和产品设计更加友好。