mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-05 22:34:22 +03:00
Docs: Improve Creating Projects and Connecting Databases
[DOCS-425]: https://hasurahq.atlassian.net/browse/DOCS-425?atlOrigin=eyJpIjoiNWRkNTljNzYxNjVmNDY3MDlhMDU5Y2ZhYzA5YTRkZjUiLCJwIjoiZ2l0aHViLWNvbS1KU1cifQ PR-URL: https://github.com/hasura/graphql-engine-mono/pull/7609 Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> GitOrigin-RevId: 8a395448ae820ecde8d36115a4ed7f70d2dd491c
This commit is contained in:
parent
ab9c56b343
commit
5327fae8e4
@ -18,26 +18,96 @@ import Thumbnail from '@site/src/components/Thumbnail';
|
|||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
From `v2.0.0` onwards Hasura GraphQL Engine allows connecting to multiple databases and build a unified GraphQL API
|
You can quickly and easily connect a new, existing, or demo database to Hasura GraphQL Engine.
|
||||||
based on the database schemas.
|
|
||||||
|
|
||||||
## Connect a database {#connect-database-v2-0}
|
You can also connect to multiple databases and build a unified GraphQL API.
|
||||||
|
|
||||||
In versions `v2.0.0` and above, databases can be connected and removed dynamically without having to restart the GraphQL
|
## Connect a database via the Hasura Console {#connect-database-v2-0}
|
||||||
engine instance via the Console / Metadata APIs / CLI:
|
|
||||||
|
Once you have [created a Hasura Cloud Project](/projects/create.mdx), click `Launch Console` to open the Hasura
|
||||||
|
console in your browser.
|
||||||
|
|
||||||
|
<Thumbnail
|
||||||
|
src="/img/databases/project_launch-console_2-17-0.png"
|
||||||
|
alt="database setup with new database"
|
||||||
|
/>
|
||||||
|
|
||||||
|
On the Hasura Console, navigate to the `Data` tab, you will see the "Connect Database" screen.
|
||||||
|
|
||||||
|
<Thumbnail
|
||||||
|
src="/img/databases/databases_connect-database_2-17-0.png"
|
||||||
|
alt="database setup with new database"
|
||||||
|
/>
|
||||||
|
|
||||||
|
### Connect to or create a new database
|
||||||
|
|
||||||
|
Hasura Cloud does not host databases, but does provide integrations with which you can connect databases from
|
||||||
|
many 3rd party managed cloud providers. Check out a
|
||||||
|
[list of supported databases here](/databases/index.mdx#supported-databases).
|
||||||
|
|
||||||
|
To get started with a demo database, choose `Create New Database`:
|
||||||
|
|
||||||
|
<Thumbnail
|
||||||
|
src="/img/projects/create-database-neon-2.15.png"
|
||||||
|
alt="database setup with existing
|
||||||
|
database"
|
||||||
|
/>
|
||||||
|
|
||||||
|
Select `Create Neon Database` and follow the prompts or
|
||||||
|
[check out our detailed Neon connect page](/databases/connect-db/cloud-databases/neon.mdx). Hasura Cloud will
|
||||||
|
integrate with your Neon account and manage the initial setup of a Postgres instance. You can always upgrade the
|
||||||
|
instance and manage options later through your Neon account:
|
||||||
|
|
||||||
|
<Thumbnail
|
||||||
|
src="/img/projects/connect-database-neon-2.15.png"
|
||||||
|
alt="database setup with existing
|
||||||
|
database"
|
||||||
|
/>
|
||||||
|
|
||||||
|
### Connect to an existing database
|
||||||
|
|
||||||
|
To use an existing database, choose `Connect existing database` and enter your database connection URL and enter your
|
||||||
|
database connection string (looks like `postgres://username:password@hostname:port/dbname`).
|
||||||
|
|
||||||
|
For help finding your particular connection string for your database provider check out our
|
||||||
|
[supported databases](/databases/index.mdx#supported-databases) and
|
||||||
|
[cloud providers](/databases/connect-db/cloud-databases/index.mdx) pages.
|
||||||
|
|
||||||
|
<Thumbnail src="/img/projects/connect-database_console_2.15.png" alt="database setup with new database" />
|
||||||
|
|
||||||
|
You can connect to databases either using env vars or by using their raw connection string/parameters. It is
|
||||||
|
recommended to use env vars for better security _(as connection details are part of Hasura Metadata)_ as well as to
|
||||||
|
allow configuring different databases in different environments _(like staging/production)_ easily.
|
||||||
|
|
||||||
|
A database can be connected to using the `HASURA_GRAPHQL_DATABASE_URL` env var as well in which case it gets
|
||||||
|
added automatically as a database named `default`.
|
||||||
|
|
||||||
|
### Allowing connections from Hasura Cloud IP {#cloud-projects-create-allow-nat-ip}
|
||||||
|
|
||||||
|
For some cloud services, like GCP, you'll need to adjust your connection settings to allow connections from the
|
||||||
|
Hasura Cloud IP address. You can copy the IP address from the copy icon in the `Hasura Cloud IP` field on the Project's
|
||||||
|
details view which you can shortcut to by clicking on your Project name in the Console.
|
||||||
|
|
||||||
|
<Thumbnail src="/img/databases/cloud-console_shortcut-to-project-settings_2-17-0.png" alt="Hasura Cloud IP field" />
|
||||||
|
|
||||||
|
<Thumbnail src="/img/projects/project-general-ip-address_console_2.12.png" alt="Hasura Cloud IP field" />
|
||||||
|
|
||||||
|
Below is an example of adding the IP address of the Hasura Cloud instance to a GCP Cloud SQL instance.
|
||||||
|
|
||||||
|
<Thumbnail
|
||||||
|
src="/img/projects/gcp-postgres-authorized-network.png"
|
||||||
|
alt="whitelist Hasura instance IP in Postgres settings"
|
||||||
|
width="700px"
|
||||||
|
/>
|
||||||
|
|
||||||
|
## Connect a database via the Hasura CLI or API
|
||||||
|
|
||||||
<Tabs groupId="user-preference" className="api-tabs">
|
<Tabs groupId="user-preference" className="api-tabs">
|
||||||
<TabItem value="console" label="Console">
|
|
||||||
|
|
||||||
Head to `Data -> Manage -> Connect database`
|
|
||||||
|
|
||||||
<Thumbnail src="/img/databases/connect-db_step-1_console_2.10.1.png" alt="Connect default database" width="1000px" />
|
|
||||||
|
|
||||||
</TabItem>
|
|
||||||
<TabItem value="cli" label="CLI">
|
<TabItem value="cli" label="CLI">
|
||||||
|
|
||||||
In your `config v3` project, head to the `/metadata/databases/databases.yaml` file and add the database configuration as
|
In your `config v3` project, head to the `/metadata/databases/databases.yaml` file and add the database configuration as
|
||||||
below:
|
below. If you're using the HASURA_GRAPHQL_DATABASE_URL env var then the database will get automatically added and named
|
||||||
|
default.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: <db_name>
|
- name: <db_name>
|
||||||
@ -95,29 +165,28 @@ X-Hasura-Role: admin
|
|||||||
</TabItem>
|
</TabItem>
|
||||||
</Tabs>
|
</Tabs>
|
||||||
|
|
||||||
:::info Note
|
:::info On-the-fly connecting and removing of databases
|
||||||
|
|
||||||
- You can connect to databases either using env vars or by using their raw connection string/parameters. It is
|
In versions `v2.0.0` and above, databases can be connected and removed dynamically without having to restart the Hasura
|
||||||
recommended to use env vars for better security _(as connection details are part of Hasura Metadata)_ as well as to
|
Engine instance.
|
||||||
allow configuring different databases in different environments _(like staging/production)_ easily.
|
|
||||||
- A Postgres database can be connected using the `HASURA_GRAPHQL_DATABASE_URL` env var as well in which case it gets
|
|
||||||
added automatically as a database named `default`
|
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
:::info Create a new Postgres DB inside Hasura Cloud
|
## Connecting different Hasura instances to the same database
|
||||||
|
|
||||||
For a quick start with Hasura, you can also create a Postgres database with Neon from inside of Hasura Cloud. For more
|
You can connect different Hasura instances (i.e. instances with different Metadata) to the same database as long as
|
||||||
information, see
|
there are no [Event Triggers](/event-triggers/index.mdx) in any of the Metadata. Event Triggers store their data in the
|
||||||
[Connect new/existing database on Hasura Cloud](/getting-started/getting-started-cloud.mdx#create-new-db-with-cloud).
|
underlying database and hence different instances acting on the same data can cause undefined behavior during
|
||||||
|
run-time. This should not be a problem if the Hasura instances have the same Metadata.
|
||||||
|
|
||||||
:::
|
To connect multiple Hasura instances to the same database, simply follow the steps above for
|
||||||
|
[Connect to an existing database](#connect-to-an-existing-database) for each instance.
|
||||||
|
|
||||||
:::caution Connecting different Hasura instances to the same database
|
## Connecting to a database not exposed over the internet
|
||||||
|
|
||||||
You can connect different Hasura instances (i.e. instances with different metadata) to the same database as long as
|
[Contact us](https://hasura.io/contact-us/) for VPC peering and on-premise solutions.
|
||||||
there are no Event Triggers in any of the metadata. Event Triggers store their data in the underlying database and hence
|
|
||||||
different instances acting on the same data can cause undefined behavior during run-time. This should not be a problem
|
|
||||||
if the Hasura instances have the same metadata.
|
|
||||||
|
|
||||||
:::
|
## More databases
|
||||||
|
|
||||||
|
Support for more databases is coming soon. Stay up to date with
|
||||||
|
[supported databases here](/databases/index.mdx#supported-databases).
|
||||||
|
@ -33,6 +33,8 @@ Hasura GraphQL Engine supports:
|
|||||||
- [BigQuery](/databases/bigquery/index.mdx)
|
- [BigQuery](/databases/bigquery/index.mdx)
|
||||||
- **MySQL** (in preview) - See the [preview guide](/databases/mysql/getting-started.mdx)
|
- **MySQL** (in preview) - See the [preview guide](/databases/mysql/getting-started.mdx)
|
||||||
|
|
||||||
|
Hasura also [supports many other cloud database services](/databases/connect-db/cloud-databases/index.mdx).
|
||||||
|
|
||||||
:::tip Tip
|
:::tip Tip
|
||||||
|
|
||||||
Although it is safe to use Hasura with a serverless database, caution must be maintained because some functionalities -
|
Although it is safe to use Hasura with a serverless database, caution must be maintained because some functionalities -
|
||||||
|
@ -37,6 +37,8 @@ Hasura supports most databases with full Postgres compatibility such as:
|
|||||||
- [Neon](https://neon.tech/)
|
- [Neon](https://neon.tech/)
|
||||||
- [CosmosDB](https://azure.microsoft.com/en-gb/products/cosmos-db/)
|
- [CosmosDB](https://azure.microsoft.com/en-gb/products/cosmos-db/)
|
||||||
|
|
||||||
|
Hasura also [supports many other cloud database services](/databases/connect-db/cloud-databases/index.mdx).
|
||||||
|
|
||||||
Curious about any other Postgres flavours? Any other questions? Ask us on
|
Curious about any other Postgres flavours? Any other questions? Ask us on
|
||||||
[GitHub discussions](https://github.com/hasura/graphql-engine/discussions)
|
[GitHub discussions](https://github.com/hasura/graphql-engine/discussions)
|
||||||
|
|
||||||
|
@ -11,7 +11,6 @@ sidebar_label: Create Projects
|
|||||||
---
|
---
|
||||||
|
|
||||||
import Thumbnail from '@site/src/components/Thumbnail';
|
import Thumbnail from '@site/src/components/Thumbnail';
|
||||||
import HeadingIcon from '@site/src/components/HeadingIcon';
|
|
||||||
|
|
||||||
# Create Projects
|
# Create Projects
|
||||||
|
|
||||||
@ -19,12 +18,13 @@ import HeadingIcon from '@site/src/components/HeadingIcon';
|
|||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
You can create a new Hasura Cloud project with either a new Postgres database, or an existing Postgres database with a
|
You can create a new Hasura Cloud Project with either a new database, or an existing database with a publicly
|
||||||
publicly available IP address.
|
available IP address. For a list of supported databases and features [see here](/databases/index.mdx).
|
||||||
|
|
||||||
## Step 1: Project setup
|
## Project setup
|
||||||
|
|
||||||
To begin, navigate to the `Projects` page, and click the `New Project` link.
|
You can quickly and easily create a new Hasura Cloud Project. To begin, navigate to the
|
||||||
|
[Projects](https://cloud.hasura.io/projects) page on Hasura Cloud and click the "New Project" link.
|
||||||
|
|
||||||
This opens a form on the right where you can create your new project.
|
This opens a form on the right where you can create your new project.
|
||||||
|
|
||||||
@ -40,86 +40,7 @@ Once you have completed the project setup, click `Create Project`.
|
|||||||
|
|
||||||
Once created, you can specify a new name for your Project if you want.
|
Once created, you can specify a new name for your Project if you want.
|
||||||
|
|
||||||
## Step 2: Database setup {#cloud-projects-db-setup}
|
## Connect to a database
|
||||||
|
|
||||||
Click `Launch Console` to open the Hasura console in your browser.
|
Once your project is created you can connect to a new or existing database. For full details on how to connect to a
|
||||||
|
database, see [connecting to a database here](/databases/connect-db/index.mdx).
|
||||||
<Thumbnail
|
|
||||||
src="/img/projects/create-project-assign-name_console_2.12.png"
|
|
||||||
alt="database setup with new database"
|
|
||||||
width="900px"
|
|
||||||
/>
|
|
||||||
|
|
||||||
On the Hasura Console, navigate to `Data -> Manage -> Connect Database`:
|
|
||||||
|
|
||||||
### Connect or create a new database
|
|
||||||
|
|
||||||
Hasura Cloud does not host databases, but does provide integrations with which you can connect databases including from
|
|
||||||
many 3rd party managed cloud providers. Check out a
|
|
||||||
[list of supported databases here](/databases/index.mdx#supported-databases).
|
|
||||||
|
|
||||||
To get started with a demo database, choose `Create New Database`:
|
|
||||||
|
|
||||||
<Thumbnail
|
|
||||||
src="/img/projects/create-database-neon-2.15.png"
|
|
||||||
alt="database setup with existing
|
|
||||||
database"
|
|
||||||
width="700px"
|
|
||||||
/>
|
|
||||||
|
|
||||||
Select `Create Neon Database` and follow the prompts. Hasura Cloud will integrate with your Neon account and manage the
|
|
||||||
initial setup of a Postgres instance. You can always upgrade the instance and manage options later through your Neon
|
|
||||||
account:
|
|
||||||
|
|
||||||
<Thumbnail
|
|
||||||
src="/img/projects/connect-database-neon-2.15.png"
|
|
||||||
alt="database setup with existing
|
|
||||||
database"
|
|
||||||
width="700px"
|
|
||||||
/>
|
|
||||||
|
|
||||||
### Existing database
|
|
||||||
|
|
||||||
To use an existing database, choose `Connect existing database` and enter your database connection URL and enter your
|
|
||||||
database connection string (looks like `postgres://username:password@hostname:port/dbname`).
|
|
||||||
|
|
||||||
<Thumbnail src="/img/projects/connect-database_console_2.15.png" alt="database setup with new database" width="700px" />
|
|
||||||
|
|
||||||
:::info
|
|
||||||
|
|
||||||
Note You can connect to databases either using env vars or by using their raw connection string/parameters. It is
|
|
||||||
recommended to use env vars for better security _(as connection details are part of Hasura Metadata)_ as well as to
|
|
||||||
allow configuring different databases in different environments _(like staging/production)_ easily.
|
|
||||||
|
|
||||||
:::
|
|
||||||
|
|
||||||
### Allowing connections from Hasura Cloud IP {#cloud-projects-create-allow-nat-ip}
|
|
||||||
|
|
||||||
For some cloud services, like GCP, you'll need to adjust your Postgres connection settings to allow connections from the
|
|
||||||
Hasura Cloud IP address. You can copy the IP address from the copy icon in the `Hasura Cloud IP` field on the project's
|
|
||||||
details view.
|
|
||||||
|
|
||||||
<Thumbnail src="/img/projects/project-general-ip-address_console_2.12.png" alt="Hasura Cloud IP field" width="1000px" />
|
|
||||||
|
|
||||||
<Thumbnail
|
|
||||||
src="/img/projects/gcp-postgres-authorized-network.png"
|
|
||||||
alt="whitelist Hasura instance IP in Postgres settings"
|
|
||||||
width="727px"
|
|
||||||
/>
|
|
||||||
|
|
||||||
## Postgres requirements
|
|
||||||
|
|
||||||
Hasura GraphQL Engine supports all supported versions of Postgres per the
|
|
||||||
[public documentation](https://www.postgresql.org/support/versioning/).
|
|
||||||
|
|
||||||
Make sure your database user has the right
|
|
||||||
[Postgres permissions](/deployment/postgres-requirements.mdx#managed-pg-permissions).
|
|
||||||
|
|
||||||
## Connecting to a database not exposed over the internet
|
|
||||||
|
|
||||||
[Contact us](https://hasura.io/contact-us/) for VPC peering and on-premise solutions.
|
|
||||||
|
|
||||||
## More databases
|
|
||||||
|
|
||||||
Support for more databases is coming soon. Stay up to date with
|
|
||||||
[supported databases here](/databases/index.mdx#supported-databases).
|
|
BIN
docs/static/img/databases/cloud-console_shortcut-to-project-settings_2-17-0.png
vendored
Normal file
BIN
docs/static/img/databases/cloud-console_shortcut-to-project-settings_2-17-0.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 15 KiB |
BIN
docs/static/img/databases/databases_connect-database_2-17-0.png
vendored
Normal file
BIN
docs/static/img/databases/databases_connect-database_2-17-0.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 53 KiB |
BIN
docs/static/img/databases/project_launch-console_2-17-0.png
vendored
Normal file
BIN
docs/static/img/databases/project_launch-console_2-17-0.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 121 KiB |
Binary file not shown.
Before Width: | Height: | Size: 202 KiB After Width: | Height: | Size: 121 KiB |
Loading…
Reference in New Issue
Block a user