Skip to content

Se7enMuting/Openwrt-Packages

Repository files navigation

本package包来自:

https://github.com/sirpdboy/sirpdboy-package

本package包说明:

  1. 来自sirpdboy(koolshare风格):
    • luci-app-advanced---------------------系统高级设置【自带文件管理功能】(自改添加passwall支持)
    • luci-app-control-speedlimit-----------网速限制
    • luci-app-control-timewol--------------定时唤醒
    • luci-app-control-weburl---------------管控过滤[集成上网时间控制,黑白名单IP过滤,网址过滤几大功能]
    • luci-app-netspeedtest-----------------网络速度测试(需要network >+ iperf3)
    • luci-app-wolplus----------------------网络唤醒+(需要配合control-weburl一起用)
    • luci-app-wrtbwmon---------------------流量监控 1.6.3
  2. 关机功能

附2:本地自编译笔记,基本和上面云编译版一致

Lean版本Openwrt(R21.10.1-687407a)源码仓库+passwalll+openclash,自编译step-by-step说明

注意:

  1. 要用 root 用户进行编译!!!
  2. 国内用户编译前最好准备好梯子
  3. 默认登陆IP 192.168.1.* (后面有修改),密码 password

1.开始编译流程:

首次编译

  1. 首先用VMware Workstation Pro 16 装好 Ubuntu 20.04 LTS x64 (虚拟机推荐硬盘大小50G-100G)

  2. 命令行输入 sudo apt-get update ,然后输入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

  3. 使用 git clone https://github.com/coolsnowwolf/lede.git 命令下载好源代码,然后 cd lede 进入目录

  4. git reset --hard 687407acdc585355acd24726eac61dca60cd06fb 退回R21.10.1版本;如果想用最新的master版本,请跳过此步

  5. 更改LAN口的默认IP地址(不需要可跳过)

    cd lede
    vim package/base-files/files/bin/config_generate
    vi /etc/config/network
    i                                                 #插入模式;找到192.168.1.1,修改;按ESC退出编辑模式
    :wq                                               #保存退出
    
  6. 添加下面代码到根目录下feeds.conf.default文件内(添加passwall的feeds源)

    src-git lienol https://github.com/xiaorouji/openwrt-passwall
    
  7. 添加openclash源

    # cd进入Clone项目
    mkdir package/luci-app-openclash
    cd package/luci-app-openclash
    git init
    git remote add -f origin https://github.com/vernesong/OpenClash.git
    git config core.sparsecheckout true
    echo "luci-app-openclash" >> .git/info/sparse-checkout
    git pull --depth 1 origin master
    git branch --set-upstream-to=origin/master master
    
    # 编译 po2lmo (如果有po2lmo可跳过)
    pushd luci-app-openclash/tools/po2lmo
    make && sudo make install
    popd
    
    # 回退到主项目目录
    cd ../..
    
  8. 添加其他主题和插件(不需要可跳过)

    git clone https://github.com/sirpdboy/luci-theme-opentopd package/luci-theme-opentopd
    
    rm -rf package/lean/luci-app-wrtbwmon/
    git clone https://github.com/Se7enMuting/Openwrt-Packages package/Openwrt-Packages
    
    rm -rf package/lean/luci-theme-argon/
    git clone -b 18.06 https://github.com/jerrykuku/luci-theme-argon package/luci-theme-argon
    
  9. update feeds

    ./scripts/feeds update -a
    
  10. 强制安装(-f)feeds,如feeds和lean源有同名的package,强制安装feeds里的

    ./scripts/feeds install -a -f
    
  11. 添加poweroff按钮,这步必须要在feeds install之后,编译之前

    cd lean #进入源码目录
    curl -fsSL https://raw.githubusercontent.com/sirpdboy/other/master/patch/poweroff/poweroff.htm > ./feeds/luci/modules/luci-mod-admin-full/luasrc/view/admin_system/poweroff.htm
    curl -fsSL https://raw.githubusercontent.com/sirpdboy/other/master/patch/poweroff/system.lua > ./feeds/luci/modules/luci-mod-admin-full/luasrc/controller/admin/system.lua
    
  12. 进入交互式配置界面

    make menuconfig
    
    • 开启IPV6
      • 选上 Extra packages >+ ipv6helper
      • 在 Network > Firewall > ip6tables 下启用 ip6tables-extra 和 ip6tables-mod-nat 项。
    • 取消samba
      • 取消 Extra packages >- autosamba
      • 在 LuCI > Applications里,现在可以取消luci-app-samba了
    • 编译丰富插件时,建议修改下面两项默认大小,留足插件空间
      • Target Images > (16) Kernel partition size (in MB) (默认是 16,建议修改成 64)
      • Target Images > (160) Root filesystem partition size (in MB) (默认是 160,建议修改成 512+)
    • Utilities > Virtualizatio > +qemu-ga ---> PVE虚拟机助手QEMU-Guest-Agent,非PVE用户不用选
    • Target Images >+ QCOW2 IMAGES - VMDK IMAGES ---> VM改生成QCOW2镜像,PVE用,非PVE用户可跳过
    • Base system >+ dnsmasq-full ---> 选满(HAVE不选)
    • LuCI > Modules >+ Luci-compat ---> OpenClash依赖
    • Network > IP Addresses and Names >+ ddns-scripts_cloudflare.com-v4 + ddns-scripts_freedns_42_pl + ddns-scripts_godaddy.com-v1 ---> DDNS插件依赖
    • Network >+ iperf3 ---> luci-app-netspeedtest需要
    • Network > WirlessAPD >- wpad - hostapd-common ---> 取消Wirless选项,避免报错,可跳过
    • 添加主题 >+ opentopd +argon
    • LuCI > Applications 先选XX-2个,因为首次编译,建议openclash和passwall先不选;如果全选,且编译通过,那下面的第二次编译就不需要了
    • 最后再确认kmod-tun被选上了(openclash依赖,一定要最后确认一次,因为会被自动取消掉)
      • Kernel modules > Network Support >+ kmod-tun
  13. make -j8 download V=s 下载dl库(国内请尽量全局科学上网)

  14. 输入 make -j1 V=s (-j1 后面是线程数;第一次编译推荐用单线程)即可开始编译你要的固件了

  15. 编译完成后输出路径:bin/targets

第二次完整编译,带上openclash和passwall

  1. 清除配置

    rm -rf ./tmp && rm -rf .config
    
  2. 重复首次编译中的第12步,LuCI > Applications里选XX个(+openclash和passwall)

    make menuconfig
    
  3. 可多线程编译

    make -j$(($(nproc) + 1)) V=s
    
  4. 编译完成后输出路径:bin/targets

以后更新编译(更新Lean master源码+feeds+openclash)

cd lede                                                       #进入LEDE目录
git pull                                                      #同步更新lean master源码,编译指定commit版本可跳过此步
cd package/luci-app-openclash && git pull                     #进入OpenClash目录并更新源码
cd ../..                                                      #退回到lede目录
./scripts/feeds update -a && ./scripts/feeds install -a -f
make defconfig
make -j$(($(nproc) + 1)) V=s

2.重新配置config的编译方法:

重新配置config编译

cd lede
rm -rf ./tmp && rm -rf .config
make menuconfig
make -j$(($(nproc) + 1)) V=s

更新Lean master源码+feeds+openclash & 重新配置config编译

cd lede
git pull                                                   #同步更新lean master源码,编译指定commit版本可跳过此步
cd package/luci-app-openclash && git pull
cd ../..
./scripts/feeds update -a && ./scripts/feeds install -a -f
rm -rf ./tmp && rm -rf .config
make menuconfig
make -j$(($(nproc) + 1)) V=s

附3:安装

PVE安装指令

  1. local(***)-->ISO镜像-->上传
qm importdisk 100 /var/lib/vz/template/iso/openwrt-x86-64-generic-squashfs-combined-efi.img local-lvm

100为虚拟机ID,请自行修改

openwrt源修改,注意要和版本对应

登录web,系统 > 软件包 > 设置,修改:

src/gz openwrt_core https://mirrors.cloud.tencent.com/lede/releases/21.02.0/targets/x86/64/packages
src/gz openwrt_base https://mirrors.cloud.tencent.com/lede/releases/21.02.0/packages/x86_64/base
src/gz openwrt_luci https://mirrors.cloud.tencent.com/lede/releases/21.02.0/packages/x86_64/luci
src/gz openwrt_packages https://mirrors.cloud.tencent.com/lede/releases/21.02.0/packages/x86_64/packages
src/gz openwrt_routing https://mirrors.cloud.tencent.com/lede/releases/21.02.0/packages/x86_64/routing
src/gz openwrt_telephony https://mirrors.cloud.tencent.com/lede/releases/21.02.0/packages/x86_64/telephony

因为是自编译固件,和官方签名不一致,无法opkg update成功,要把这行用#注释掉# option check_signature

附4:其他

diffconfig.sh脚本导出[默认的.config]和[menuconfig之后的.config]之间的差异文件seed.config,给云编译备用

make defconfig                             #新clone首次menuconfig之前需执行一次
./scripts/diffconfig.sh > seed.config

.config文件笔记(在Ubuntu Desktop下是隐藏文件)

make defconfig
# 1. 如果没有.config文件,生成默认配置的.config文件
# 2. 如果有.config文件,则保留这份.config文件中的所有配置,缺少的(如果有缺少)则用默认配置中的其余内容补全进去(github action 中的 .yml 脚本就是用这种方式运行的:make defconfig,所以上传的 .config 是差异文件)

make menuconfig
# 1. 通过菜单选择来生成.config文件
  • make前必须要有.config文件
  • 如果没有新增编译项目,可以直接使用上次的.config,用make defconfig确认是否是 # No change to .config
  • 或使用diffconfig.sh导出的差异配置seed.config,改名成.config,然后用make defconfig生成完整版的.config,再make

如何快速获取完整版的默认.config文件,用于搜索查找

git clone -b openwrt-18.06 https://github.com/immortalwrt/immortalwrt.git --depth 1
#或者
git clone -b openwrt-21.02 https://github.com/immortalwrt/immortalwrt.git --depth 1

#CD 进入 immortalwrt 文件夹

#以下额外的 package 可以省略
git clone https://github.com/Se7enMuting/Openwrt-Packages package/Openwrt-Packages --depth 1
git clone https://github.com/sirpdboy/luci-theme-opentopd package/luci-theme-opentopd --depth 1
git clone -b 18.06 https://github.com/jerrykuku/luci-theme-argon package/luci-theme-argon --depth 1
git clone -b 18.06 https://github.com/kiddin9/luci-theme-edge package/luci-theme-edge --depth 1

./scripts/feeds update -a
./scripts/feeds install -a

make defconfig

单独编译 OpenWRT ipk 插件

  1. 保存插件源码

    • 下载源码git clone到~/lede/package
    • 或者已经在feeds里面了,无需在手动下载,./scripts/feeds update -a && ./scripts/feeds install -a即可
  2. 配置

    • make menuconfig
    • 然后进入对应的子菜单中找到对应插件按M表示选中插件,但不编译进固件
  3. 编译

    • make package/xxxxx/compile V=99
    • xxxxx 就是你需要单独编译的程序名称
    • 注意这里是固定格式,不用填写插件所在的路径,直接用名字即可,只要上面配置时用M选中了
  4. ipk 生成路径

    • ~/lede/bin/packages/x86_64/xxxx
  5. 其他

    • 若无法编译出插件,手动删除bin,feeds,package/feeds这些文件夹,再./scripts/feeds update -a && ./scripts/feeds install -a

默认luci-app-ddns插件里的dnspod和aliyun如何正确使用

  • 域名的正确填写方法
    • 如果是example.com,则域名填:@example.com
    • 如果是blog.example.com,则域名填:blog@example.com
    • 如果是good.blog.example.com,则域名填:good.blog@example.com