注册不讲了,github授权。
该工具的研究来源于我看了一个工具[php monitor](https://github.com/laynefyc/php-monitor/blob/master/README-zh_CN.md) 的里面有一个扩展,tidaways。官方个给的 [windows扩展](https://ci.appveyor.com/project/tideways/php-profiler-extension) 点过去却看不到构建产物。
![](https://img.kancloud.cn/8e/3d/8e3d1a0b56967f55dbcfe0dba6334354_1034x331.png)
![](https://img.kancloud.cn/35/d8/35d890833f201efaab677f926097d897_1046x306.png)
于是研究了下如何用他自己生成windows用的php扩展。
首先,是自己fork了一下官方的仓库到yangweijie 账号下。
登录后有个导入项目
![](https://img.kancloud.cn/d8/1a/d81af5c1920a39f89b356e9f1e2c9657_1056x896.png)
将其导入。因为里面如果需要交互发布zip 作为release 到github 那肯定需要github 的token 的。所以想着是将仓库转私有 再新建导入。结果发先fork 的不能转私有。网上有说免费如何用私有库的,没试。
主要是将官方的token 通过加密后再写到.deplo 里的auth_token 里。本来想着用环境变量的,结果折腾半天读取不对。
![](https://img.kancloud.cn/f0/09/f009b5be376d8feaf0d0b782a84aff4e_1259x909.png)
原官方 appveyor 配置。
~~~ yaml
image: Visual Studio 2015
version: '{branch}.{build}'
cache:
- c:\build-cache -> .appveyor.yml, .appveyor/*.cmd
environment:
PHP_BUILD_CACHE_BASE_DIR: c:\build-cache
PHP_BUILD_OBJ_DIR: c:\obj
PHP_BUILD_CACHE_SDK_DIR: c:\build-cache\sdk
PHP_BUILD_SDK_BRANCH: php-sdk-2.2.0
SDK_REMOTE: https://github.com/OSTC/php-sdk-binary-tools.git
SDK_BRANCH: php-sdk-2.2.0
matrix:
- PHP_REL: 8.0
ARCHITECTURE: x64
ZTS_STATE: enable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
PHP_BUILD_CRT: vs16
- PHP_REL: 8.0
ARCHITECTURE: x64
ZTS_STATE: disable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
PHP_BUILD_CRT: vs16
- PHP_REL: 8.0
ARCHITECTURE: x86
ZTS_STATE: enable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
PHP_BUILD_CRT: vs16
- PHP_REL: 8.0
ARCHITECTURE: x86
ZTS_STATE: disable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2019
PHP_BUILD_CRT: vs16
- PHP_REL: 7.4
ARCHITECTURE: x64
ZTS_STATE: enable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.3
ARCHITECTURE: x64
ZTS_STATE: enable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.2
ARCHITECTURE: x64
ZTS_STATE: enable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.4
ARCHITECTURE: x64
ZTS_STATE: disable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.3
ARCHITECTURE: x64
ZTS_STATE: disable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.2
ARCHITECTURE: x64
ZTS_STATE: disable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.4
ARCHITECTURE: x86
ZTS_STATE: enable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.3
ARCHITECTURE: x86
ZTS_STATE: enable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.2
ARCHITECTURE: x86
ZTS_STATE: enable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.4
ARCHITECTURE: x86
ZTS_STATE: disable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.3
ARCHITECTURE: x86
ZTS_STATE: disable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
- PHP_REL: 7.2
ARCHITECTURE: x86
ZTS_STATE: disable
APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2017
PHP_BUILD_CRT: vc15
install:
- .appveyor\install.cmd
build_script:
- .appveyor\build.cmd
~~~
可以看出来 和 github action 编译php扩展一样。用到了矩阵。
我们要做的就是补上gitbub 部署那步。
官方文档是这么写的,
![](https://img.kancloud.cn/36/ac/36aca61f7a5d85e7fda57328427631cf_790x277.png)
auth_token 通过account 里的加密yaml
![](https://img.kancloud.cn/10/03/1003cfe2cfa21c6add3056a4bcf06c55_1039x466.png)
获取到就行,别人最多拿到加密后字符串也没法操作你的github其他 只能用于构建。
然后我就尝试构建。
![](https://img.kancloud.cn/a6/d8/a6d88529e74e9d53e962f64ae8e6b4c9_1031x663.png)
经过多此尝试后终于构建成功了第一次。
点击项目下 构建历史,右面显示 jobs
![](https://img.kancloud.cn/23/6b/236b30de01b0bbdb72e5feea3d18825f_1039x320.png)
能看到4个job 因为我精简了, 只构建7.4, 8.0 (x86、x64)。不然一个任务job不完成,会影响下次提交导致的构建(排队中)。只能手动取消。他文档里说 可以在构建初始化时后,rdp远程连接电脑看。
![](https://img.kancloud.cn/81/51/815143716e6f9e10878a5e73f3416741_780x357.png)
为了搞清楚最后构建成功的文件在哪里。我就加上了。 他每次远程后会在桌面产生一个delete 开头的文件。构建后job 就卡住,删除文件就会继续job 测试生成的dll。
![](https://img.kancloud.cn/88/d5/88d5373089f4483897332c6cd7b418db_994x394.png) 加上后 init 会显示机器远程ip:端口 用户名都固定的,密码是
![](https://img.kancloud.cn/6a/b0/6ab01aeca33e936c5eaaf8fec07f4237_540x178.png)
自己配的。
最终研究发现 他会在被远程的电脑上建一个project 里clone 除php-src 源码,然后将源码 拉取到ext 目录里,构建的dll 在build目录下。
![](https://img.kancloud.cn/f8/4d/f84dd3a68cb113f556301ddf8f4824de_779x643.png)
然而,我第一次成功的名字都很奇怪,只有源码的zip。
![](https://img.kancloud.cn/17/10/1710a73923c95cd3ea7684892eaa7158_1201x480.png)
这个得细看文档。
![](https://img.kancloud.cn/79/65/7965d9f6b2b4266ac187880145dd693e_858x799.png)
~~~
release: php_tideways_xhprof-v$(APPVEYOR_BUILD_VERSION)
~~~
当时yaml 是这么写的,v 因为没有tag name 他只好以分支名来作为tag,5是第5次发布。
后来既然能生成了,我干脆改了。
![](https://img.kancloud.cn/95/fe/95fecd39ec5dc59ec2d1314288716db9_405x134.png) 固定了一个名字
![](https://img.kancloud.cn/f7/f0/f7f08754006469f474c888ba90aa001e_590x63.png) 补了一个tag name 的环境变量。结合架构,php版本。
这个源码的压缩包怎么来的。
![](https://img.kancloud.cn/d8/ed/d8ed01cc6aeabb3aedcbb9030611421b_1779x868.png)
build_task.cmd 里有 7zip 压缩ext/扩展源码为压缩包,最后上传。
我依葫芦画瓢,补上了 build下dll 压缩 为dll.zip,并上传至产物。
![](https://img.kancloud.cn/39/fc/39fc662f00e20907daa0779b7f4860ca_1041x177.png)
![](https://img.kancloud.cn/5c/a6/5ca65d43b0e9f34b09c3cb2988c49f5a_979x368.png)
最终我研究了半天 上传至github 只需要把deploy 下的 artifacts 或 artifacts 删除用默认的,保证 build_cmd里有
~~~
7z a php_tideways_xhprof-%APPVEYOR_REPO_TAG_NAME%-%PHP_REL%-%PHP_BUILD_CRT%!ZTS_IN_FILENAME!!ARCH_IN_FILENAME!.zip %APPVEYOR_BUILD_FOLDER%\php_tideways_xhprof-%PHP_REL%-!ZTS_SHORT!-%PHP_BUILD_CRT%-%PHP_SDK_ARCH%\*
appveyor PushArtifact php_tideways_xhprof-%APPVEYOR_REPO_TAG_NAME%-%PHP_REL%-%PHP_BUILD_CRT%!ZTS_IN_FILENAME!!ARCH_IN_FILENAME!.zip -FileName php_tideways_xhprof-%APPVEYOR_REPO_TAG_NAME%-%PHP_REL%-%PHP_BUILD_CRT%!ZTS_IN_FILENAME!!ARCH_IN_FILENAME!.zip
~~~
类似这两行代码
就是将build\扩展名目录压缩为压缩包,然后上传至本地ci 的产物里。所有产物都会被上传作为release的附件。压缩包内容类似
![](https://img.kancloud.cn/fb/14/fb14c2846377a5571c9938d8a5fa5e66_989x119.png)
![](https://img.kancloud.cn/0a/cb/0acb6313d47644ac85bd964f2648fd8c_966x448.png)
剩下的一个方向是,这个构建用的别人电脑,能否自己电脑用于编译?
答案是可以的。
![](https://img.kancloud.cn/20/47/20473956619a57f2944ae81f42030f8e_1034x435.png)
bYOC
点了 新增电脑,![](https://img.kancloud.cn/52/5e/525e8560f1c64d845999a57aade295ae_777x474.png)
windows 后按照要求在家里电脑执行就行。
PS> 坑很多,需要自己尝试。
之前我那个init 远程脚本没删,导致我电脑被创建了账户,关闭的防火墙又加了N多规则,本地github 连不通之类的。 很麻烦。
这个ci server 也可以局域网服务器 本地部署。
反正,折腾来折腾去半天,大部分配置、环境、网络问题。
总算解决了,windows dll生成难的问题。
![](https://img.kancloud.cn/7a/b7/7ab78ed7b436847477f4f0a2c3fd4d23_1867x942.png)
![](https://img.kancloud.cn/e5/99/e5997b6d690073d970384ca1ff9afae0_1849x920.png)
贴两张 php-monitor 成功后的图 互勉。
成功也是各种问题,monitor 用的db illuminate 和tp env collection 冲突啊。项目7 monitor 8 之类的。也想过这种性能数据 应该只上报,监控平台应该独立出来。可他实现接入的是通过append php
源文件来开启的。两个项目杂交。 一地鸡毛。tidyawyes 4.17.5 后又不支持sql了。你看到的sql 是我本地项目看源码模拟的
![](https://img.kancloud.cn/5e/9a/5e9a2c1e660bc9f011d4df7ab52dac71_842x755.png)。 结果也不是span 那种样式。tp trace默日可以取到sql 执行时间的。就是函数耗时不知道。
不禁让我想到 如果ui 层做成 headless ui 多好。 扩展只采集上报。当然pecl 扩展以后都是composer包了,无非性能问题。