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:
Sean Park-Ross 2023-01-26 11:44:04 +02:00 committed by hasura-bot
parent ab9c56b343
commit 5327fae8e4
8 changed files with 111 additions and 117 deletions

View File

@ -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).

View File

@ -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 -

View File

@ -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)

View File

@ -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).

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 53 KiB

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