/alist-sync

Alist同步工具

Primary LanguagePythonMIT LicenseMIT

alist-sync

Alist 同步工具

终极目标:利用GitHub Actions实现使用Github的计算和网络资源定期同步各个网盘之间的数据。

本地运行

  1. 克隆并cd到存储库: git clone https://github.com/lee-cq/alist-sync.git && cd alist-sync
  2. 创建配置文件配置模版cp config-template.yaml config.yaml
  3. 配置AList服务端(可以是远程的)
  4. Linux: ./bootstrap.sh main sync Windows: python -m alist_aync sync

Actions 运行

  1. FORK存储库

  2. 创建SYNC_CONFIG文件,内容参见:config-template.yaml

  3. 创建存储库机密(Action):

    1. ALIST_BACKUP: 可选 [JSON] 现有ALIST网页端导出的备份配置, 用于初始化Alist
    2. ALIST_BACKUP_URL: 可选 [URL] 可以从远程导出BACKUP的URL, 与ALIST_BACKUP二选一
    3. ALIST_BACKUP_USERNAME: 可选 [string] 当ALIST_BACKUP存在时,需要提供用户名
    4. ALIST_BACKUP_PASSWORD: 可选 [string] 当ALIST_BACKUP存在时,需要提供密码
    5. ALIST_ADMIN_PASSWORD: 可选[string] 管理员密码,默认值: 123456
    6. SYNC_CONFIG: 必选[YAML|JSON] Alist-sync的配置
  4. 启用Action

预期同步模式:

1. copy 简单复制 (已实现)

工作原理:

将源目录中的文件分别同步到全部的目标目录中,

  1. 如果目标目录中已经存在该文件,则跳过
  2. 忽略存在与目标目录中但不存在于源目录中的文件

2. mirror 镜像复制 (待实现)

工作原理:

将源目录中的文件分别镜像同步到全部的目标目录中,

  1. 如果目标目录中已经存在该文件,则跳过
  2. 删除存在于目录目录但不存在于源目录中的文件

3. sync 多源双向复制(实现中)

工作原理:

-s 指定的目录分别作为源目录,想其他的目录中发起copy命令 将源目录中的文件分别镜像同步到全部的目标目录中,

  1. 如果目标目录中已经存在该文件,则跳过
  2. 删除存在于目录目录但不存在于源目录中的文件

4. sync-incr 多源增量复制(设计中)

工作原理:

-s 指定的目录分别作为源目录,想其他的目录中发起copy命令, 首次运行后会生成配置文件,持久化保存,作为增量的识别文件。

在每一个需要同步的目录创建.alist-sync-data(它不会被扫描器识别)

.alist-sync-data/
    scanner/
        time.time.json
    sync-lockor.json
history/
    file_path_MD5.history
    file_path_MD5.history.json
    ...