• OpenWrt 固件编译教程


    一、编译环境准备

    编译平台 阿里云 Ubuntu 20.04.5 LTS

    安装编译环境依赖

    sudo apt-get -y install build-essential asciidoc binutils bzip2 gawk gettext git libncurses5-dev libz-dev patch python3 python2.7 unzip zlib1g-dev lib32gcc1 libc6-dev-i386 subversion flex uglifyjs git-core gcc-multilib p7zip p7zip-full msmtp libssl-dev texinfo libglib2.0-dev xmlto qemu-utils upx libelf-dev autoconf automake libtool autopoint device-tree-compiler g++-multilib antlr3 gperf wget curl swig rsync

    更新本地软件包

    sudo sh -c "apt update && apt upgrade -y"

    不推荐使用 root 用户进行编译,所以先使用 root 权限创建一个用户,以创建 gaven 用户为例

    1. # 添加用户
    2. adduser gaven

    为新用户设置密码,根据个人情况,这里设置“123456”

    passwd 123456

    从 root 用户切换使用新用户

    su gaven

    从此刻开始,以非 root 用户执行编译过程的所有操作。

    二、首次编译步骤

    重要的事情说三遍,不要使用root用户!!!

    拉取代码,这里拉取的代码是LEDE

    git clone https://github.com/coolsnowwolf/lede.git openwrt

    添加自定义源(可选项),这里只是告诉一种方式和方法

    注:以下是自己正在使用的软件源,这里你也可以换成自己喜欢的软件源

    1. # 进入openwrt目录
    2. cd ~/openwrt
    3. # 添加自定义源
    4. cat >> feeds.conf.default <
    5. src-git kenzo https://github.com/kenzok8/openwrt-packages
    6. src-git passwall https://github.com/xiaorouji/openwrt-passwall
    7. EOF

    更新下载软件仓库的源码到本地,并安装自定义源包含的软件包

    ./scripts/feeds update -a

     这个过程可能会因为国内网路的原因会失败,多试几次,尽量保证别出现错误。如果有些代码源确实无法实现下载更新操作,原因是因为github的DNS系统解析不了,这里可以通过一些方式查询githhub的地址,进行手动配置

    查询github的IP地址

    GitHub: Let's build from here · GitHub  通过此网站便可以查询到。

    配置/etc/hosts ,在结尾处写上。
    140.82.114.3 github.com
    140.82.114.3 www.github.com

    然后执行

    ping  github.com  是否能够ping通,能够ping通,说明可以进行代码更新了。

    测试结果示例

     继续执行更新操作,是否能够成功?

    ./scripts/feeds update -a 

    进行拉取代取的安装操作

    ./scripts/feeds install -a

    单独添加软件包(可选项)

    如果需要单独添加软件,请拉取源码到 pack­age 目录之下。示例如下:

    1. # 添加 OpenAppFilter 应用过滤插件
    2. git clone https://github.com/destan19/OpenAppFilter package/OpenAppFilter

    设置默认主题(可选项)

    注:此操作请在编译前执行,设置 ar­gon 为默认主题,以此为例举一反三

    1. # 删除自定义源默认的 argon 主题
    2. rm -rf package/lean/luci-theme-argon
    3. # 部分第三方源自带 argon 主题,上面命令删除不掉的请运行下面命令
    4. find ./ -name luci-theme-argon | xargs rm -rf;
    5. # 针对 LEDE 项目拉取 argon 原作者的源码
    6. git clone -b 18.06 https://github.com/jerrykuku/luci-theme-argon.git package/lean/luci-theme-argon
    7. # 替换默认主题为 luci-theme-argon
    8. sed -i 's/luci-theme-bootstrap/luci-theme-argon/' feeds/luci/collections/luci/Makefile

    设置路由器默认的 LAN IP(可选项)

    注:此操作请在编译前执行

    1. # 设置默认IP为 192.168.199.1
    2. sed -i 's/192.168.1.1/192.168.199.1/g' package/base-files/files/bin/config_generate

    仅制作.config文件,无需本地编译固件(可选项)

    根据自己的定制需求,调整系统组件

    make menuconfig

    通过以下命令行获得 seed.config 配置文件,然后使用 GitHub Ac­tions 云编译。

    1. # 若在调整OpenWrt系统组件的过程有多次保存操作,则建议先删除.config.old文件再继续操作
    2. rm -f .config.old
    3. # 根据编译环境生成默认配置
    4. make defconfig
    5. # 对比默认配置的差异部分生成配置文件(可以理解为增量)
    6. ./scripts/diffconfig.sh > seed.config

    若需要编译固件

    根据自己的定制需求,调整系统组件

    make menuconfig

    下载编译所需的软件包

    make download -j8 V=s

    编译 Open­Wrt 固件

    1. # -j1:单线程编译
    2. make -j1 V=s

    单线程编译可提高编译成功率,但过程非常漫长,也完全取决于机器的性能。编译完成后固件输出路径: /openwrt/bin/targets/ 之下。

    三、二次编译步骤

    不要使用 root 用户!

    更新本地编译环境

    1. # 更新软件列表、升级软件包
    2. sudo sh -c "apt update && apt upgrade -y"
    3. # 拉取最新源码
    4. cd ~/openwrt && git pull
    5. # 更新下载安装订阅源包含的软件包
    6. cd ~/openwrt
    7. ./scripts/feeds update -a && ./scripts/feeds install -a

    清理旧文件

    1. # 删除/bin和/build_dir目录中的文件
    2. make clean

    如果要更换架构,例如要从 x86_64 换到 MediaTek Ralink MIPS 建议执行以下命令深度清理 /bin 和 /build_dir 目录的中的文件 (make clean) 以及 /staging_dir/toolchain/tmp 和 /logs 中的文件。

    make dirclean

    如果需要对组件重新调整,则建议先删除旧配置

    rm -rf ./tmp && rm -rf .config

    根据自己的定制需求,再次调整 Open­Wrt 系统组件

    make menuconfig

    下载编译所需的软件包

    make download -j8 V=s

    编译 Open­Wrt 固件

    make -j$(nproc) || make -j1 || make -j1 V=s

    二次编译可以优先使用多线程,报错会自动使用单线程,仍然报错会单线程执行编译并输出详细日志。

    附加内容

    如果没有特殊的定制需求,运行 make menuconfig 命令配置目标架构完成后,进入 LUCI --> Applications 选择需要的插件,进入 LUCI --> Themes 选择喜欢的主题皮肤,编译即可。

    如果是硬路由且需要闭源的 Wi-Fi 驱动,务必记得勾选 luci-app-mtwifi

  • 相关阅读:
    Python3.8+PyCharm安装和简单配置
    uboot启动流程-涉及_main汇编函数
    大型化工企业数字化转型建议
    1)合同/案件/法务/合规/风险 开篇
    Windows如何运行anywhere
    机器学习4-降维技术
    手把手推导分布式矩阵乘的最优并行策略
    手机端布局页面写法
    怎样让您的电商 API 快速且轻松地提取所有商品数据?
    深度学习基础之激活函数
  • 原文地址:https://blog.csdn.net/qq84395064/article/details/127934147