2

我想在我的本地机器上设置 Hasura 的开发环境,复制我现有的产品(相同的表、相同的模式、相同的数据)。

  • 完成此任务所需的步骤是什么?
4

3 回答 3

3

我发现这个过程运作良好。

  1. 创建一个干净的空本地 postgresql 数据库和 Hasura 实例。要更新现有的本地数据库,请将其删除并重新创建

  2. 从现有的 Hasura 服务器转储模式和数据(根据@protob 的回答,但使用clean_outputset 以便不必对输出进行手动更改。有关详细信息,请参阅pgdump

    curl --location --request POST 'https://example.com/v1alpha1/pg_dump' \
      --header 'Content-Type: application/json' \
      --header 'X-Hasura-Role: admin' \
      --header 'Content-Type: text/plain' \
      --header 'x-hasura-admin-secret: {SECRET}' \
      --data-raw '{ "opts": ["-O", "-x","--inserts",  "--schema", "public"], "clean_output": true}' > hasura-db.sql
    
  3. 在本地导入架构和数据:

    psql -h localhost -U postgres < hasura-db.sql
    
  4. 本地数据库包含所有迁移,因为我们复制了最新的模式,所以只需将它们标记为已应用:

    # A simple `hasura migrate apply --skip-execution` may work too!
    for x in $(hasura migrate status | grep "Not Present" | awk '{ print $1 }'); do
      hasura migrate apply --version $x --skip-execution
    done
    
    # and confirm the updated status
    hasura migrate status
    
  5. 现在最后使用 hasura CLI 应用 Hasura 元数据:

    hasura metadata apply
    

享受您的新实例!

于 2020-12-02T19:07:53.940 回答
1
  1. 备份数据库。
  2. 使用数据库运行 Hasura。
  3. 确保 Hasura 元数据已同步。
于 2020-02-15T09:33:29.980 回答
1

Hasura 有一个特殊的端点用于在 Postgres 实例上执行 pg_dump。

这是一个示例 CURL 请求:

curl --location --request POST 'https://your-remote-hasura.com/v1alpha1/pg_dump' \ --header 'Content-Type: application/json' \ --header 'X-Hasura-Role: admin' \ --header 'Content-Type: text/plain' \ --data-raw '{ "opts": ["-O", "-x","--inserts", "--schema", "public"] }'

它以 psql 格式输出模式和数据。

您可以使用 Postman 等工具来方便地导入、测试和运行 CURL 查询。

请按照 pg_dump 文档调整所需的选项。

即上面的查询使用“--inserts” opt,它在输出中产生“INSERT INTO”语句。

输出可以直接复制、粘贴和导入到 Hasura 面板 SQL 选项卡(“COPY FROM stdin”语句插入面板时会导致错误)。

http://localhost:8080/console/data/sql

在导入之前,注释掉或CREATE SCHEMA public;从查询中删除该行,因为它已经存在。

您还必须在执行查询期间或之后选择要跟踪的表和关系。

如果数据量较大,最好使用 CLI 进行导入。

于 2020-04-10T02:53:09.637 回答