Github使用GitHub Actions Workflow 自动同步fork的项目或使用Pull自动同步

简单介绍 🥰

GitHub 是一个流行的代码托管平台,允许开发人员分享和协作他们的代码。当您在 GitHub 上 fork 一个项目时,您会创建一个该项目的副本,您可以对其进行修改和贡献,而不会影响原始项目。但是,如果您想将您的更改同步回原始项目,您需要创建一个 pull Request-Hook

建议使用第二种方法

首先打开Actions页面 新建workflow(第一种方法 )

首先打开你Fork的项目,打开Actions页面,点击new workflow,选择set up a workflow yourself进入编辑页面。
workflowt

编辑文件

文件取名为sync.yml,然后输入以下代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
name: Upstream Sync

permissions:
contents: write

on:
schedule:
- cron: "0 0 * * *"
workflow_dispatch:

jobs:
sync_with_upstream:
name: Sync with Upstream
runs-on: ubuntu-latest
if: ${{ github.event.repository.fork }}

steps:
- name: Checkout target repo
uses: actions/checkout@v3

- name: Sync Upstream
uses: aormsby/Fork-Sync-With-Upstream-action@v3.4
with:
target_repo_token: ${{ secrets.GITHUB_TOKEN }}
upstream_sync_repo: shaoyouvip/uptime
upstream_sync_branch: main
target_sync_branch: main
test_mode: false

- name: Check for Failure
if: failure()
run: |
echo "[Error] Due to a change in the workflow file of the upstream repository, GitHub has automatically suspended the scheduled automatic update. You need to manually sync your fork."
exit 1

修改配置

  1. 定时任务执行间隔
    修改cron项,这里是0 0 * * *,代表每天0点执行一次

  2. 要同步的仓库路径
    修改upstream_sync_repo项,这里要填你fork的仓库路径,在你fork项目的的名字下方能看到。
    同步的仓库路径
    同步的仓库路径2

  3. 同步分支名称( 超级无敌要注意
    修改upstream_sync_branchtarget_sync_branch项,填写你要同步分支的名称,例如我填的main,一般来说fork的分支名称都一样,但这只是一般情况,也有的老项目默认的分支不是main,在Sync Upstream步骤中请一定确保你上游项目的分支路径。

提交保持文件

填写完成后点右上角commit changes,然后确认。
提交保持文件
提交保持文件2

测试运行

回到Actions页面,点击你刚刚创建的workflow,点击Run workflow
测试运行

运行成功

刷新页面可以看到效果
运行成功
运行成功2

使用 Pull 自动同步(第二种方法 )

设置 Pull 帮助我们和上游保持一致同步

  1. 打开 https://github.com/apps/pull 点击右上角安装,选择你的账户。
    Pull
  2. 选择你要同步的项目,选择储存库不要选所有储存库,有些项目并不是最新的就是好的。你自己选择。
    同步
    安装
  3. 下次如要添加新的项目同步可以在你的Github 账户设置
    账户设置
  4. 找到 Applications应用 Configure配置你的 新项目
    配置拉取
  5. 选择你要同步的项目就可以了,完事结束!
    同步项目

相关链接

workflow 点击前往

Pull 点击前往

Request-Hook 点击前往