对于将博客部署于Github的博主来说,每次写完日志或是对博客做了些改动,都会同步远程的Github仓库,重复的在终端执行git XXXX的命令,国内连接Github很不稳定,所以有时需要重复很多次,很麻烦的一说,今天我们就要解决掉这个痛点的。
一般部署与Github的博客进行同步的话,需要的命令是很少的,例如git add git commit git push
三条命令就可以搞定一个博客的更新了。
那么我们的目的就是在网络不通畅连接Github不稳定的时候,重复这几条命令,直到同步远程的仓库。
这里我使用Python终的subprocess.run()来执行这些git的命令行。
subprocess.run() 是 Python 中用于运行外部命令的函数之一。它是 subprocess 模块提供的一个高级接口,用于替代较低级的函数 subprocess.call()。
subprocess.run() 函数执行指定的命令,并等待命令完成执行。它提供了很多选项来控制命令的执行方式,并且可以获取命令的输出结果、错误信息和执行状态。
首先,我们需要进入到需要更新的仓库的根目录,然后再执行这一系列的git命令。
代码很简单,就不解释了,具体可以查看代码的注释:
import os
import time
import subprocess
def sync_to_remote_repo(path):
# 切换到指定目录
os.chdir(path)
while True:
# 1. 添加所有更新进入git的本地仓库
subprocess.run(["git", "add", "."])
# 添加更新信息
subprocess.run(["git", "commit", "-m", "更新博客"])
# 2. 同步到远程仓库
while True:
result = subprocess.run(["git", "push", "origin", "master"])
if result.returncode == 0:
# 如果成功同步到远程仓库,退出内部循环
break
else:
# 如果同步失败,等待一段时间后继续重试
time.sleep(10)
# 检查上一步操作的返回值
if subprocess.run(["git", "rev-parse", "--quiet", "--verify", "HEAD"]).returncode == 0:
# 如果成功同步到远程仓库,退出外部循环
break
else:
# 如果同步失败,等待一段时间后继续重试
time.sleep(10)
# 示例用法
directory_path = "/path/to/your/directory"
sync_to_remote_repo(directory_path)
这样我们以后就可以使用这个方法来自动更新博客文章和博客的改动了,即便网络不好,也不必重复的输入git push XXX,只需要运行上边的代码,等待他重复执行git命令直到更新同步Github仓库。