PHP无法原生定时发布,需借助Linux cron等外部调度;数据库须设status枚举字段与publish_at时间字段,并建(status, publish_at)联合索引;脚本需加锁防并发重复执行。
PHP 是请求响应式脚本语言,没有后台常驻进程能力。所谓“视频定时发布”,实际是:把发布时间存进数据库,再由外部机制(如 Linux cron)定期调用 PHP 脚本检查并执行发布逻辑。
不能只存一个 publish_time 就完事。必须区分“待发布”、“已发布”、“已取消”等状态,否则 cron 多次拉起时会重复操作。
status 字段建议用枚举:'draft'、'pending'、'published'、'cancelled'
publish_at 必须是 DATETIME 类型,且带时区一致性(推荐全用 UTC 存储)INDEX status_publish_at (status, publish_at),避免每次全表扫描Linux 的 cron 每分钟跑一次,但 PHP 脚本执行可能超时或卡住,导致多个实例同时运行,引发视频重复发布或状态错乱。
SELECT * FROM videos WHERE id = ? AND status = 'pending' AND publish_at <= NOW() FOR UPDATE
status 为 'published',并设 published_at = NOW()
video_id 和时间,方便排查漏发或重发开发机本地时间、Web 服务器时间、MySQL 服务器时间、PHP date_default_timezone_set() 设置,四者不一致就会导致“明明到了时间却不发布”。
date_default_timezone_set('UTC'),MySQL 启动参数加 --default-time-zone='+00:00'
NOW() 和系统时间是否一致:date 命令 vs SELECT NOW();
$_POST['publish_time']
真正难的不是写那几行 PHP 代码,而是让时间判断精准、状态流转可靠、多实例互斥安全——这些细节一旦漏掉,上线后
