Guovin / iptv-api
⚡️IPTV直播源自动更新平台『🤖全自动采集、筛选、测速、生成🚀』:自定义获取频道;IPv4/IPv6;接口验效;推流;多平台支持;工作流、Docker、命令行、GUI多端部署 | IPTV live streaming source automatic update platform
AI Architecture Analysis
This repository is indexed by RepoMind. By analyzing Guovin/iptv-api in our AI interface, you can instantly generate complete architecture diagrams, visualize control flows, and perform automated security audits across the entire codebase.
Our Agentic Context Augmented Generation (Agentic CAG) engine loads full source files into context, avoiding the fragmentation of traditional RAG systems. Ask questions about the architecture, dependencies, or specific features to see it in action.
Repository Summary (README)
PreviewEnglish | 中文
</div>[!IMPORTANT]
核心特性
| 功能 | 支持状态 | 说明 |
|---|---|---|
| 自定义模板 | ✅ | 生成自己想要的频道菜单 |
| 频道别名 | ✅ | 提升频道结果获取量与准确率,支持正则表达式 |
| 多源聚合 | ✅ | 本地源、订阅源 |
| 推流 | ✅ | 改善弱网播放体验,支持浏览器直接播放 |
| 回放类接口 | ✅ | 回放类接口的获取与生成 |
| EPG | ✅ | 获取并显示频道预告内容 |
| 频道台标 | ✅ | 自定义频道台标,支持本地添加或远程库 |
| 测速验效 | ✅ | 获取延迟、速率、分辨率,过滤无效接口,支持实时输出结果 |
| 高级偏好 | ✅ | 速率、分辨率、黑/白名单、归属地与运营商自定义过滤 |
| 结果管理 | ✅ | 结果分类存储与访问、日志记录、未匹配频道记录、统计分析、冻结过滤/解冻回归、数据缓存 |
| 定时任务 | ✅ | 定时或间隔执行更新 |
| 多平台部署 | ✅ | 工作流、命令行、GUI 软件、Docker (amd64/arm64/arm v7) |
| 更多功能 | ✨ | 详见配置参数章节 |
配置
[!NOTE]
以下配置项位于config/config.ini文件中,支持通过配置文件或环境变量进行修改,修改保存后重启即可生效
| 配置项 | 描述 | 默认值 |
|---|---|---|
| open_update | 开启更新,用于控制是否更新接口,若关闭则所有工作模式(获取接口和测速)均停止 | True |
| open_empty_category | 开启无结果频道分类,自动归类至底部 | False |
| open_update_time | 开启显示更新时间 | True |
| open_url_info | 开启显示接口说明信息,用于控制是否显示接口来源、分辨率、协议类型等信息,为 $ 符号后的内容,播放软件使用该信息对接口进行描述,若部分播放器(如 PotPlayer)不支持解析导致无法播放可关闭 | False |
| open_epg | 开启 EPG 功能,支持频道显示预告内容 | True |
| open_m3u_result | 开启转换生成 m3u 文件类型结果链接,支持显示频道图标 | True |
| urls_limit | 单个频道接口数量 | 5 |
| update_time_position | 更新时间显示位置,需要开启 open_update_time 才能生效,可选值: top、bottom;top: 显示于结果顶部,bottom: 显示于结果底部 | top |
| language | 系统语言设置;可选值: zh_CN、en | zh_CN |
| update_mode | 定时执行更新时间模式,不作用于工作流;可选值: interval、time; interval: 按间隔时间执行,time: 按指定时间点执行 | interval |
| update_interval | 定时执行更新时间间隔,仅在update_mode = interval时生效,单位小时,设置 0 或空则只运行一次 | 12 |
| update_times | 定时执行更新时间点,仅在update_mode = time时生效,格式 HH:MM,支持多个时间点逗号分隔 | |
| update_startup | 启动时执行更新,用于控制程序启动后是否立即执行一次更新 | True |
| time_zone | 时区,可用于控制定时执行时区或显示更新时间的时区;可选值: Asia/Shanghai 或其它时区编码 | Asia/Shanghai |
| source_file | 模板文件路径 | config/demo.txt |
| final_file | 生成结果文件路径 | output/result.txt |
| open_realtime_write | 开启实时写入结果文件,在测速过程中可以访问并使用更新结果 | True |
| open_service | 开启页面服务,用于控制是否启动结果页面服务;如果使用青龙等平台部署,有专门设定的定时任务,需要更新完成后停止运行,可以关闭该功能 | True |
| app_port | 页面服务端口,用于控制页面服务的端口号 | 5180 |
| public_scheme | 公网协议;可选值: http、https | http |
| public_domain | 公网 Host 地址,用于生成结果中的访问地址,默认使用本机 IP | 127.0.0.1 |
| cdn_url | CDN 代理加速地址,用于订阅源、频道图标等资源的加速访问 | |
| http_proxy | HTTP 代理地址,用于获取订阅源等网络请求 | |
| open_local | 开启本地源功能,将使用模板文件与本地源文件(local.txt)中的数据 | True |
| open_subscribe | 开启订阅源功能 | True |
| open_history | 开启使用历史更新结果(包含模板与结果文件的接口),合并至本次更新中 | True |
| open_headers | 开启使用 M3U 内含的请求头验证信息,用于测速等操作,注意:只有个别播放器支持播放这类含验证信息的接口,默认为关闭 | False |
| open_speed_test | 开启测速功能,获取响应时间、速率、分辨率 | True |
| open_filter_resolution | 开启分辨率过滤,低于最小分辨率(min_resolution)的接口将会被过滤,GUI 用户需要手动安装 FFmpeg,程序会自动调用 FFmpeg 获取接口分辨率,推荐开启,虽然会增加测速阶段耗时,但能更有效地区分是否可播放的接口 | True |
| open_filter_speed | 开启速率过滤,低于最小速率(min_speed)的接口将会被过滤 | True |
| open_full_speed_test | 开启全量测速,频道下所有接口(白名单除外)都进行测速,关闭则当测速有效结果数量达到urls_limit后停止剩余接口测速 | False |
| open_supply | 开启补偿机制模式,用于控制当频道接口数量不足时,自动将不满足条件(例如低于最小速率)但可能可用的接口添加至结果中,从而避免结果为空的情况 | False |
| min_resolution | 接口最小分辨率,需要开启 open_filter_resolution 才能生效 | 1280x720 |
| max_resolution | 接口最大分辨率,需要开启 open_filter_resolution 才能生效 | 3840x2160 |
| min_speed | 接口最小速率(单位 M/s),需要开启 open_filter_speed 才能生效 | 0.5 |
| resolution_speed_map | 分辨率与速率映射关系,用于控制不同分辨率接口的最低速率要求,格式为 resolution:speed,多个映射关系逗号分隔 | 1280x720:0.2,1920x1080:0.5,3840x2160:1.0 |
| speed_test_limit | 同时执行测速的接口数量,用于控制测速阶段的并发数量,数值越大测速所需时间越短,负载较高,结果可能不准确;数值越小测速所需时间越长,低负载,结果较准确;调整此值能优化更新时间 | 5 |
| speed_test_timeout | 单个接口测速超时时长,单位秒(s);数值越大测速所需时间越长,能提高获取接口数量,但质量会有所下降;数值越小测速所需时间越短,能获取低延时的接口,质量较好;调整此值能优化更新时间 | 10 |
| speed_test_filter_host | 测速阶段使用 Host 地址进行过滤,相同 Host 地址的频道将共用测速数据,开启后可大幅减少测速所需时间,但可能会导致测速结果不准确 | False |
| request_timeout | 查询请求超时时长,单位秒(s),用于控制查询接口文本链接的超时时长以及重试时长,调整此值能优化更新时间 | 10 |
| ipv6_support | 强制认为当前网络支持 IPv6,跳过检测 | False |
| ipv_type | 生成结果中接口的协议类型;可选值: ipv4、ipv6、all | all |
| ipv_type_prefer | 接口协议类型偏好,优先将该类型的接口排在结果前面;可选值: ipv4、ipv6、auto | auto |
| location | 接口归属地,用于控制结果只包含填写的归属地类型,支持关键字过滤,英文逗号分隔,不填写表示不指定归属地,建议使用靠近使用者的归属地,能提升播放体验 | |
| isp | 接口运营商,用于控制结果中只包含填写的运营商类型,支持关键字过滤,英文逗号分隔,不填写表示不指定运营商 | |
| origin_type_prefer | 结果偏好的接口来源,结果优先按该顺序进行排序,逗号分隔,例如: local,subscribe;不填写则表示不指定来源,按照接口速率排序 | |
| local_num | 结果中偏好的本地源接口数量 | 10 |
| subscribe_num | 结果中偏好的订阅源接口数量 | 10 |
| logo_url | 频道台标库地址 | |
| logo_type | 频道台标文件类型 | png |
| open_rtmp | 开启 RTMP 推流功能,需要安装 FFmpeg,利用本地带宽提升接口播放体验 | True |
| nginx_http_port | Nginx HTTP 服务端口,用于 RTMP 推流转发的 HTTP 服务端口 | 8080 |
| nginx_rtmp_port | Nginx RTMP 服务端口,用于 RTMP 推流转发的 RTMP 服务端口 | 1935 |
| rtmp_idle_timeout | RTMP 频道接口空闲停止推流超时时长,单位秒(s),用于控制接口无人观看时超过该时长后停止推流,调整此值能优化服务器资源占用 | 300 |
| rtmp_max_streams | RTMP 推流最大并发数量,用于控制同时推流的频道数量,数值越大服务器压力越大,调整此值能优化服务器资源占用 | 10 |
快速上手
配置与结果目录
iptv-api/ # 项目根目录
├── config # 配置文件目录,包含配置文件、模板文件等
│ └── hls # 本地HLS推流文件目录,用于存放多个频道名称命名的视频文件
│ └── local # 本地源文件目录,用于存放多个本地源文件,支持txt/m3u格式
│ └── config.ini # 配置参数文件
│ └── demo.txt # 频道模板
│ └── alias.txt # 频道别名
│ └── blacklist.txt # 接口黑名单
│ └── whitelist.txt # 接口白名单
│ └── subscribe.txt # 频道订阅源列表
│ └── local.txt # 本地源文件
│ └── epg.txt # EPG订阅源列表
└── output # 结果文件目录,包含生成的结果文件等
└── data # 结果数据缓存目录
└── epg # EPG结果目录
└── ipv4 # IPv4结果目录
└── ipv6 # IPv6结果目录
└── result.m3u/txt # m3u/txt结果
└── hls.m3u/txt # RTMP hls推流结果
└── log # 日志文件目录
└── result.log # 有效结果日志
└── speed_test.log # 测速日志
└── statistic.log # 统计结果日志
└── nomatch.log # 未匹配频道记录
工作流
Fork 本项目并开启工作流更新,具体步骤请见详细教程
命令行
pip install pipenv
pipenv install --dev
启动更新:
pipenv run dev
启动服务:
pipenv run service
GUI 软件
-
下载IPTV-API 更新软件,打开软件,点击启动,即可进行更新
-
或者在项目目录下运行以下命令,即可打开 GUI 软件:
pipenv run ui
<img src="./docs/images/ui.png" alt="IPTV-API更新软件" title="IPTV-API更新软件" style="height:600px" />
Docker
1. Compose部署(推荐)
下载docker-compose.yml或复制内容创建(内部参数可按需更改),在文件所在路径下运行以下命令即可部署:
docker compose up -d
2. 手动命令部署
(1)拉取镜像
docker pull guovern/iptv-api:latest
🚀 代理加速(若拉取失败可以使用该命令,但有可能拉取的是旧版本):
docker pull docker.1ms.run/guovern/iptv-api:latest
(2)运行容器
docker run -d -p 80:8080 guovern/iptv-api
环境变量:
| 变量 | 描述 | 默认值 |
|---|---|---|
| PUBLIC_DOMAIN | 公网域名或IP地址,决定外部访问或推流结果的Host地址 | 127.0.0.1 |
| PUBLIC_PORT | 公网端口,设置为映射后的端口,决定外部访问地址和推流结果地址的端口 | 80 |
| NGINX_HTTP_PORT | HTTP服务端口,外部访问需要映射该端口 | 8080 |
如果需要修改环境变量,在上述运行命令后添加以下参数:
# 修改公网域名
-e PUBLIC_DOMAIN=your.domain.com
# 修改公网端口
-e PUBLIC_PORT=80
除了以上环境变量,还支持通过环境变量覆盖配置文件中的配置项
挂载: 实现宿主机文件与容器文件同步,修改模板、配置、获取更新结果文件可直接在宿主机文件夹下操作,在上述运行命令后添加以下参数
# 挂载配置目录
-v /iptv-api/config:/iptv-api/config
# 挂载结果目录
-v /iptv-api/output:/iptv-api/output
3. 更新结果
| 接口 | 描述 |
|---|---|
| / | 默认接口 |
| /m3u | m3u 格式接口 |
| /txt | txt 格式接口 |
| /ipv4 | ipv4 默认接口 |
| /ipv6 | ipv6 默认接口 |
| /ipv4/txt | ipv4 txt接口 |
| /ipv6/txt | ipv6 txt接口 |
| /ipv4/m3u | ipv4 m3u接口 |
| /ipv6/m3u | ipv6 m3u接口 |
| /content | 接口文本内容 |
| /log/result | 有效结果的日志 |
| /log/speed-test | 所有参与测速接口的日志 |
| /log/statistic | 统计结果的日志 |
| /log/nomatch | 未匹配频道的日志 |
RTMP 推流:
[!NOTE]
- 如果是服务器部署,请务必配置
PUBLIC_DOMAIN环境变量为服务器域名或IP地址,PUBLIC_PORT环境变量为公网端口,否则推流地址无法访问- 开启推流后,默认会将获取到的接口(如订阅源)进行推流
- 如果需要对本地视频源进行推流,可在
config目录下新建hls文件夹,将以频道名称命名的视频文件放入其中,程序会自动推流到对应的频道中
| 推流接口 | 描述 |
|---|---|
| /hls | 推流接口 |
| /hls/txt | 推流txt接口 |
| /hls/m3u | 推流m3u接口 |
| /hls/ipv4 | 推流ipv4 默认接口 |
| /hls/ipv6 | 推流ipv6 默认接口 |
| /hls/ipv4/txt | 推流ipv4 txt接口 |
| /hls/ipv4/m3u | 推流ipv4 m3u接口 |
| /hls/ipv6/txt | 推流ipv6 txt接口 |
| /hls/ipv6/m3u | 推流ipv6 m3u接口 |
| /stat | 推流状态统计接口 |
更新日志
关注
Github
关注我的Github账号Guovin,获取更多实用项目
微信公众号
微信公众号搜索 Govin,或扫码,接收更新推送、学习更多使用技巧:

需要更多帮助?
联系邮箱:360996299@qq.com
Star统计
捐赠
<div>开发维护不易,请我喝杯咖啡☕️吧~</div>| 支付宝 | 微信 |
|---|---|
![]() | ![]() |
免责声明
- 本项目仅为工具/框架,不包含或提供任何直播源、受版权保护的节目或其他第三方内容。用户需自行添加数据源并确保所使用的数据源及使用行为符合所在地区法律法规。
- 使用者对通过本项目获取、分发或播放的内容独立负责。请勿用于传播、分发或观看未经授权的受版权保护内容。
- 在使用本项目时,应遵守当地相关法律法规与监管要求。作者不对因用户使用本项目而产生的任何法律责任承担责任。
- 商业、企业或生产环境使用前建议咨询法律顾问并做好合规审查。

