alist-strm脚本最终版本
(将alist的视频文件生成媒体播放设备可播放的strm文件脚本(带webUI界面))
更新日志:
- [√] 增加配置文件管理webUI管理界面
- [√] 增加定时任务配置
- [√] 支持多线程运行,选择配置文件运行多线程运行
- [√] 优化代码结构
- [√] 弃用.ini方式的配置文件存储方式,更改为轻量级数据库SQLlite
7.12更新
- [√] 新增alist单向同步(即为本地strm文件失效删除)
- [√] 增加复制配置功能
- [√] 增加元数据下载功能
- [√] 支持脚本线程设置
- [√] 元数据格式、视频格式自定义
- [√] webUI增加账户验证
7.13更新
- [√] 新增alist签名开启支持(增强alist安全性)
- [√] 部分UI优化操作逻辑
- [√] 定时任务逻辑优化,日志输出优化
github地址,如果各位大佬觉得脚本好用的可以帮我点个小星星哦。
部署
docker一键部署
命令行版本:
docker run -d --name alist-strm -p 18080:5000 -v /home:/home - /volume1/alist-strm/config:/config itefuir/alist-strm:latest
#18080是宿主机端口 不是一定要这个 容器端口5000是一定要的
#/home是本地路径
docker-compose.yaml配置
version: "3"
services:
alist-strm:
stdin_open: true
tty: true
volumes:
#跟命令行一样的 前面是宿主机的目录
- /volume1/video:/volume1/video
- /volume1/alist-strm/config:/config
#第二行填写的是容器中数据库的存放位置
ports:
#:前面是宿主机的端口,自由选择
- "15000:5000"
container_name: alist-strm
#restart: always
image: itefuir/alist-strm:latest
network_mode: bridge
拉取docker镜像网络原因看这里
如果本地镜像拉取困难的可以前往镜像包下载地址下载后导入:传送门
导入方式就去百度啦 这里就不说啦
配置
配置格式是什么
运行起来之后他会有个默认配置。如果不会填可以参考默认配置填入配置
配置词条解释:
监控路径:即为你要生成的strm的alist的路径。比如说你访问到alist的路径是这样的
http://192.168.100.166:5244/115/动漫/剧集/
那么在这一栏你就需要填写/115/动漫/剧集
- alist的url:这里就不用说了吧,就是你访问alist的地址。上面以上面例子为例就是
http://192.168.100.166:5244
- 目标目录:字面意思理解的就是生成strm文件的文件夹路径,但是需要注意的是这里填写的是docker容器内部的路径。比如说我想生成在我nas上的
/home/alist-strm/115
的目录下,我docker运行时已经把宿主机的/home
映射到容器的/home
上了,那我现在可以直接填写/home/alist-strm/115
即可。如果不是的话需要注意对应 - 忽略的目录:这个就随便填即可,但是不能留空。如果有不想创建的目录按需填写
- 令牌获取见下文
- alist是否启用签名:这个选项用于增强一些用户alist是暴露在公网的安全性,但是会对alist负载产生一点影响。没有特殊需求不推荐开启,如果开启了alist后台也应该对应开启。
alist
令牌如何获取:
进入alist网页端,使用管理员账号密码登陆至后台
点击设置后
点击其他
就可以看到令牌啦
关于定时任务
定时任务选择需要进行定时的任务,在corn表达式中添加你想要的间隔时间。不会填写corn的可以参考
每个字段的取值范围和允许的特殊字符如下:
秒 (秒 可选,在某些系统或应用中才支持): 0-59
分钟: 0-59
小时: 0-23
日期: 1-31 (注意一些月份没有31日)
月份: 1-12 或 JAN-DEC
星期: 0-6 或 SUN-SAT,其中0和7都代表周日
(对于不包括秒的cron表达式,则从分钟开始)
Cron表达式中的特殊字符含义:
*:代表任何可能的值,例如在分钟字段表示每分钟。
,:用于指定多个值,比如 MON,WED,FRI 表示周一、周三和周五。
-:表示范围,如 1-5 表示1到5之间的所有数字。
/:用于指定间隔频率,如 0/15 在分钟字段表示每15分钟执行一次。
示例
每天凌晨1点执行:0 1 * * *
每周一到周五的上午9:30执行:30 9 * * 1-5
每隔5分钟执行一次:*/5 * * * *
每月1号和15号的下午2点执行:0 14 1,15 * *
如果需要包含秒,表达式变为7个字段,第一个字段表示秒,其余相同,例如:
每隔10秒执行一次:*/10 * * * * *
此信息来自于大模型AI。 填入之后只有到你设定的那个时间他才会自动运行 可以看定时任务的日志查看是否运行了
关于多线程运行
本脚本先前都是用的单线程多配置文件的方式运行的,如果alist上的资源较多的话可能会造成等待时间过长等等。如果alist是上了cdn或者防火墙的建议将运行本脚本的ip加入白名单以免请求过快触发阈值。
现在是你只要勾选了配置文件并且点击运行(或定时任务设定)它就会自动以每个配置文件为一个线程进行创建strm文件。
脚本配置说明
其实这里面的配置都是字面意思
有几个地方说明下:
- 元数据下载:即为监控目录中有
.nfo、.xml
文件会下载到对应的目录下 - 失效链接检查:检查本地strm文件是否失效,如果失效删除strm文件并且清空目录(如果目录下没有strm文件就清空文件夹)
- 启用alist强制刷新:如果启用的话代表着每一次脚本访问监控目录下的子目录它都会刷新一次alist的目录列表(可以理解为alist的网页端点击刷新按钮),这样会导致产生大量对挂载的网盘的api请求,但是会保证每次都是最新的数据。除非有特殊需求,否则不建议开启
- 脚本运行线程数:这里设置脚本的线程数,字面意思。在遍历目录时会使用,在下载文件时会使用,创建strm文件也会。但是注意不要开太大了。如果3太慢了建议使用5,最好不要超过10。如果你的nas是12代I5那当我没说(bushi)
几个常见问题:
运行脚本生成的strm不全。如果挂载的是115网盘,访问alist网页,查看挂载的存储是否返回“访问的网址不安全。。。。”啥啥啥的等等提示,如果是的话 那就是被115防火墙阻断了。
解决办法:
1、等待防火墙解封ip(cookie)或者更换cookie重新添加存储
2、更新alist版本,将图示变量设置小点,测试设置为2时正常旧版本升级后使用旧数据库报错,首页上不去
解决办法:删除原有数据库后重启容器
至此项目完结撒花,如果有bug博客评论留言吧。大概率没有后续版本更新啦。
现已知bug:
在容器重启之后,定时任务失效。不会自动定时
解决办法:重新开关定时任务。
24 条评论
容器的cron,配置一段时间后会失效,不知道为啥
最新版本修复了这个问题 拉取下最新镜像就好了 新版本重构了 旧版本的数据库要删掉 容器也是
谢谢,我都开始自学了
你这个站点,一会儿进的去,一会儿进不去
可能是前段时间刚好在整顿吧
有一点好难受,用了5000端口....
小猫盘-老docker,只能设置host网络。
把我群晖5000挤走了。
强迫症犯了 ┭┮﹏┭┮
但是你端口没法映射嘛? 后续考虑看看应该会给个配置文件自定义端口号
请问这个是每次都需要完全扫描文件夹,然后再生成strm吗?如果文件量比较大,每次扫一回都需要很长时间,未来可以更新为增量文件生成strm吗?
增量更新的话 主要是逻辑被卡住了。目前脚本逻辑是使用alist的api遍历目录结构 然后保存json去对比本地的目录树 如果alist返回的跟本地不一样再进行操作 如果单单增量的话 你有什么好的逻辑参考下嘛
目前检测是否生效也是这样检测的 本来想通过使用curl来检验。但是好像如果链接多的话 会导致占用特别大。。。。
单次运行脚本,从网盘中下载图片,下载后的图片容量只有51B,无法正常打开。
将图片转换成txt看下报错
我也是这个情况,不知道什么原因
你好我设置了.dat格式,还是没办法抓
是所有都不行吗 还是只有dat格式不行。
图片下载失败了? 看看日志
你好,我设了视频格式.dat,没办法爬取
冲天 (2015) - 1080p.d20240715-u092217.nfo,我的nfo文件格式是这样的,请问怎么修改代码可以识别。
看了代码了,知道了,要和视频保持一致
好的嘞
你好 生成的文件看不到???
可以把你配置贴出来看下吗?
有几种可能
1、配置填写出错
2、你看错文件夹了,是容器映射出去的文件夹。(配置中也要写对应的目录)
docker run -d --name alist-strm -p 18080:5000 -v /volume1/docker/alist-strm:/alist-strm itefuir/alist-strm:latest 我是黑群晖的安装映射目录到我的DOCKer新建的alist-strm,配置文件目标目录写的/docker/alist-strm,日志提示成功了,但是目录里面没有文件
你目的目录写错了 目的目录应该跟你的映射到容器内的目录一样或者是下级目录 即为/alist-strm
不知道为什么,路径目录怎么设置生成strm的问题都出不了,日志又显示成功