From ca47e46a83f1a8129632e02596b05326320e9dce Mon Sep 17 00:00:00 2001
From: Ankur Datta <64993082+ankur-arch@users.noreply.github.com>
Date: Thu, 21 Mar 2024 21:00:31 +0600
Subject: [PATCH] feat: add troubleshooting guide for accelerate (#5731)
* feat: add troubleshooting guide for accelerate
* enhance: enhance the troubleshooting guide
* fix refine indentation
---
.../500-reference/250-error-reference.mdx | 6 +
content/300-accelerate/500-limitations.mdx | 4 +
content/300-accelerate/650-troubleshoot.mdx | 127 ++++++++++++++++++
3 files changed, 137 insertions(+)
create mode 100644 content/300-accelerate/650-troubleshoot.mdx
diff --git a/content/200-orm/500-reference/250-error-reference.mdx b/content/200-orm/500-reference/250-error-reference.mdx
index 65c4ef5499..ff968a5a33 100644
--- a/content/200-orm/500-reference/250-error-reference.mdx
+++ b/content/200-orm/500-reference/250-error-reference.mdx
@@ -474,6 +474,8 @@ The included usage of the current plan has been exceeded. This can only occur on
The global timeout of Accelerate has been exceeded. You can find the limit [here](/accelerate/limitations#query-timeout-limit).
+> Also see the [troubleshooting guide](/accelerate/troubleshoot#p6004-querytimeout) for more information.
+
#### P6005 (InvalidParameters)
The user supplied invalid parameters. Currently only relevant for transaction methods. For example, setting a timeout that is too high. You can find the limit [here](/accelerate/limitations#interactive-transactions-query-timeout-limit).
@@ -486,10 +488,14 @@ The chosen Prisma version is not compatible with Accelerate. This may occur when
The engine failed to start. For example, it couldn't establish a connection to the database.
+> Also see the [troubleshooting guide](/accelerate/troubleshoot#p6008-connectionerrorenginestarterror) for more information.
+
#### P6009 (ResponseSizeLimitExceeded)
The global response size limit of Accelerate has been exceeded. You can find the limit [here](/accelerate/limitations#response-size-limit).
+> Also see the [troubleshooting guide](/accelerate/troubleshoot#p6009-responsesizelimitexceeded) for more information.
+
### Prisma Pulse
Prisma Pulse-related errors start with P61xx.
diff --git a/content/300-accelerate/500-limitations.mdx b/content/300-accelerate/500-limitations.mdx
index dec1b870a6..e0921d4473 100644
--- a/content/300-accelerate/500-limitations.mdx
+++ b/content/300-accelerate/500-limitations.mdx
@@ -16,6 +16,8 @@ Below are descriptions of known limitations when using Accelerate. If you are aw
Accelerate has a global timeout of `10s` for each query. Reach out to [support@prisma.io](mailto:support@prisma.io) with your use case if your application requires a greater timeout value.
+> Also see the [troubleshooting guide](/accelerate/troubleshoot#p6004-querytimeout) for more information.
+
## Interactive transactions query timeout limit
Accelerate has a global timeout of `15s` for each [interactive transaction](/orm/prisma-client/queries/transactions#interactive-transactions). Reach out to [support@prisma.io](mailto:support@prisma.io) with your use case if your application requires a greater timeout value.
@@ -24,6 +26,8 @@ Accelerate has a global timeout of `15s` for each [interactive transaction](/orm
Accelerate has a global response size limit of `5MB`. Reach out to [support@prisma.io](mailto:support@prisma.io) with your use case if your application requires a larger response size.
+> Also see the [troubleshooting guide](/accelerate/troubleshoot#p6009-responsesizelimitexceeded) for more information.
+
## Cannot cache raw queries
At the moment, it is not possible to cache the responses of [raw queries](/orm/prisma-client/queries/raw-database-access/raw-queries).
diff --git a/content/300-accelerate/650-troubleshoot.mdx b/content/300-accelerate/650-troubleshoot.mdx
new file mode 100644
index 0000000000..77034f6cec
--- /dev/null
+++ b/content/300-accelerate/650-troubleshoot.mdx
@@ -0,0 +1,127 @@
+---
+title: 'Troubleshooting Guide'
+metaTitle: 'Troubleshooting: Prisma Accelerate'
+metaDescription: 'Troubleshooting Prisma Accelerate.'
+tocDepth: 3
+toc: true
+---
+
+
+
+When working with Prisma Accelerate, you may encounter errors often highlighted by specific error codes during development and operations. It is important to understand the meaning of these errors, why they occur, and how to resolve them in order to ensure the smooth operation of your applications. This guide aims to provide insights and steps to troubleshoot specific error codes encountered with Prisma Accelerate.
+
+
+
+## [P6009](/orm/reference/error-reference#p6009-responsesizelimitexceeded) (ResponseSizeLimitExceeded)
+
+This error is triggered when the response size from a database query exceeds the 5MB limit. We've implemented this restriction to safeguard your application performance, as retrieving data over 5MB can significantly slow down your application due to multiple network layers. Typically, transmitting more than 5MB of data is common when conducting ETL (Extract, Transform, Load) operations. However, for other scenarios such as transactional queries, real-time data fetching for user interfaces, bulk data updates, or aggregating large datasets for analytics outside of ETL contexts, it should generally be avoided. These use cases, while essential, can often be optimised to work within the 5MB limit, ensuring smoother performance and a better user experience.
+
+### Possible causes for [P6009](/orm/reference/error-reference#p6009-responsesizelimitexceeded)
+
+#### Transmitting images/files in response
+
+This error may arise if images or files stored within your table are being fetched, resulting in a large response size. Storing assets directly in the database is generally discouraged because it significantly impacts database performance and scalability. In addition to performance, it makes database backups slow and significantly increases the cost of storing routine backups.
+
+**Suggested solution:** Store the image/file in a BLOB store like [Cloudflare R2](https://developers.cloudflare.com/r2/), [AWS S3](https://aws.amazon.com/pm/serv-s3/), [Cloudinary](https://cloudinary.com/), etc. These services would allow you to store the assets optimally and return a URL through which you should be able to access the asset. You can store this URL in your table instead of storing the asset directly in database. This would substantially reduce the size of your response.
+
+#### Overfetching of data
+
+In certain cases, a large number of records or fields are unintentionally fetched, which results in exceeding the 5MB limit. This could happen when the [`where`](/orm/reference/prisma-client-reference#where) clause in the query is incorrect or entirely missing.
+
+**Suggested solution:** Double-check if the `where` clause is filtering the data as you expect. Consider using [pagination](/orm/prisma-client/queries/pagination) to prevent a large number of records from being fetched. Additionally, use the [`select`](/orm/reference/prisma-client-reference#select) clause to return only the fields that are being consumed to further reduce the response size.
+
+#### Fetching a large volume of data
+
+In many data processing workflows, especially those involving ETL (Extract-Transform-Load) processes or scheduled CRON jobs, there's a need to extract large amounts of data from data sources (like databases, APIs, or file systems) for analysis, reporting, or further processing. If you are running an ETL/CRON workload that fetches a huge chunk of data for analytical processing then you might run into this limit.
+
+**Suggested solution:** Consider splitting your query to fetch data in batches to prevent the 5MB limit from being reached. By splitting your query to retrieve data in batches, you ensure that each operation fetches only a portion of the total data volume, thereby not exceeding the size limit for a single fetch operation.
+
+## [P6004](/orm/reference/error-reference#p6004-querytimeout) (QueryTimeout)
+
+This error occurs when a database query fails to return a response within 10 seconds. The 10-second limit includes the duration of waiting for a connection from the pool, network latency to the database, and the execution time of the query itself. We enforce this limit to prevent unintentional long-running queries that can overload system resources.
+
+> The time for Accelerate's cross-region networking is excluded from the 10-second limit.
+
+### Possible causes for [P6004](/orm/reference/error-reference#p6004-querytimeout)
+
+This error could be caused by numerous reasons. Some of the prominent ones are:
+
+#### High traffic and insufficient connections
+
+If the application is receiving very high traffic and there are not a sufficient number of connections available to the database, then the queries would need to wait for a connection to become available. This situation can lead to queries waiting longer than 10 seconds for a connection, ultimately triggering a timeout error if they do not get serviced within this duration.
+
+**Suggested solution**: Review and possibly increase the `connection_limit` specified in the connection string parameter when setting up Accelerate in a platform environment ([reference](/accelerate/connection-pooling#configuring-the-connection-pool-size)).
+This limit should align with your database's maximum number of connections.
+
+By default, the connection limit is set to 10 unless a
+different `connection_limit` is specified in your database connection string.
+
+#### Long-running queries
+
+Queries may be slow to respond, hitting the 10-second timeout even when connections are available. This could happen if a very large amount of data is being fetched in a single query or if appropriate indexes are missing from the table.
+
+**Suggested solution**: Identify the slow-running queries and fetch only the required data. If you only need to use specific fields from the table, then you can use the select clause in your queries to prevent unnecessary data from being fetched. Additionally, you could consider adding appropriate indexes based on the query to ensure that data is fetched efficiently.
+You can also consider isolating long running queries into separate environments, so that these long running queries would not affect the transactional queries.
+
+#### Database resource contention
+
+A common yet challenging issue is when other services operating on the same database perform heavy analytics or data processing tasks, significantly consuming database resources. These operations can monopolize database connections and processing power, leading to a scenario where even simple queries cannot be executed in a timely manner. This "busy" or "noisy" database environment can cause queries that are typically fast to run slowly or even timeout, particularly during periods of high activity from other services.
+
+Users often rely on CPU and memory usage metrics to gauge database load, which can be misleading. While these are important indicators, they might not fully represent the database's operational state. Direct metrics like the number of reads, writes, and wait times offer a clearer view of the database's performance and should be monitored closely. A noticeable degradation in these metrics, especially in the absence of changes to the queries or data model, suggests that external pressures are affecting database performance.
+
+**Suggestion solution**: If normally quick queries are intermittently slow or timing out without any modifications to them, it's probable that competing queries are exerting pressure on the same database tables. To diagnose this, adopt monitoring tools or leverage your database's inherent capabilities to observe reads, writes, and wait times. Such monitoring will unveil activity patterns or spikes that align with the observed performance dips.
+
+Moreover, it's crucial to periodically scrutinize and refine essential queries and verify that tables are properly indexed. This proactive approach minimizes the vulnerability of these queries to slowdowns caused by competing workloads.
+
+### Considerations for [P6009](/orm/reference/error-reference#p6009-responsesizelimitexceeded) and [P6004](/orm/reference/error-reference#p6004-querytimeout) errors
+
+For runtimes that support Prisma ORM natively, you could consider creating two `PrismaClient` Instances. One with the Accelerate connection string (prefixed with `prisma://`) and the other one with the direct database connection string (prefixed with `postgres://`, `mysql://` etc). The main idea behind this approach is to bypass Accelerate for certain specific queries.
+
+However, please note that the available connections would be split between both of your `PrismaClient` Instances. It's crucial to understand the implications of managing multiple instances, particularly in regards to direct database connections. Utilizing a `PrismaClient` instance with a direct database connection string means that this connection will interact directly with your database.
+
+This approach requires careful consideration because the direct connections and those managed by Accelerate share the same underlying database connection pool. This can lead to competition for resources, potentially affecting the performance and availability of your database services.
+
+Additionally, direct connections could have a significant impact on your database's performance and availability. Operations that consume a considerable amount of resources could potentially degrade the service for other users or processes that rely on the same database.
+
+If your application's runtime environment supports Prisma ORM natively and you're considering this strategy to circumvent P6009 and P6004 errors, you might create two `PrismaClient` instances:
+
+1. An instance using the Accelerate connection string (prefixed with `prisma://`) for general operations.
+2. Another instance with the direct database connection string (e.g., prefixed with `postgres://`, `mysql://`, etc.) for specific operations anticipated to exceed 10 seconds in execution time or to result in responses larger than 5MB.
+
+```jsx
+export const prisma = new PrismaClient({
+ datasourceUrl: process.env.DIRECT_DB_CONNECTION,
+})
+
+export const prismaAccelerate = new PrismaClient({
+ datasourceUrl: process.env.ACCELERATE_CONNECTION,
+}).$extends(withAccelerate())
+```
+
+This setup allows you to strategically direct certain operations through the direct connection, mitigating the risk of encountering the aforementioned errors. However, this decision should be made with a comprehensive understanding of the potential consequences and an assessment of whether your database infrastructure can support this additional load without compromising overall performance and availability.
+
+> Also see [**why doesn’t Accelerate fall back to the direct connection string during a service disruption?**](/accelerate/faq#why-doesnt-accelerate-fall-back-to-the-direct-connection-string-during-a-service-disruption)
+
+## [P6008](/orm/reference/error-reference#p6008-connectionerrorenginestarterror) (ConnectionError|EngineStartError)
+
+This error indicates that Prisma Accelerate cannot establish a connection to your database, potentially due to several reasons.
+
+### Possible causes for [P6008](/orm/reference/error-reference#p6008-connectionerrorenginestarterror)
+
+#### Database Not Publicly accessible
+
+Prisma Accelerate currently requires the database to be publicly accessible. If your database is behind a VPC, or access is restricted to specific IP addresses, this error may occur.
+
+**Suggested solution:** Ensure your database is publicly accessible, if not, allow public access. Please note this is only an interim requirement, Static IPs are coming soon and will alleviate the need for complete public access if that’s not desirable.
+
+#### Unreachable Database Host/Port
+
+If the database’s server address (hostname) and port are incorrect or unreachable then you may encounter this error.
+
+**Suggested solution:** Verify the hostname/port of the database connection string that was provided while creating the Prisma Accelerate project. Additionally, attempt to connect to the database using a Database GUI tool (e.g., [Prisma Studio](https://www.prisma.io/studio), [TablePlus](https://tableplus.com/), or [DataGrip](https://www.jetbrains.com/datagrip/)) for further investigation.
+
+#### Incorrect username/password/database name
+
+This error can happen when the wrong credentials are provided to Prisma Accelerate, preventing it from establishing a connection to your database.
+
+**Suggested solution:** Verify the correctness of your database's username, password, and name in the connection string provided to Prisma Accelerate. Ensure that these credentials match those required by your database. Testing the connection using a direct database GUI tool can also help in confirming if the provided credentials are correct.