Skip to main content
Version: v2.x

Metadata Best Practices

Proper Metadata management ensures the Hasura GraphQL Engine operates appropriately and as expected. You can use several different patterns to manage Metadata successfully. However, the below do's, and don'ts have been gathered through real-world practices, user experiences, and challenges when managing enterprise-scale Hasura ecosystems.

  • Use the Hasura CLI to manage and export Metadata.

    • The CLI exports YAML files which is much more source-control friendly than JSON (exported by the Console and API).
    • Using the Hasura CLI Console will capture all Metadata changes in the local file system as the changes are made.
  • Use the Hasura CLI Console as your development Console.

  • Leverage a version control solution such as GitHub or GitLab as the source of truth for the Metadata configuration.

    • Local files updated by the CLI Console are then committed to the source control solution.
  • We recommend retaining the CLI-exported file structure for ease of use.

  • Automate deployments using tools such as GitHub Actions, Jenkins, or the CLI-migrations image.

Note

Hasura Cloud users can leverage the GitHub integration to automate deployments.

  • Ensure good regression testing is implemented as part of the deployment workflow.
    • graphqurl is a simple tool that can be used to execute GraphQL queries and compare the results to known values.

Use the Enterprise Edition for local development if the other Hasura tiers are Enterprise Edition. Using this image is required to allow for the configuration of Hasura Enterprise features (i.e., read-replicas), so the Hasura CLI will include the configurations in the exported Metadata.

Patterns to avoid

  • Don't use the Console or API to export Metadata.

    • The Console and API export JSON files that are not as source-control friendly as YAML (exported by the CLI).
  • Don't use the Hasura GraphQL default Console as your development Console.

    • Changes made via the Hasura GraphQL default Console will not capture Metadata changes and can easily cause systems to be out of sync.
  • Don't rely on the local file system or the Hasura Metadata database as the source of truth for the Metadata configuration.

    • Local files can easily be unintentionally modified, corrupted, or lost.
    • You can unintentionally modify the Hasura Metadata database through misapplication of Metadata changes.
    • The Hasura Metadata database could be unintentionally lost if you accidentally delete the supporting database or persistent volume.
  • Don't manually deploy. While this will work in practice, it will quickly grow beyond a reasonable level of effort as the system's complexity and frequency of deployments increase.

  • Don't skip good regression testing as Metadata changes can easily change the fundamental way the Hasura GraphQL Engine operates. Queries you structure differently may return unexpected results. You could modify security policies such as RBAC permissions or allowed queries via Metadata changes that cause unexpected behavior.

  • Don't apply Metadata generated from the Community Edition to an Enterprise Edition system that has EE features configured (e.g., read-replicas). Hasura stores these configurations in the Metadata, and the Community Edition cannot configure these features. The resulting exported Metadata will not contain these values, and this Metadata would overwrite the Enterprise Edition configurations if you applied it.