需要注意的是:
- yml里面的设备配置信息(例如
'device_config/k2b.config'
)的路径一定要写对,而且区分大小写; - 设备配置信息文件(例如
'k2b.config'
文件里,路由器的型号一定要写对); 因为即便你写的不对,编译也不会报错,默认会生成x86_x64的固件,这及其浪费时间,因此请花时间核对信息是否正确!!!
用途:这里主要是用于云编译+UA2F防检测部署 其他用处:可以自定义编译自己想要的openwrt固件
- Zxilly大佬的项目UA2F 这是Z佬的官方部署教程:OpenWrt 编译与防检测部署教程
- MoorCorPa大佬的项目例程:Actions-immortalWrt-UA2F
- P3TERX的编译模板:Actions-OpenWrt 这是P佬的官方部署博客:使用 GitHub Actions 云编译 OpenWrt
- master分支用于同步lede的仓库源码,保持编译源始终保持最新
还没写这部分的代码 - dev分支包含了自定义编译的脚本,在后面会详细介绍,其默认使用
dev分支
的代码进行编译(这是为了防止新源码有故障,在不能保证源码可用情况下不要立即同步最新源) - k2p分支专用于编译k2p固件,其实和
dev分支
区别不大,就是更改了编译固件型号,几行代码的区别
device_config
:用于存放编译固件型号的文件夹device_info.config
:用于基本的设备配置文件(包含设备的型号、需要启用的插件) 代码内容如下:
# 以下三行代码用于配置固件型号
CONFIG_TARGET_x86=y
CONFIG_TARGET_x86_64=y
CONFIG_TARGET_x86_64_DEVICE_generic=y
# 以下代码用于配置固件所需要插件
CONFIG_PACKAGE_ua2f=y
CONFIG_PACKAGE_ipset=y
CONFIG_PACKAGE_iptables-mod-conntrack-extra=y
CONFIG_PACKAGE_iptables-mod-filter=y
CONFIG_PACKAGE_iptables-mod-ipopt=y
CONFIG_PACKAGE_iptables-mod-nfqueue=y
CONFIG_PACKAGE_iptables-mod-u32=y
CONFIG_PACKAGE_kmod-ipt-conntrack-extra=y
CONFIG_PACKAGE_kmod-ipt-filter=y
CONFIG_PACKAGE_kmod-ipt-ipopt=y
CONFIG_PACKAGE_kmod-ipt-nfqueue=y
CONFIG_PACKAGE_kmod-ipt-u32=y
CONFIG_PACKAGE_kmod-nfnetlink-queue=y
CONFIG_LUCI_LANG_zh_Hans=y
CONFIG_PACKAGE_luci-theme-argon=y
CONFIG_PACKAGE_luci-app-argon-config=y
outer_repo.sh
在更新与安装 feeds 的前执行,作用是拉取仓库里没有的插件的源码 内容如下:
#!/bin/bash
#
# Copyright (c) 2019-2020 P3TERX <https://p3terx.com>
#
# This is free software, licensed under the MIT License.
# See /LICENSE for more information.
#
# https://github.com/P3TERX/Actions-OpenWrt
# File name: diy-part1.sh
# Description: OpenWrt DIY script part 1 (Before Update feeds)
#
# Uncomment a feed source
#sed -i 's/^#\(.*helloworld\)/\1/' feeds.conf.default
# Add a feed source
#sed -i '$a src-git lienol https://github.com/Lienol/openwrt-package' feeds.conf.default
git clone https://github.com/CHN-beta/rkp-ipid package/rkp-ipid
git clone https://github.com/Zxilly/UA2F package/UA2F
kernel_mod.sh
在更新与安装 feeds 的后执行,作用是配置一些内核层面的修改 代码如下:
#!/bin/bash
#
# Copyright (c) 2019-2020 P3TERX <https://p3terx.com>
#
# This is free software, licensed under the MIT License.
# See /LICENSE for more information.
#
# https://github.com/P3TERX/Actions-OpenWrt
# File name: diy-part2.sh
# Description: OpenWrt DIY script part 2 (After Update feeds)
#
# CONFIG_NETFILTER=y
# CONFIG_NETFILTER_NETLINK=y
# CONFIG_NETFILTER_NETLINK_GLUE_CT=y
# CONFIG_NETFILTER_NETLINK_LOG=y
# CONFIG_NF_CONNTRACK=y
# CONFIG_NF_CT_NETLINK=y
# Modify default IP
#sed -i 's/192.168.1.1/192.168.50.5/g' package/base-files/files/bin/config_generate
target=$(grep "^CONFIG_TARGET" .config --max-count=1 | awk -F "=" '{print $1}' | awk -F "_" '{print $3}')
for configFile in $(ls target/linux/$target/config*)
do
echo -e "\nCONFIG_NETFILTER_NETLINK_GLUE_CT=y" >> $configFile
done
yml
文件变量的作用以及配置(来自使用 GitHub Actions 云编译 OpenWrt)
环境变量 | 功能 | 默认值 |
---|---|---|
REPO_URL | 源码仓库地址 | https://github.com/SoDebug/OpenWRTResourseCode |
REPO_BRANCH | 源码分支 | dev |
FEEDS_CONF | 自定义feeds.conf.default文件名 | feeds.conf.default |
CONFIG_FILE | 自定义.config文件名 | device_config/device_info.config |
DIY_P1_SH | 自定义diy-part1.sh文件名 | device_config/outer_repo.sh |
DIY_P2_SH | 自定义diy-part2.sh文件名 | device_config/kernel_mod.sh |
UPLOAD_BIN_DIR | 上传 bin 目录。即包含所有 ipk 文件和固件的目录。 | false |
UPLOAD_FIRMWARE | 上传固件目录。 | false |
UPLOAD_COWTRANSFER | 上传固件到奶牛快传。 | false |
UPLOAD_WERANSFER | 上传固件到 WeTransfer 。 | false |
UPLOAD_RELEASE | 上传固件到 releases 。 | false |
TZ | 时区设置 | Asia/Shanghai |
- 在
Github
账户设置中找到Developer Settings
,创建Personal access token(PAT)
,勾选repo
权限,这将用于自动触发编译工作流程。 - 然后点击自己仓库的
Settings
选项卡,再点击Secrets
。添加名为ACTIONS_TRIGGER_PAT
的加密环境变量,保存刚刚创建的PAT
。 - 在
Actions
页面选择Update Checker
,点击Run workflow
手动进行一次测试运行。如果没有报错且OpenWrt
编译工作流程被触发,则代表测试通过。 - 最后编辑
Update Checker
的workflow
文件(.github/workflows/update-checker.yml
),取消注释(删除#)定时触发相关的部分。这里可以根据cron
格式来设定检测的时间,时区为 UTC 。
# schedule:
# - cron: 0 */18 * * *
如何编译自己需要的 OpenWrt 固件 How to build your Openwrt firmware
如有技术问题需要讨论或者交流,欢迎加入以下群:
- 不要用 root 用户进行编译
- 国内用户编译前最好准备好梯子
- 默认登陆IP 192.168.1.1 密码 password
-
首先装好 Linux 系统,推荐 Debian 11 或 Ubuntu LTS
-
安装编译依赖
sudo apt update -y sudo apt full-upgrade -y sudo apt install -y ack antlr3 asciidoc autoconf automake autopoint binutils bison build-essential \ bzip2 ccache cmake cpio curl device-tree-compiler fastjar flex gawk gettext gcc-multilib g++-multilib \ git gperf haveged help2man intltool libc6-dev-i386 libelf-dev libglib2.0-dev libgmp3-dev libltdl-dev \ libmpc-dev libmpfr-dev libncurses5-dev libncursesw5-dev libreadline-dev libssl-dev libtool lrzsz \ mkisofs msmtp nano ninja-build p7zip p7zip-full patch pkgconf python2.7 python3 python3-pip libpython3-dev qemu-utils \ rsync scons squashfs-tools subversion swig texinfo uglifyjs upx-ucl unzip vim wget xmlto xxd zlib1g-dev
-
下载源代码,更新 feeds 并选择配置
git clone https://github.com/coolsnowwolf/lede cd lede ./scripts/feeds update -a ./scripts/feeds install -a make menuconfig
-
下载 dl 库,编译固件 (-j 后面是线程数,第一次编译推荐用单线程)
make download -j8 make V=s -j1
本套代码保证肯定可以编译成功。里面包括了 R22 所有源代码,包括 IPK 的。
你可以自由使用,但源码编译二次发布请注明我的 GitHub 仓库链接。谢谢合作!
二次编译:
cd lede
git pull
./scripts/feeds update -a
./scripts/feeds install -a
make defconfig
make download -j8
make V=s -j$(nproc)
如果需要重新配置:
rm -rf ./tmp && rm -rf .config
make menuconfig
make V=s -j$(nproc)
编译完成后输出路径:bin/targets
由于 WSL 的 PATH 中包含带有空格的 Windows 路径,有可能会导致编译失败,请在 make
前面加上:
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
-
在 AppStore 中安装 Xcode
-
安装 Homebrew:
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
-
使用 Homebrew 安装工具链、依赖与基础软件包:
brew unlink awk brew install coreutils diffutils findutils gawk gnu-getopt gnu-tar grep make ncurses pkg-config wget quilt xz brew install gcc@11
-
然后输入以下命令,添加到系统环境变量中:
echo 'export PATH="/usr/local/opt/coreutils/libexec/gnubin:$PATH"' >> ~/.bashrc echo 'export PATH="/usr/local/opt/findutils/libexec/gnubin:$PATH"' >> ~/.bashrc echo 'export PATH="/usr/local/opt/gnu-getopt/bin:$PATH"' >> ~/.bashrc echo 'export PATH="/usr/local/opt/gnu-tar/libexec/gnubin:$PATH"' >> ~/.bashrc echo 'export PATH="/usr/local/opt/grep/libexec/gnubin:$PATH"' >> ~/.bashrc echo 'export PATH="/usr/local/opt/gnu-sed/libexec/gnubin:$PATH"' >> ~/.bashrc echo 'export PATH="/usr/local/opt/make/libexec/gnubin:$PATH"' >> ~/.bashrc
-
重新加载一下 shell 启动文件
source ~/.bashrc
,然后输入bash
进入 bash shell,就可以和 Linux 一样正常编译了
-
源代码中绝不含任何后门和可以监控或者劫持你的 HTTPS 的闭源软件, SSL 安全是互联网最后的壁垒。安全干净才是固件应该做到的;
-
想学习 OpenWrt 开发,但是摸不着门道?自学没毅力?基础太差?怕太难学不会?跟着佐大学 OpenWrt 开发入门培训班助你能学有所成 报名地址:点击报名
-
QCA IPQ60xx 开源仓库地址:https://github.com/coolsnowwolf/openwrt-gl-ax1800
iKOOLCORE 硬酷R1 多网口小主机 - N5105/N6005 : Cube box, rest fun. 方寸之间,尽是乐趣
(商品介绍页面 - 深圳市硬酷科技): Lean用户R1专属券 N5105下单链接 N6005下单链接
(商品介绍页面 - 硬酷科技(支持花呗)): Lean用户R1专属券 下单链接
如果你觉得此项目对你有帮助,可以捐助我们,以鼓励项目能持续发展,更加完善