LuCI 工作架构介绍

1. LuCI 是什么

LuCI 是 OpenWrt 的 Web UI 框架,核心特点:

  • 基于 Lua + uhttpd + ubus/uci

  • 配置驱动(不直接改文件,而是改 UCI

  • 轻耦合,可插插件(package)

2. 整体架构图

3. 核心组成

层级 角色 常见内容
uhttpd HTTP入口 /etc/config/uhttpd
Lua/dispatcher URL Router → Controller /usr/lib/lua/luci/dispatcher.lua
Controller 处理请求 & 调 UCI/ubus /usr/lib/lua/luci/controller/...
Model 读取/写 UCI / RPCD /usr/lib/lua/luci/model/...
View 渲染 HTML /usr/lib/lua/luci/view/...
UCI 持久配置数据 /etc/config/...
ubus/rpcd API层与系统交互 wifi, firewall, system

4. 请求处理流程(以"保存 Wi-Fi 配置"为例)

(1) 浏览器点击 "保存" → POST

(2) uhttpd 转发给 LuCI dispatcher

(3) Dispatcher 找到对应 Controller

(4) Controller 调用 Model 写 UCI: wifi.ssid="MyAP"

(5) 提交 UCI → uci commit wireless

(6) Controller 触发系统动作 (ubus call hostapd reload)

(7) 返回 JSON / HTML 页面

特点:所有配置不直接改文件,而走 UCI + commit

5. 配置持久化机制

  • Edit = uci set

  • Save & Apply = uci commit + reload/restart

  • 改写的是 /etc/config/* 文件(统一入口,便于 scripts/CLI/GUI 同源)

6. 插件扩展机制(如何增加一个页面)

添加新功能一般需要三件:

/usr/lib/lua/luci/controller/myapp.lua ← 路由 + 控制逻辑

/usr/lib/lua/luci/model/cbi/myapp/*.lua ← 调UCI的模型文件

/usr/lib/lua/luci/view/myapp/*.htm ← 页面模板

注册路由后重启 uhttpd/LuCI 即可显示 UI 模块。

7. 为什么 LuCI 适合路由器/嵌入式

  • 运行在低 RAM/Flash 上(Lua轻量)

  • 统一系统配置模型 (UCI)

  • 面向 RPC(可与 CLI/scripts/daemon 无缝协同)

  • 插件化结构适配 ODM/OEM 场景

相关推荐
行乾21 小时前
鸿蒙端 IMSDK 架构探索
架构·harmonyos
石小石Orz21 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
若风的雨21 小时前
【deepseek】RISC-V 的CSR寄存器详解
架构
ZHENGZJM1 天前
架构总览:Monorepo 结构与容器化部署
架构·go·react·全栈开发
搜佛说1 天前
比SQLite更快,比InfluxDB更轻:sfsDb的降维打击
jvm·数据库·物联网·架构·sqlite·边缘计算·iot
提子拌饭1331 天前
昼夜节律下的肝脏代谢清除率演算仪:基于鸿蒙Flutter的双路流场与酶解粒子对照架构
flutter·华为·架构·harmonyos·鸿蒙
SuperEugene1 天前
前端通用基础组件设计:按钮/输入框/弹窗,统一设计标准|组件化设计基础篇
前端·javascript·vue.js·架构
贺小涛1 天前
DeepSeek vs ChatGPT:技术架构深度解析与核心优势对比
chatgpt·架构
Ghost Face...1 天前
Linux USB 全栈解析:OTG + Type-C + PD 内核架构(架构师级)
linux·c语言·架构
be to FPGAer1 天前
架构与微架构设计
架构