作为世界上最“好”的语言,在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 再返回给浏览器。流程如下图:
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,代理到对应服务器。这样连浏览器插件都不需要装了,对运营和产品设计更加友好。
原文链接:https://segmentfault.com/a/1190000012298594
|