AppVeyor 作为 Windows 开拓者供应的持续集成工具 。
它许可开拓者在 Windows 环境下测试代码,并为利用 C 扩展的项目构建面向 Windows 的二进制文件 。
AppVeyor 与 GitHub 和 Bitbucket 集成,能够在代码提交到这些平台后自动触发构建 。
对付开源项目,AppVeyor 供应了免费的账户层,足以知足基本的持续集成需求。

开始

该工具的研究来源于我看了一个工具php monitor的里面有一个扩展,tidaways。
官方个给的windows扩展点过去却看不到构建产物。

于是研究了下如何用他自己天生windows用的php扩展。

ciphp视频AppVeyor CI 构建和宣布PHP扩大 AJAX

首先,是自己fork了一下官方的仓库到yangweijie账号下。
登录后有个导入项目

将其导入。
由于里面如果须要交互发布zip 作为release 到github 那肯定须要github 的token 的。
以是想着是将仓库转私有 再新建导入。
结果发先fork 的不能转私有。
网上有说免费如何用私有库的,没试。

紧张是将官方的token通过加密后再写到deplo 里的auth_token 里。
本来想着用环境变量的,结果折腾半天读取不对。

原官方 appveyor 配置。

image: Visual Studio 2015version: '{branch}.{build}'cache: - c:\build-cache -> .appveyor.yml, .appveyor/.cmdenvironment: 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: vc15install: - .appveyor\install.cmdbuild_script: - .appveyor\build.cmd

可以看出来和 github action 编译php扩展一样。
用到了矩阵。
我们要做的便是补上gitbub 支配那步。

官方文档是这么写的:

auth_token 通过account里的加密yaml

获取到就行,别人最多拿到加密后字符串也没法操作你的github其他只能用于构建。
然后我就考试测验构建。

经由多此考试测验后终于构建成功了第一次。
点击项眼前【构建历史】,右面显示 jobs

能看到4个job由于我精简了,只构建7.4, 7.3 (x86、x64)。
不然一个任务job不完成,会影响下次提交导致的构建(排队中)。
只好手动取消。
他文档里说 可以在构建初始化时后,rdp远程连接电脑看。

为了搞清楚末了构建成功的文件在哪里。
我就加上了。
他每次远程后会在桌面产生一个delete 开头的文件。
构建后job 就卡住,删除文件就会连续job 测试天生的dll。

加上后 init 会显示机器远程ip:端口 用户名都固定的,密码是

自己配的。
终极研究创造 他会在被远程的电脑上建一个project 里clone 除php-src 源码,然后将源码 拉取到ext 目录里,构建的dll 在build目录下。

然而,我第一次成功的名字都很奇怪,只有源码的zip。

这个得细看文档。

release: php_tideways_xhprof-v$(APPVEYOR_BUILD_VERSION)

当时yaml 是这么写的,v 由于没有tag name 他只好以分支名来作为tag,5是第5次发布。

后来既然能天生了,我干脆改了。

固定了一个名字

补了一个tag name的环境变量。
结合架构,php版本。

这个源码的压缩包怎么来的。

build_task.cmd 里有 7zip 压缩ext扩展源码为压缩包,末了上传。

我依葫芦画瓢,补上了 build下dll 压缩 为dll.zip,并上传至产物。

终极我研究了半天 上传至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的附件。
压缩包内容类似

剩下的一个方向是,这个构建用的别人电脑,能否自己电脑用于编译?

答案是可以的。

bYOC 点了新增电脑

windows 后按照哀求在家里电脑实行就行。

PS> 坑很多,须要自己考试测验。

之前我那个init 远程脚本没删,导致我电脑被创建了账户,关闭的防火墙又加了N多规则,本地github 连不通之类的。
很麻烦。

这个ci server 也可以局域网做事器 本地支配。

反正,折腾来折腾去半天,大部分配置、环境、网络问题。
总算办理了,windows dll天生难的问题。

贴两张 php-monitor 成功后的图 互勉。

成功也是各种问题,monitor 用的db illuminate 和tp env collection 冲突啊。
项目7 monitor 8 之类的。
也想过这种性能数据 该当只上报,监控平台该当独立出来。
可他实现接入的是通过append php 源文件来开启的。
两个项目杂交。
一地鸡毛。
tidyawyes 4.17.5 后又不支持sql了。
你看到的sql是我本地项目看源码仿照的

结果也不是span 那种样式。
tp trace默日可以取到sql实行韶光的。
便是函数耗时不知道。
不禁让我想到 如果ui 层做成 headless ui 多好。
扩展只采集上报。
当然pecl 扩展往后都是composer包了,无非性能问题。