- 在使用
Docker的过程中,很多容器的配置文件需要管理,使用过程中不少人对命令行及配置文件不熟悉,所以考虑将luci装入容器,配合luci-lib-docker以进行Docker容器的配置文件管理 luci-in-docker将openwrt中ubus去除,宿主为alpine,方便后期增加插件luci-in-docker目的是将家用NAS服务全部部署在Docker中,并通过luci进行管理,从而实现NAS IN DOCKER
lisaac/luci:latest内置luci-app-dockermanluci-app-diskmanluci-app-podsamba等常用插件(陆续增加,以实现简单 NAS 功能),需要骨架luci请使用lisaac/luci:nano
tips: 由于
luci-app-diskmanluci-app-dockerman中的依赖较多,第一次启动安装依赖可能会比较慢,需要多等一会,通过docker logs luci可以看到运行日志
docker pull lisaac/luci:latest
docker run -d \
--name luci \
--restart unless-stopped \
--privileged \
-p 80:80 \
-p 7682:7682 \
-e TZ=Asia/Shanghai \
-v $HOME/pods/luci:/external:rslave \
-v /media:/media:rshared \
-v /dev:/dev:rslave \
-v /var/run/docker.sock:/var/run/docker.sock \
--tmpfs /tmp:exec \
--tmpfs /run \
lisaac/luci:latest
lisaac/luci:nano版本只包含luci骨架,不含内置插件, 可以根据自己需要安装插件,插件目录结构请参考下一章节。
docker pull lisaac/luci:nano
docker run -d \
--name luci \
--restart unless-stopped \
--privileged \
-p 80:80 \
-p 7682:7682 \
-e TZ=Asia/Shanghai \
-v $HOME/pods/luci:/external:rslave \
-v /media:/media:rshared \
-v /dev:/dev:rslave \
-v /var/run/docker.sock:/var/run/docker.sock \
--tmpfs /tmp:exec \
--tmpfs /run \
lisaac/luci:nano
/
|- external # 外部目录,需要外部挂载
|-cfg.d
|-config # UCI cofnig 目录,用于存放配置文件,启动后 link 至/etc/config
|-crontab # crontab
|-periodic # crond 定期执行目录
|-rc.local # rc.local 本地启动执行脚本
|-shadow # 密码保存
|-plugin # 插件目录
|-luci-app-diskman # 插件,会忽略以 _ 开头的目录,方便调试,插件结构如下:
|-Makefile # 判定有效插件目录标志
|-root # 插件所需的 root 目录,合并至/tmp/.luci/
|-luasrc # 插件所需的 lua 文件目录,合并至/tmp/.luci/usr/lib/lua/luci
|-htdocs # 插件所需的 html 文件目录,合并至/tmp/.luci/www
|-po # 插件所需的 po 文件目录
|-depends.lst # 插件所需要 alpine 依赖列表文件, 依赖用' '隔开, 只用来存放 alpine 依赖
|-preinst # 插件所需的初始化脚本(合并前)
|-postinst # 插件所需的初始化脚本(合并后), 若没有此脚本, 会尝试执行 /root/etc/uci-defaults/ 下的插件初始化脚本
|-...
|- internal # 内部 luci-in-docker 自带插件目录(用户无需关心)
|-plugin # 内部插件目录
|-luci # luci 目录
|-Makefile # 判定有效插件目录标志
|-root # 插件所需的 root 目录,合并至/tmp/.luci/
|-luasrc # 插件所需的 lua 文件目录,合并至/tmp/.luci/usr/lib/lua/luci
|-htdocs # 插件所需的 html 文件目录,合并至/tmp/.luci/www
|-po # 插件所需的 po 文件目录
|-depends.lst # 插件所需要 alpine 依赖列表文件, 依赖用' '隔开, 只用来存放 alpine 依赖
|-preinst # 插件所需的初始化脚本(合并前)
|-postinst # 插件所需的初始化脚本(合并后)
|-...
|tmp
|-.luci # 合并后的 luci root 目录
- 通过遍历
internal/external目录下plugin中的各个插件目录,将其合并至/temp/.luci目录中,并修改path环境变量 - 同时保证兼容性和持久性
config目录存储位置为external/cfg.d/config, 挂载至/etc/config - 遍历时先执行
preinst,插件目录合并到/temp/.luci后,会通过apk add方式安装插件目录下depends.lst中需要的依赖,最后执行插件目录下postinst
- 插件合并时不会执行按照
Makefile编译,所以需要编译完成后ipk中的data目录中的内容,或者纯lua源码 + 二进制文件 - 插件中
po目录下的翻译文件会自动转换成对应lmo,并合并至luci/i18n目录 - 插件中依赖文件
depends.lst为alpine依赖,并非openwrt中的依赖 - 插件中的
preinst及postinst是在遍历插件目录执行的,可能执行preinst及postinst存在依赖其他插件的情况,可以将插件目录开头的加上数字,来确定遍历顺序 - 插件目录名若以
_开头,则会跳过此插件