Skip to content

🛬 数据迁移

数据行囊

数据行囊(Artrans = Art + Ran)是 Artalk 持久化数据保存规范格式。

Artran 格式定义

我们这样定义:每一条评论数据 (Object) 称为 Artran,多条评数据论组成一个 Artrans (Array 类型)

json
{
  "id": "123",
  "rid": "233",
  "content": "Hello Artalk",
  "ua": "Artalk/6.6",
  "ip": "233.233.233.233",
  "created_at": "2021-10-28 20:50:15 +0800",
  "updated_at": "2021-10-28 20:50:15 +0800",
  "is_collapsed": "false",
  "is_pending": "false",
  "vote_up": "666",
  "vote_down": "0",
  "nick": "qwqcode",
  "email": "qwqcode@github.com",
  "link": "https://qwqaq.com",
  "password": "",
  "badge_name": "管理员",
  "badge_color": "#FF716D",
  "page_key": "https://artalk.js.org/guide/transfer.html",
  "page_title": "数据迁移",
  "page_admin_only": "false",
  "site_name": "Artalk",
  "site_urls": "http://localhost:3000/demo/,https://artalk.js.org"
}

我们称:一个 JSON 数组为 Artran s

数组里的每一个 Object 项目为 Artran (没有 s)

转换工具

使用以下工具,将其他格式的评论数据转换为 Artrans,然后导入 Artalk。在新窗口中打开

提示

下文有各种获取源数据的方法可供参考;若遇问题,请提交 issue 反馈。

数据导入

转换为 .artrans 格式的数据文件可以导入 Artalk:

  • 控制中心导入:你可在「控制中心」找到「迁移」选项卡,并根据提示导入 Artrans。
  • 命令行导入:参考 命令行导入

获取源数据

Typecho

安装插件获取 Artrans

提供 Artrans 导出插件:

  1. 点击「这里」下载插件并「解压」到 Typecho 目录 /usr/plugins/
  2. 前往 Typecho 后台「控制台 - 插件」启用插件「ArtransExporter」。
  3. 前往「控制台 - 导出评论 (Artrans)」即可导出 Typecho 所有评论为 Artrans 格式。

直连数据库获取 Artrans

如果你的博客已闭站,但数据库还存在,可以使用我们提供的支持直连 Typecho 数据库的命令行工具。

下载 Artransfer-CLI 压缩包解压后,执行:

sh
./artransfer typecho \
    --db="mysql" \
    --host="localhost" \
    --port="3306" \
    --user="root" \
    --password="123456" \
    --name="typecho_数据库名"

执行后你将得到一份 Artrans 格式的文件:

sh
> ls
typecho-20220424-202246.artrans

注:支持连接多种数据库,详情参考此处

WordPress

前往 WordPress 后台「工具 - 导出」勾选「所有内容」,导出文件即可使用转换工具进行转换。

Valine

前往 LeanCloud 后台 导出 JSON 格式的评论数据文件,然后使用转换工具进行转换。

Waline

使用 LeanCloud 数据库的 Waline 可参考上面 Valine 的方法,它们格式相通,方法类似。

独立部署的 Waline 可下载 Artransfer-CLI 连接本地数据库导出,命令行执行:

bash
./artransfer waline \
    --db="mysql" \
    --host="localhost" \
    --port="3306" \
    --user="root" \
    --password="123456" \
    --name="waline_数据库名" \
    --table-prefix="wl_"

你将得到一份 Artrans 格式的数据文件,然后导入 Artalk

注:支持连接多种数据库,详情参考此处

Disqus

前往 Disqus 后台,找到「Moderation - Export」点击导出,Disqus 会将 .gz 格式的压缩包发送至你的邮箱,解压之后可以得到 .xml 格式的数据文件,然后使用转换工具转为 Artrans。

Commento

你可在 Commento 后台导出 JSON 格式的数据文件,然后使用转换工具进行转换。

【图示,待补充...】

Twikoo

Twikoo 是一款基于腾讯云开发的评论系统,可前往 腾讯云后台 导出 JSON 格式的评论数据,然后使用转换工具进行转换。

Artalk v1 (PHP 旧版后端)

Artalk v1 是 Artalk 的旧版后端,它使用 PHP 编写。新版后端我们全面转向 Golang,并重新设计了数据表结构,升级新版需要通过转换工具进行转换。

旧版数据路径:/data/comments.data.json

命令行导入

执行 artalk import -h 查看帮助文档。

bash
./artalk import [参数...] [文件名]

通过命令行的 -p Flag 设定导入参数:

bash
./artalk import -p '{ "target_site_name": "Site", "target_site_url": "https://xx.com", "json_file": "", "url_resolver": true }' ./artrans.json

如果在网页后台导入可将 JSON 填入文本框:

json
{
  "target_site_name": "Site",
  "target_site_url": "https://xx.com",
  "json_file": "服务器上的文件路径",
  "url_resolver": true
}

Artalk 导入参数:

参数类型说明
target_site_nameString导入站点名称
target_site_urlString导入站点 URL
url_resolverBoolean默认关闭,URL 解析器。将 page_key 基于 target_site_url 参数重新生成为完整 URL 作为评论的新 page_key
url_keep_domainBoolean默认关闭,是否保留原有 URL 的域名部分。当关闭时将去除 pageKey 中的域名。当 url_resolver 开启时,url_keep_domain 将被同时启用
json_fileStringJSON 数据文件路径
json_dataStringJSON 数据字符串内容
assumeyesBoolean不提确认 y/n,直接执行

数据备份

你可在前端界面的「控制中心」找到「迁移」选项卡,然后导出 Artrans 格式的评论数据。

命令行备份

导出:artalk export ./artrans

导入:artalk import ./artrans

高级玩法

执行 artalk export 可直接 “标准输出”,并进行 “管道” 或 “输出重定向” 等操作,例如:

bash
artalk export | gzip -9 | ssh username@remote_ip "cat > ~/backup/artrans.gz"

写在结尾

目前已支持将 Typecho、WordPress、Valine、Waline、Disqus、Commento、Twikoo 等类型的数据转为 Artrans,但鉴于评论系统的多样性,虽然我们已经对上述类型数据做了适配,但仍然还有许多并未兼容。如果你恰巧正在使用未被适配的评论系统,你除了等待 Artalk 官方支持之外,还可以尝试了解 Artrans 数据格式后自主编写评论数据导入导出工具。如果你觉得自己的工具写得不错,我们十分乐意将其收录在内,让我们共同创造一个能够在不同评论系统之间自由切换的工具。

前往:Artransfer 迁移工具代码仓库