X-OpenWrt/README.md

144 lines
6.6 KiB
Markdown
Raw Normal View History

2021-11-06 10:07:54 +00:00
# OpenWrt-Actions & One-key AutoUpdate
2020-09-29 06:17:03 +00:00
2020-10-24 00:59:14 +00:00
![GitHub Stars](https://img.shields.io/github/stars/Hyy2001X/AutoBuild-Actions.svg?style=flat-square&label=Stars&logo=github)
![GitHub Forks](https://img.shields.io/github/forks/Hyy2001X/AutoBuild-Actions.svg?style=flat-square&label=Forks&logo=github)
2021-11-08 00:55:29 +00:00
AutoBuild-Actions 稳定版仓库地址: [AutoBuild-Actions-Template](https://github.com/Hyy2001X/AutoBuild-Actions-Template)
2021-06-27 15:54:55 +00:00
2021-11-06 10:07:54 +00:00
自用修改版软件包地址: [AutoBuild-Packages](https://github.com/Hyy2001X/AutoBuild-Packages)
2021-04-08 08:56:11 +00:00
2021-07-21 09:56:37 +00:00
支持的 OpenWrt 源码: `coolsnowwolf/lede`、`immortalwrt/immortalwrt`、`openwrt/openwrt`、`lienol/openwrt`
2021-11-11 08:41:36 +00:00
## 维护设备列表
| 机型 | 配置文件 | 拥有设备 |
| :----: | :----: | :----: |
2021-11-20 15:43:17 +00:00
| [x86_64](./.github/workflows/AutoBuild-x86_64.yml) | [x86_64](./Configs/x86_64) | ✅ |
| [新路由3](./.github/workflows/AutoBuild-d-team_newifi-d2.yml) | [d-team_newifi-d2](./Configs/d-team_newifi-d2 "点击") | ✅ |
| [华硕 acrh17](./.github/workflows/AutoBuild-asus_rt-acrh17.yml) | [asus_rt-acrh17](./Configs/asus_rt-acrh17) | ❎ |
| [竞斗云 2.0](./.github/workflows/AutoBuild-p2w_r619ac-128m.yml) | [p2w_r619ac-128m](./Configs/p2w_r619ac-128m) | ❎ |
| [红米 AC2100](./.github/workflows/AutoBuild-xiaomi_redmi-router-ac2100.yml) | [xiaomi_redmi-router-ac2100](./Configs/xiaomi_redmi-router-ac2100) | ✅ |
| [小娱C1/3/5](./.github/workflows/AutoBuild-xiaoyu_xy-c5.yml) | [xiaoyu_xy-c5](./Configs/xiaoyu_xy-c5) | ❎ |
2022-03-23 13:16:18 +00:00
| [红米 AX6S](./.github/workflows/AutoBuild-xiaomi_redmi-router-ax6s-test.yml) | [xiaomi_redmi-router-ax6s](./Configs/xiaomi_redmi-router-ax6s-test) | ✅ |
2020-10-07 13:51:13 +00:00
2021-11-06 10:07:54 +00:00
## 一、定制固件(可选)
2021-11-20 14:06:38 +00:00
🎈 **提示**: 文中的 **TARGET_PROFILE** 为要编译的设备名称, 例如: `d-team_newifi-d2`、`asus_rt-acrh17`
2021-07-16 04:54:53 +00:00
2021-11-06 10:07:54 +00:00
从本地获取: 在源码目录执行`egrep -o "CONFIG_TARGET.*DEVICE.*=y" .config | sed -r 's/.*DEVICE_(.*)=y/\1/'`
2021-06-22 09:20:02 +00:00
2021-11-06 10:07:54 +00:00
或执行`grep 'TARGET_PROFILE' .config`, 请先执行`make menuconfig`进行配置
2021-06-22 09:20:02 +00:00
2021-11-08 00:55:29 +00:00
1. 进入你的`AutoBuild-Actions`仓库, **下方所有操作都将在你的`AutoBuild-Actions`仓库下进行**
建议使用`Github Desktop`和`Notepad++`进行操作 [[Github Desktop](https://desktop.github.com/)] [[Notepad++](https://notepad-plus-plus.org/downloads/)]
2021-11-20 14:06:38 +00:00
2. 编辑`/Configs`目录下的配置文件, 若配置文件不存在则需要在本地生成`.config`重命名并上传
2021-06-22 09:20:02 +00:00
2021-11-20 14:06:38 +00:00
3. 编辑`/.github/workflows/某设备.yml`文件, 修改`第 7 行`为随便的名称
2021-07-09 14:03:49 +00:00
2021-11-20 14:06:38 +00:00
4. 编辑`/.github/workflows/某设备.yml`文件, 修改`第 32 行`为上传的`.config`配置文件名称
2020-09-29 06:17:03 +00:00
2021-11-20 15:43:17 +00:00
5. 按照需求且编辑 [/Scripts/AutoBuild_DiyScript.sh](./Scripts/AutoBuild_DiyScript.sh), `/Scripts`下的其他文件无需修改
2021-04-04 13:44:47 +00:00
2021-11-20 14:06:38 +00:00
**/Scripts/AutoBuild_DiyScript.sh: Firmware_Diy_Core() 函数中的变量解释:**
2021-01-31 12:17:40 +00:00
```
2021-11-20 14:06:38 +00:00
Author 作者名称, AUTO: [自动识别]
2021-08-05 07:27:21 +00:00
2021-11-20 14:06:38 +00:00
Author_URL 自定义作者网站或域名, 将写入到内核信息, 例如 AUTO: [自动识别]; "https://www.baidu.com"
2021-07-21 09:56:37 +00:00
2022-03-23 13:16:18 +00:00
Default_Title Shell 终端首页显示的额外信息
2021-03-31 01:49:42 +00:00
2021-11-20 14:06:38 +00:00
Default_IP 固件初始 IP 地址
2021-07-21 09:56:37 +00:00
2022-03-23 13:16:18 +00:00
Short_Fw_Date 简短的固件日期, 例如 true: [20210601]; false: [202106012359]
2021-07-21 09:56:37 +00:00
2022-03-23 13:16:18 +00:00
x86_Full_Images 额外上传已检测到的 x86 虚拟磁盘镜像
2021-08-09 17:26:40 +00:00
2022-03-23 13:16:18 +00:00
Fw_Format 自定义固件格式; false: [自动识别]
2021-08-09 17:26:40 +00:00
2022-03-23 13:16:18 +00:00
Regex_Skip 输出固件时丢弃包含该内容的文件
2021-07-21 09:56:37 +00:00
2022-03-23 13:16:18 +00:00
AutoBuild_Features 自动添加 AutoBuild 固件特性, 例如 一键更新固件; 固件工具箱
2021-01-31 12:17:40 +00:00
2022-03-23 13:16:18 +00:00
Compatible 完善原生 OpenWrt 支持, 例如 true: [自动识别]; 自选版本号: 19.07; 21.02
2021-08-29 15:02:31 +00:00
2021-11-20 14:06:38 +00:00
注: 禁用某功能请将变量值修改为 false, 开启则为 true
2021-01-31 12:17:40 +00:00
```
2021-03-31 01:49:42 +00:00
2021-11-06 10:07:54 +00:00
## 二、编译固件(必选)
2021-04-09 14:47:24 +00:00
2021-11-20 14:06:38 +00:00
**手动编译** 点击上方`Actions`, 在左栏选择要编译的设备,点击右方`Run workflow`再点击`绿色按钮`即可开始编译
2021-04-09 14:47:24 +00:00
2022-03-23 13:16:18 +00:00
**一键编译** 删除`第 29-30 行`的注释并保存, 以后点击两次右上角的 **Star** 按钮即可一键编译
2021-04-29 02:22:53 +00:00
2021-11-20 14:06:38 +00:00
**定时编译** 删除`第 26-27 行`的注释, 然后按需修改时间并提交修改 [Corn 使用方法](https://www.runoob.com/w3cnote/linux-crontab-tasks.html)
2021-10-22 07:29:12 +00:00
2021-11-20 14:06:38 +00:00
**临时修改固件 IP 地址** 该功能仅在**手动编译**生效, 点击`Run workflow`后即可输入 IP 地址
**使用其他 [.config] 配置文件** 点击`Run workflow`后即可输入位于`/Configs`下的配置文件名称
2021-04-29 02:22:53 +00:00
2021-11-20 14:06:38 +00:00
🔔 **为了你的账号安全, 请不要使用 SSH 连接 Github Action**, `.config`配置等操作请务必在本地完成
2021-11-11 08:41:36 +00:00
2021-11-11 08:45:03 +00:00
## 三、部署云端日志(可选)
2021-10-06 16:10:33 +00:00
2021-11-20 14:06:38 +00:00
1. 下载本仓库中的 [Update_Logs.json](https://github.com/Hyy2001X/AutoBuild-Actions/releases/download/AutoUpdate/Update_Logs.json) 到本地 (如果有)
2021-10-06 16:10:33 +00:00
2021-11-20 14:06:38 +00:00
2.**JSON** 格式编辑本地的`Update_Logs.json`
2021-10-06 16:10:33 +00:00
2021-11-20 14:06:38 +00:00
3. 手动上传修改后的`Update_Logs.json`到`Github Release`
2021-10-06 16:10:33 +00:00
2021-11-20 14:06:38 +00:00
4. 在本地执行`autoupdate --fw-log`测试
2021-11-08 00:55:29 +00:00
2021-11-06 10:07:54 +00:00
## 使用一键更新固件脚本
2021-01-06 13:18:27 +00:00
2021-11-06 10:07:54 +00:00
首先需要打开`TTYD 终端`或者使用`SSH`, 按需输入下方指令:
2021-04-29 02:22:53 +00:00
2021-11-08 00:55:29 +00:00
常规更新固件: `autoupdate`或完整指令`bash /bin/AutoUpdate.sh`
2021-04-29 02:22:53 +00:00
2021-11-06 10:07:54 +00:00
使用镜像加速更新固件: `autoupdate -P`
2021-01-06 13:18:27 +00:00
2021-07-16 16:38:27 +00:00
更新固件(不保留配置): `autoupdate -n`
强制刷入固件: `autoupdate -F`
2021-11-06 10:07:54 +00:00
"我不管, 我就是要更新!": `autoupdate -f`
更新脚本: `autoupdate -x`
列出相关信息: `autoupdate --list`
2021-10-06 16:10:33 +00:00
查看所有可用参数: `autoupdate --help`
2021-11-20 14:06:38 +00:00
**注意: **部分参数可一起使用, 例如 `autoupdate -n -P -F --path /mnt/sda1`
2021-05-16 11:03:55 +00:00
2021-10-17 13:16:50 +00:00
## 使用 tools 固件工具箱
2021-10-06 16:10:33 +00:00
2021-11-06 10:07:54 +00:00
打开`TTYD 终端`或者使用`SSH`, 执行指令`tools`或`bash /bin/AutoBuild_Tools.sh`即可启动固件工具箱
2021-10-06 16:10:33 +00:00
当前支持以下功能:
- USB 扩展内部空间
- Samba 相关设置
- 打印端口占用详细列表
- 打印所有硬盘信息
- 网络检查 (基础网络 | Google 连接检测)
- AutoBuild 固件环境修复
- 系统信息监控
- 打印在线设备列表
2021-04-29 02:22:53 +00:00
2020-10-24 01:06:21 +00:00
## 鸣谢
2021-04-04 13:44:47 +00:00
- [Lean's Openwrt Source code](https://github.com/coolsnowwolf/lede)
2021-01-31 13:25:14 +00:00
- [P3TERX's Blog](https://p3terx.com/archives/build-openwrt-with-github-actions.html)
2021-02-23 14:29:12 +00:00
2021-05-26 13:31:15 +00:00
- [ImmortalWrt's Source code](https://github.com/immortalwrt)
2021-04-04 13:44:47 +00:00
2021-05-26 13:31:15 +00:00
- [eSir 's workflow template](https://github.com/esirplayground/AutoBuild-OpenWrt/blob/master/.github/workflows/Build_OP_x86_64.yml)
2021-08-09 17:26:40 +00:00
2021-11-06 10:07:54 +00:00
- [[openwrt-autoupdate](https://github.com/mab-wien/openwrt-autoupdate)] [[Actions-OpenWrt](https://github.com/P3TERX/Actions-OpenWrt)]
2021-04-04 13:44:47 +00:00
2021-08-09 17:26:40 +00:00
- 测试与建议: [CurssedCoffin](https://github.com/CurssedCoffin) [Licsber](https://github.com/Licsber) [sirliu](https://github.com/sirliu) [神雕](https://github.com/teasiu) [yehaku](https://www.right.com.cn/forum/space-uid-28062.html) [缘空空](https://github.com/NaiHeKK) [281677160](https://github.com/281677160)