GitHub Actions 定时运行代码
GitHub Actions 定时运行代码:每天定时百度链接推送
GitHub Actions 是一个 CI/CD(持续集成/持续部署)工具,但也可用作代码运行环境。功能非常强大,能够玩出许多花样。
百度主动链接推送
链接主动推送在百度站长中有介绍
具体使用方法就是创建一个文件urls.txt
,文件内每行一条链接的格式写入提交的多个链接
运行命令
1 | curl -H 'Content-Type:text/plain' --data-binary @urls.txt "http://data.zz.baidu.com/urls?site=xxx.com&token=T5PEAzhG*****" |
上面命令的地址和参数由百度站长提供。运行完命令会返回推送结果,不出意外的话就会把urls.txt
内的所有链接一次性推送给百度。
这个方法虽然比嵌入网站头部的自动推送更高效,但是也有它的麻烦之处,就是得自己填入链接到urls.txt
文件,然后手动运行命令。
自动生成urls.txt
没关系,技术的本质就是让人”偷懒”的。于是,我写了一个nodejs工具,用于把所有的博客页面链接生成到urls.txt
1 | // baiduPush.js |
上面代码仅是针对我个人的博客生成链接到urls.txt
文件。
运行如下命令就可以生产一个包含博客所有链接的urls.txt
文件:
1 | node utils/baiduPush.js https://xxx.com |
哈哈,第一个麻烦解决了:smirk:,接下来是解决第二个需要手动运行推送命令的问题。
如果你没办法自动生成,你也可以自己手动创建一个
urls.txt
文件,放到github仓库。
GitHub Actions 定时运行代码
今天的主角GitHub Actions 要登场了。(相关:GitHub Actions 入门教程
GitHub Actions 是一个 CI/CD(持续集成/持续部署)工具,但也可用作代码运行环境。功能非常强大,能够玩出许多花样。
配置 GitHub Actions
触发 GitHub Actions 需要在项目仓库新建一个.github/workflows
子目录,里面是 YAML 格式配置文件,文件名可以随便取。GitHub 只要发现配置文件,就会运行 Actions。
配置文件的第一部分是触发条件。
1 | ## baiduPush.yml |
上面代码中,name
字段是配置文件的描述,on
字段是触发条件。我们指定两种情况下触发,第一种是代码 Push 进仓库,第二种是定时任务,每天在国际标准时间23点(北京时间+8,即早上7点)运行。
定时设置看这里
接着,就是运行流程。
1 | jobs: |
上面代码中,指定运行环境是最新的ubuntu,流程的第一步是从代码仓库获取代码,第二步运行两个命令,先安装项目依赖,再运行写在package.json
的baiduPush
命令。
baiduPush
命令在package.json
配置
1 | // package.json |
上面脚本中在node utils/baiduPush.js
的后面加入你的域名参数。运行此命令生成urls.txt
文件,然后执行baiduPush.sh
文件。
注意,在使用window系统时,请使用git bash命令窗运行上面的脚本。
baiduPush
命令之所以没有放在baiduPush.yml
的 run 里面是因为我想在本地也可以执行npm run baiduPush
命令。
baiduPush.sh
执行百度推送命令
baiduPush.sh
文件:
1 |
|
上面代码中,把urls.txt
文件中的所有链接一次性推送。
baiduPush.sh内的命令之所以没有写在
package.json
是因为我觉得命令太长了,不方便阅读。
写好配置,推送到仓库,就会在每天的早上7点钟,自动运行命令生成一个包含博客所有页面链接的urls.txt
文件,并把所有链接一次性推送到百度。麻麻再也不用担心我的网站不被收录~~:kissing_heart: :kissing_heart: :kissing_heart:
在这个基础上可以扩展,使用GitHub Actions满足你自己的各种定时需求。