diff --git a/website/docs/docs/cloud/secure/postgres-privatelink.md b/website/docs/docs/cloud/secure/postgres-privatelink.md index 58098f4c23a..864cfe4acba 100644 --- a/website/docs/docs/cloud/secure/postgres-privatelink.md +++ b/website/docs/docs/cloud/secure/postgres-privatelink.md @@ -5,6 +5,7 @@ description: "Configuring PrivateLink for Postgres" sidebar_label: "PrivateLink for Postgres" --- import SetUpPages from '/snippets/_available-tiers-privatelink.md'; +import PrivateLinkTroubleshooting from '/snippets/_privatelink-troubleshooting.md'; @@ -86,3 +87,5 @@ Once dbt Cloud support completes the configuration, you can start creating new c 3. Select the private endpoint from the dropdown (this will automatically populate the hostname/account field). 4. Configure the remaining data platform details. 5. Test your connection and save it. + + \ No newline at end of file diff --git a/website/docs/docs/cloud/secure/redshift-privatelink.md b/website/docs/docs/cloud/secure/redshift-privatelink.md index 23e2b4382fc..a9d4332918b 100644 --- a/website/docs/docs/cloud/secure/redshift-privatelink.md +++ b/website/docs/docs/cloud/secure/redshift-privatelink.md @@ -6,6 +6,7 @@ sidebar_label: "PrivateLink for Redshift" --- import SetUpPages from '/snippets/_available-tiers-privatelink.md'; +import PrivateLinkTroubleshooting from '/snippets/_privatelink-troubleshooting.md'; @@ -115,3 +116,5 @@ Once dbt Cloud support completes the configuration, you can start creating new c 3. Select the private endpoint from the dropdown (this will automatically populate the hostname/account field). 4. Configure the remaining data platform details. 5. Test your connection and save it. + + \ No newline at end of file diff --git a/website/docs/docs/cloud/secure/vcs-privatelink.md b/website/docs/docs/cloud/secure/vcs-privatelink.md index b08154d2e72..6041b1cb4ed 100644 --- a/website/docs/docs/cloud/secure/vcs-privatelink.md +++ b/website/docs/docs/cloud/secure/vcs-privatelink.md @@ -6,6 +6,7 @@ sidebar_label: "PrivateLink for VCS" --- import SetUpPages from '/snippets/_available-tiers-privatelink.md'; +import PrivateLinkTroubleshooting from '/snippets/_privatelink-troubleshooting.md'; @@ -106,3 +107,5 @@ Once dbt confirms that the PrivateLink integration is complete, you can use it i + + \ No newline at end of file diff --git a/website/mgb-sfpl.json b/website/mgb-sfpl.json new file mode 100644 index 00000000000..213845e1f6d --- /dev/null +++ b/website/mgb-sfpl.json @@ -0,0 +1,98 @@ +[ + { + "host": "jd43444.east-us-2.privatelink.snowflakecomputing.com", + "port": 443, + "type": "SNOWFLAKE_DEPLOYMENT" + }, + { + "host": "mgb-mgbdev.privatelink.snowflakecomputing.com", + "port": 443, + "type": "SNOWFLAKE_DEPLOYMENT_REGIONLESS" + }, + { + "host": "r3iqwjsfcb1stg.blob.core.windows.net", + "port": 443, + "type": "STAGE" + }, + { + "host": "sfc-repo.snowflakecomputing.com", + "port": 443, + "type": "SNOWSQL_REPO" + }, + { + "host": "client-telemetry.snowflakecomputing.com", + "port": 443, + "type": "OUT_OF_BAND_TELEMETRY" + }, + { + "host": "app-mgb-mgbdevenv.privatelink.snowflakecomputing.com", + "port": 443, + "type": "SNOWSIGHT_CLIENT_FAILOVER" + }, + { + "host": "mgb-mgbdevenv.privatelink.snowflakecomputing.com", + "port": 443, + "type": "CLIENT_FAILOVER" + }, + { + "host": "ocsp.mgb-mgbdevenv.privatelink.snowflakecomputing.com", + "port": 80, + "type": "OCSP_CLIENT_FAILOVER" + }, + { + "host": "ocsp.app-mgb-mgbdevenv.privatelink.snowflakecomputing.com", + "port": 80, + "type": "OCSP_CLIENT_FAILOVER" + }, + { + "host": "ocsp.jd43444.east-us-2.privatelink.snowflakecomputing.com", + "port": 80, + "type": "OCSP_CACHE" + }, + { + "host": "ocsp.mgb-mgbdev.privatelink.snowflakecomputing.com", + "port": 80, + "type": "OCSP_CACHE_REGIONLESS" + }, + { + "host": "api-73a252bb.duosecurity.com", + "port": 443, + "type": "DUO_SECURITY" + }, + { + "host": "app-mgb-mgbdev.privatelink.snowflakecomputing.com", + "port": 443, + "type": "SNOWSIGHT_DEPLOYMENT_REGIONLESS" + }, + { + "host": "app.east-us-2.privatelink.snowflakecomputing.com", + "port": 443, + "type": "SNOWSIGHT_DEPLOYMENT" + } +] + +# Current +{ + "regionless-snowsight-privatelink-url": "app-mgb-mgbdev.privatelink.snowflakecomputing.com", + "privatelink-account-name": "jd43444.east-us-2.privatelink", + "snowsight-privatelink-url": "app.east-us-2.privatelink.snowflakecomputing.com", + "regionless-privatelink-ocsp-url": "ocsp.mgb-mgbdev.privatelink.snowflakecomputing.com", + "privatelink-account-url": "jd43444.east-us-2.privatelink.snowflakecomputing.com", + "privatelink-connection-ocsp-urls": "[ocsp.mgb-mgbdevenv.privatelink.snowflakecomputing.com, ocsp.app-mgb-mgbdevenv.privatelink.snowflakecomputing.com]", + "privatelink-pls-id": "sf-pvlinksvc-azeastus2.cf82bce2-be9d-4dc6-92ee-3de5fb04d191.eastus2.azure.privatelinkservice", + "regionless-privatelink-account-url": "mgb-mgbdev.privatelink.snowflakecomputing.com", + "privatelink_ocsp-url": "ocsp.jd43444.east-us-2.privatelink.snowflakecomputing.com", + "privatelink-connection-urls": "[mgb-mgbdevenv.privatelink.snowflakecomputing.com, app-mgb-mgbdevenv.privatelink.snowflakecomputing.com]" +} + +# Received from customer 02/2023 +{ + "regionless-snowsight-privatelink-url": "app-mgb-mgbdev.privatelink.snowflakecomputing.com", + "privatelink-account-name": "jd43444.east-us-2.privatelink", + "snowsight-privatelink-url": "app.east-us-2.privatelink.snowflakecomputing.com", + "privatelink-account-url": "jd43444.east-us-2.privatelink.snowflakecomputing.com", + "privatelink-pls-id": "sf-pvlinksvc-azeastus2.cf82bce2-be9d-4dc6-92ee-3de5fb04d191.eastus2.azure.privatelinkservice", + "regionless-privatelink-account-url": "mgb-mgbdev.privatelink.snowflakecomputing.com", + "privatelink_ocsp-url": "ocsp.jd43444.east-us-2.privatelink.snowflakecomputing.com", + "privatelink-connection-urls": "[CLIENT_FAILOVER,mgb-mgbdevenv.privatelink.snowflakecomputing.com]" +} \ No newline at end of file diff --git a/website/snippets/_privatelink-troubleshooting.md b/website/snippets/_privatelink-troubleshooting.md new file mode 100644 index 00000000000..6db6e313e95 --- /dev/null +++ b/website/snippets/_privatelink-troubleshooting.md @@ -0,0 +1,54 @@ +## Troubleshooting + +If the PrivateLink endpoint has been provisioned and configured in dbt Cloud, but connectivity is still failing, check the following in your networking setup to ensure requests and responses can be successfully routed between dbt Cloud and the backing service. + +### Configuration + +Start with the configuration: + + + +The Network Load Balancer (NLB) associated with the VPC Endpoint Service must either not have an associated Security Group or the Security Group must have a rule that allows requests from the appropriate dbt Cloud _private CIDR(s)_. Note that this differs from the static public IPs listed on the dbt Cloud Connection page. dbt Support can provide the correct private CIDR(s) upon request. + - **Note***: To test if this is the issue, temporarily adding an allow rule of `10.0.0.0/8` should allow connectivity until the rule can be refined to a smaller CIDR + + + + + +Check that there is a Listener connected to the NLB that matches the port that dbt Cloud is trying to connect to. This Listener must have a configured action to forward to a Target Group with targets that point to your backing service. At least one (but preferably all) of these targets must be **Healthy**. Unhealthy targets could suggest that the backing service is, in fact, unhealthy or that the service is protected by a Security Group that doesn't allow requests from the NLB. + + + + + +Check that _Cross-zone load balancing_ is enabled for your NLB (check the **Attributes** tab of the NLB in the AWS console). If this is disabled, and the zones that dbt Cloud is connected to are misaligned with the zones where the service is running, requests may not be able to be routed correctly. Enabling cross-zone load balancing will also make the connection more resilient in the case of a failover in a zone outage scenario. Cross-zone connectivity may incur additional data transfer charges, though this should be minimal for requests from dbt Cloud. + + + + + +If all the above check out, it may be possible that requests are not routing correctly within the private network. This could be due to a misconfiguration in the VPCs routing tables or access control lists. Review these settings with your network administrator to ensure that requests can be routed from the VPC Endpoint Service to the backing service and that the response can be returned to the VPC Endpoint Service. One way to test this is to create a VPC endpoint in another VPC in your network to test that connectivity is working independent of dbt's connection. + + + +### Monitoring + +To help isolate connection issues over a PrivateLink connection from dbt Cloud, there are a few monitoring sources that can be used to verify request activity. Requests must first be sent to the endpoint to see anything in the monitoring. Contact dbt Support to understand when connection testing occurred or request new connection attempts. Use these times to correlate with activity in the following monitoring sources. + + + +In the AWS Console, navigate to VPC -> Endpoint Services. Select the Endpoint Service being tested and click the **Monitoring** tab. Update the time selection to include when test connection attempts were sent. If there is activity in the _New connections_ and _Bytes processed_ graphs, then requests have been received by the Endpoint Service, suggesting that the dbt endpoint is routing properly. + + + + + +In the AWS Console, navigate to EC2 -> Load Balancers. Select the Network Load Balancer (NLB) being tested and click the **Monitoring** tab. Update the time selection to include when test connection attempts were sent. If there is activity in the _New flow count_ and _Processed bytes_ graphs, then requests have been received by the NLB from the Endpoint Service, suggesting the NLB Listener, Target Group, and Security Group are correctly configured. + + + + + +VPC Flow Logs can provide various helpful information for requests being routed through your VPCs, though they can sometimes be challenging to locate and interpret. Flow logs can be written to either S3 or CloudWatch Logs, so determine the availability of these logs for your VPC and query them accordingly. Flow logs record the Elastic Network Interface (ENI) ID, source and destination IP and port, and whether the request was accepted or rejected by the security group and/or network ACL. This can be useful in understanding if a request arrived at a certain network interface and whether that request was accepted, potentially illuminating overly restrictive rules. For more information on accessing and interpreting VPC Flow Logs, see the related [AWS documentation](https://docs.aws.amazon.com/vpc/latest/userguide/flow-logs.html). + + \ No newline at end of file