Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Github Action云编译磁盘不足、编译超时问题解决方案 #11665

Open
lorchr opened this issue Nov 17, 2023 · 17 comments
Open

Github Action云编译磁盘不足、编译超时问题解决方案 #11665

lorchr opened this issue Nov 17, 2023 · 17 comments

Comments

@lorchr
Copy link

lorchr commented Nov 17, 2023

Github Action云编译磁盘不足、编译超时问题解决方案

1. 超时原因

根据Lean's OpenWrt Issue区大佬EnnawYangGabrielxzx的描述,结合stupidloud大佬的PR,编译超时主要有两个原因

  1. Toolchain编译工具链会消耗一个多小时。Toolchain是可以复用的
  2. 部分插件需要使用Node环境编译,非常耗时。编译时可以去掉,编译完成后再单独安装

2. 超时解决方案

针对这两个问题的解决方案

  1. Toolchain缓存起来,后面编译时引用前面编译好的Toolchain,具体脚本可以参考大佬Haiibo的脚本。(stupidloud大佬的PR似乎不生效,不知道是不是我的使用有问题)
  2. 去掉需要Node环境编译的插件,常用的有unblockmusicalist

AlistUnblockmusic 注释掉,在所在行前面加 # 或者 把 = 号后的 y(yes) 改为 n(no)

# 修改前
CONFIG_PACKAGE_luci-app-alist=y
CONFIG_PACKAGE_luci-app-unblockmusic=y

# 修改后
CONFIG_PACKAGE_luci-app-alist=n
CONFIG_PACKAGE_luci-app-unblockmusic=n

实测一次编译从超时(超过6小时)变为3小时左右,顺便磁盘的占用也会下降很多

3. 磁盘空间不足

编译前删除不需要的工具包,参考 P3TERXHaiibo 大佬的脚本

- name: Initialization environment
  env:
    DEBIAN_FRONTEND: noninteractive
  run: |
    docker rmi `docker images -q`
    sudo rm -rf /etc/apt/sources.list.d/* /usr/share/dotnet /usr/local/lib/android /opt/ghc /etc/mysql /etc/php
    sudo -E apt-get -y purge azure-cli* docker* ghc* zulu* hhvm* llvm* firefox* google* dotnet* aspnetcore* powershell* openjdk* adoptopenjdk* mysql* php* mongodb* moby* snap* || true
    sudo -E apt-get -qq update
    sudo -E apt-get -qq install libfuse-dev $(curl -fsSL git.io/depends-ubuntu-2204)
    sudo -E apt-get -qq autoremove --purge
    sudo -E apt-get -qq clean
    sudo timedatectl set-timezone "$TZ"
    sudo mkdir -p /workdir
    sudo chown $USER:$GROUPS /workdir

4. 识别编译是否包含【需要Node环境编译的插件】的方法

  1. 下载编译日志压缩包(编译详情右上角齿轮),日志文件压缩包超过1M基本可以确定使用了Node
    • 在包含alist时,日志压缩包8M+,解压后130M+
    • 去掉alist后,日志压缩包120k,解压后500k
  2. 打开日志文件,搜索关键字node-v + 版本号,例如目前编译使用的node版本为: node-v16.19.1,不知道版本号直接搜node-v即可
    • 定位到第一个 node-v16.19.1 出现的位置,往上翻第一个插件就是使用node编译的

例如下面例子:

locate-Nodejs-usage-position

可以看到 node-v 一共出现了近 1.8w 次,而第一次出现是在alist插件的下方,可以确定是alist编译用到了node-v16,去掉即可。

如果实在不会,安装一个iStoreOS,把可以从iStore安装的插件全部删除掉

5. 其他编译报错(警告)

正常插件编译成功是每个插件只输出一行日志的,如果日志文件很大,内容格式杂乱,说明有插件编译出错了

定位问题不要从下面往上翻,有些异常日志会非常大,从下面翻会看花眼,从上面往下翻,找到错误队列开始的位置

如下面编译日志示例:

 make[2] -C feeds/sml/luci-app-passwall compile
 make[2] -C feeds/sml/luci-app-passwall2 compile
 make[2] -C package/kernel/mac80211 compile
 make[2] -C package/lean/autosamba compile
 make[2] -C package/system/urandom-seed compile
 make[2] -C package/system/fstools compile
 make[2] -C feeds/luci/applications/luci-app-firewall compile
 make[2] -C feeds/luci/modules/luci-base compile
 make[2] -C feeds/luci/libs/rpcd-mod-rrdns compile
 make[2] -C package/network/services/uhttpd compile
 make[2] -C package/libs/uclient compile
 make[2] -C feeds/luci/applications/luci-app-airplay2 compile
 make[2] -C feeds/packages/net/uwsgi compile
 make[2] -C feeds/packages/net/ddns-scripts compile
 make[2] -C feeds/packages/utils/smartmontools compile
 make[2] -C feeds/packages/utils/ttyd compile
 make[2] -C feeds/luci/applications/luci-app-filetransfer compile
 make[2] -C feeds/luci/applications/luci-app-frpc compile
 make[2] -C feeds/luci/applications/luci-app-frps compile
 make[2] -C feeds/luci/applications/luci-app-minidlna compile
 make[2] -C feeds/luci/applications/luci-app-nfs compile
 make[2] -C feeds/luci/applications/luci-app-nps compile
 make[2] -C feeds/luci/applications/luci-app-pptp-server compile
 make[2] -C feeds/packages/net/qBittorrent compile
 make[2] -C feeds/luci/applications/luci-app-rclone compile
 make[2] -C feeds/packages/net/transmission-web-control compile
 make[2] -C feeds/luci/applications/luci-app-ttyd compile
 make[2] -C feeds/luci/applications/luci-app-uhttpd compile
 make[2] -C feeds/luci/libs/luci-lib-ipkg compile
 make[2] -C feeds/luci/modules/luci-newapi compile
 make[2] -C feeds/packages/net/adguardhome compile
 make[2] -C feeds/opp/luci-app-filebrowser compile
 make[2] -C feeds/opp/luci-app-ikoolproxy compile
 make[2] -C package/system/procd compile
 make[2] -C package/system/opkg compile
 make[2] -C feeds/sml/luci-app-ssr-plus compile
 make[2] -C package/kernel/mt76 compile
 make[2] -C package/lean/automount compile
 make[2] -C package/lean/ddns-scripts_aliyun compile
 make[2] -C package/lean/ddns-scripts_dnspod compile
 make[2] -C package/network/ipv6/6in4 compile
 make[2] -C package/base-files compile
 make[2] -C feeds/luci/modules/luci-mod-admin-full compile
 make[2] -C feeds/luci/applications/luci-app-adbyby-plus compile
 make[2] -C feeds/packages/net/nginx compile
 make[2] -C feeds/luci/applications/luci-app-ddns compile
 make[2] -C feeds/luci/applications/luci-app-diskman compile
 make[2] -C feeds/luci/applications/luci-app-dockerman compile
 make[2] -C feeds/luci/applications/luci-app-mwan3 compile
 make[2] -C feeds/luci/applications/luci-app-transmission compile
 make[2] -C feeds/opp/luci-app-adguardhome compile
 make[2] -C feeds/opp/taskd compile
 make[2] -C package/lean/ipv6-helper compile
 make[2] -C feeds/luci/collections/luci compile
 make[2] -C feeds/packages/net/ariang compile
 make[2] -C feeds/luci/applications/luci-app-autoreboot compile
 make[2] -C feeds/luci/applications/luci-app-kodexplorer compile
 make[2] -C feeds/luci/applications/luci-app-mwan3helper compile
 make[2] -C feeds/luci/applications/luci-app-syncdial compile
 make[2] -C feeds/opp/luci-lib-taskd compile
 make[2] -C package/lean/default-settings compile
 make[2] -C feeds/luci/applications/luci-app-aria2 compile
 make[2] -C feeds/opp/luci-app-store compile
 make[2] -C feeds/luci/applications/luci-app-qbittorrent compile
WARNING: Makefile 'package/feeds/opp/luci-app-wechatpush/Makefile' has a dependency on 'wrtbwmon', which does not exist
make[2]: Entering directory '/home/runner/work/Actions-OpenWrt/Actions-OpenWrt/openwrt/scripts/config'
make[2]: 'conf' is up to date.
make[2]: Leaving directory '/home/runner/work/Actions-OpenWrt/Actions-OpenWrt/openwrt/scripts/config'
 make[1] package/index

可以看到前面插件编译都很正常,到 luci-app-wechatpush 时出现了问题

  1. 正常编译成功的插件都是 make[2] -C feeds make[2] -C package 开头且格式统一
  2. 而在编译luci-app-wechatpush时,格式明显和正常的不一样,从描述看是缺少依赖 'wrtbwmon'
  3. 虽然只是一个警告消息,不会导致固件整体编译失败,但是定位导致编译失败问题的方法也是类似的
WARNING: Makefile 'package/feeds/opp/luci-app-wechatpush/Makefile' has a dependency on 'wrtbwmon', which does not exist
make[2]: Entering directory '/home/runner/work/Actions-OpenWrt/Actions-OpenWrt/openwrt/scripts/config'
make[2]: 'conf' is up to date.
make[2]: Leaving directory '/home/runner/work/Actions-OpenWrt/Actions-OpenWrt/openwrt/scripts/config'
 make[1] package/index

6. 最后

以上为本人根据各位大佬的描述,多次在线编译的得出的结论,分享出来供大家参考,并非专业人士,如有错漏,还请勿喷。

@binge8
Copy link

binge8 commented Nov 17, 2023

你忽略一个很重要的因素,还得看给你分配的机器配置怎么样,已知CPU型号(降序):7763,8370C,8272CL,8171M,E5系列
我的插件多,E5和8171M 这两个6小时不够,8272CL这个6小时刚好,8370C这个4.5小时,7763只需3小时

@lorchr
Copy link
Author

lorchr commented Nov 17, 2023

  1. 同样是 7763 在带 Alist 和不带 Alist,时间从超时变成了3小时,编译 Alist 是个很大的坑,完全可以从iStore 里面下载
  2. Haiibo大佬的库里可以找到打印服务器配置的脚本,在编译开始如果发现分配的配置太低,可以关掉重新开始,总能随机到高配的服务器

@coolsnowwolf coolsnowwolf pinned this issue Nov 18, 2023
@binge8
Copy link

binge8 commented Nov 22, 2023

最近一个礼拜github给分配的都是7763,本来6小时不够用的配置,现在都3小时完成。我每天晚上有4个型号的yml,都是7763

@liwenjie119
Copy link
Contributor

磁盘不足可以利用/dev/sdb1,挂载点/mnt,把编译链文件夹放这个盘里软链接过去就行,足够用了,但是时间限制还真是个问题
/dev/sda1 63G 4.1G 56G 7% /mnt

@coolsnowwolf coolsnowwolf unpinned this issue Dec 9, 2023
@Kisoul
Copy link

Kisoul commented Dec 14, 2023

磁盘不足可以利用/dev/sdb1,挂载点/mnt,把编译链文件夹放这个盘里软链接过去就行,足够用了,但是时间限制还真是个问题 /dev/sda1 63G 4.1G 56G 7% /mnt

求问怎么写这个代码?硬盘实在不够用

@cyzzc
Copy link

cyzzc commented Feb 5, 2024

磁盘不足可以利用/dev/sdb1,挂载点/mnt,把编译链文件夹放这个盘里软链接过去就行,足够用了,但是时间限制还真是问题/dev /sda1 63G 4.1G 56G 7% /mnt

真心求大佬教教代码如何写?这问题已经困扰我好久了。

@dxdf
Copy link

dxdf commented Feb 6, 2024

磁盘不足可以利用/dev/sdb1,挂载点/mnt,把编译链文件夹放这个盘里软链接过去就行,足够用了,但是时间限制还真是问题/dev /sda1 63G 4.1G 56G 7% /mnt

真心求大佬教教代码如何写?这问题已经困扰我好久了。

image
我释放空间后有122G使用空间,你可以参考下

@cyzzc
Copy link

cyzzc commented Feb 6, 2024

磁盘不足可以利用/dev/sdb1,挂载点/mnt,把编译链文件夹放这个盘里软链接过去就行,足够用了,但是时间限制还真是问题 /dev /sda1 63G 4.1G 56G 7% /米恩特

真心求大佬教教代码如何写?这个问题已经困扰我很久了。

图像 我释放空间后有122G使用空间,你可以参考下

真心感谢大佬的帮助,总算解决了硬盘不足的问题。

@liwenjie119
Copy link
Contributor

磁盘不足可以利用/dev/sdb1,挂载点/mnt,把编译链文件夹放这个盘里软链接过去就行,足够用了,但是时间限制还真是问题/dev /sda1 63G 4.1G 56G 7% /mnt

真心求大佬教教代码如何写?这问题已经困扰我好久了。

image 我释放空间后有122G使用空间,你可以参考下

这还真是个好办法,比我清理空间清理得更彻底,而且很方便,

@jimgo188
Copy link

jimgo188 commented Feb 8, 2024

请教大佬,代码怎么写?图像打不开看不到

@liwenjie119
Copy link
Contributor

请教大佬,代码怎么写?图像打不开看不到

我已经参照delea的代码改了一部分了,目前没问题。你可以参照他的,或者我的库,我的库还保留着使用旧的ln挂载文件夹的方法的文件

@dxdf
Copy link

dxdf commented Feb 9, 2024

请教大佬,代码怎么写?图像打不开看不到

图片在这里
#11665 (comment)

具体代码去我代码仓库查看呗

@jimgo188
Copy link

jimgo188 commented Feb 9, 2024

好的,谢谢上面2位大佬,我去抄下

@xayane
Copy link

xayane commented Feb 11, 2024

mark,抄下作业!

@ljkk-li
Copy link

ljkk-li commented Feb 21, 2024

现在默认空间84g掉73了。。。越来越扣了

@yuehua-s
Copy link

真心感谢大佬的帮助,总算解决了硬盘不足的问题。

@SummerXxqq
Copy link

先mark,谢谢,希望用不到

SummerXxqq added a commit to SummerXxqq/AutoBuild-OpenWrt that referenced this issue Sep 16, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests