Diagnose issues (original) (raw)

This page contains a list of the most frequent issues you might run into when working with Cloud SQL instances and steps you can take to address them. Also review theKnown issues,Troubleshooting, andSupport page pages.

View logs

To see information about recent operations, you can view theCloud SQL instance operation logsor the MySQL error logs.

Instance unresponsive

If your instance stops responding to connections or performance is degraded, make sure it conforms to the Operational Guidelines. If it does not conform to these guidelines, it is not covered by the Cloud SQL SLA.

Connection issues

See the Debugging connection issues page or the Connectivity section in the troubleshooting page for help with connection problems.

Instance issues

Backups

For the best performance forbackups, keep the number of tables to a reasonable number.

For other backups issues, see the Backups section in the troubleshooting page.

Import and export

Imports and exports in Cloud SQL are the same as using the mysqldump utility, except that with the Cloud SQL import/export feature, you transfer data using a Cloud Storage bucket.

Imports into Cloud SQL and exports out of Cloud SQL can take a long time to complete, depending on the size of the data being processed. This can have the following impacts:

You can decrease the amount of time it takes to complete each operation by using the Cloud SQL import or export functionality with smaller batches of data.

For exports, you can perform the export from a read replica or useserverless export to minimize the impact on database performance and allow other operations to run on your instance while an export is running.

Other points to keep in mind when importing:

For other import and export issues, see the Import and export section in the troubleshooting page.

Disk space

If your instance reaches the maximum storage amount allowed, writes to the database fail. If you delete data, for example, by dropping a table, the space freed is not reflected in the reportedStorage Used of the instance. See the FAQHow can I reclaim the space from a dropped table?for an explanation of this behavior.

Reaching the maximum storage limit can also cause the instance to get stuck in restart.

Avoid data corruption

Avoid generated columns

Due to an issue in MySQL, using generated columns might result in data corruption. For more information, seeMySQL bug #82736.

Clean shutdowns

When Cloud SQL shuts down an instance (e.g, for maintenance), no new connections are sent to the instance and existing connections are ended. The amount of time mysqld has to shutdown is capped to 1 minute. If the shutdown does not complete in that time, the mysqld process is forcefully stopped. This can result in disk writes being aborted mid-way through.

Database engines

InnoDB is the only supported storage engine for MySQL instances because it is more resistant to table corruption than other MySQL storage engines, such asMyISAM.

By default, Cloud SQL database tables are created using the InnoDB storage engine. If your CREATE TABLE syntax includes an ENGINEoption specifying a storage engine other than InnoDB, for exampleENGINE = MyISAM, the table is not created and you see error messages like the following example:

ERROR 3161 (HY000): Storage engine MyISAM is disabled (Table creation is disallowed).

You can avoid this error by removing the ENGINE = MyISAM option from theCREATE TABLE command. Doing so creates the table with the InnoDB storage engine.

Changes to system tables

MySQL system tables use the MyISAM storage engine, including all tables in themysql database, for example mysql.user and mysql.db. These tables are vulnerable to unclean shutdowns; issue the FLUSH CHANGES command after making changes to these tables. If MyISAM corruption does occur, CHECK TABLE and REPAIR TABLE can get you back to good state (but not save data).

Global Transaction Identifiers (GTID)

All MySQL instances have GTID enabled automatically. Having GTID enabled protects against data loss during replica creation and failover, and makes replication more robust. However, GTID comes with some limitations imposed by MySQL, as documented in theMySQL manual. The following transactionally unsafe operations cannot be used with a GTID-enabled MySQL server:

If you use a transactionally unsafe transaction, you see an error message like the following example:

 Exception: SQLSTATE[HY000]: General error: 1786
 CREATE TABLE ... SELECT is forbidden when @@GLOBAL.ENFORCE_GTID_CONSISTENCY = 1.

Work with triggers and stored functions

If your instance has binary logging enabled, and you need to work with triggers or stored functions, make sure your instance has thelog_bin_trust_function_creatorsflag set to on.

Suspended state

There are various reasons why Cloud SQL may suspend an instance, including:

While an instance is suspended, you can continue to view information about it or you can delete it, if billing issues triggered the suspension.

Cloud SQL users with Platinum, Gold, or Silversupport packages can contact our support team directly about suspended instances. All users can use the earlier guidance along with thegoogle-cloud-sqlforum.

Performance

Overview

Cloud SQL supports performance-intensive workloads with up to 60,000 IOPS and no extra cost for I/O. IOPS and throughput performance depends on disk size, instance vCPU count, and I/O block size, among other factors.

Your instance's performance also depends on yourchoice of storage type and workload.

Learn more about:

Enable query logs

To tune the performance of your queries, you can configure Cloud SQL to log slow queries byadding the database flags --log_output='FILE' and --slow_query_log=on to your instance. This makes the log output available using theLogs Viewer in the Google Cloud console. Note that Google Cloud Observability logging charges apply.

Do not set log_output to TABLE. Doing so can cause connection issues as described inTips for working with flags.

You can refer to this tutorialfor instructions to log and monitor Cloud SQL for MySQL slow queries usingCloud Logging and Monitoring.

Enable lock monitoring

InnoDB monitors provide information about the InnoDB storage engine's internal state, which you can use in performance tuning.

Access the instance using MySQL Client and obtain on-demand monitor output:

SHOW ENGINE INNODB STATUS\G

For explanations of the sections in the monitor output, seeInnoDB Standard Monitor and Lock Monitor Output.

You can enable InnoDB monitors so that output is generated periodically to a file or a table, with performance degradation. For more information, seeEnabling InnoDB Monitors.

Use performance schema

The MySQL Performance Schema is a feature for monitoring MySQL Server execution at a low level. The most accessible way to consume the stats generated in performance_schema is through MySQL Workbench Performance Reportsfunctionality.

Keep a reasonable number of database tables

Database tables consume system resources. A large number can affect instance performance and availability, and cause the instance to lose its SLA coverage.Learn more.

General performance tips

. For slow database inserts, updates, or deletes, consider the following actions:

For slow database selects, consider the following:

If you observe poor performance executing queries, useEXPLAIN. EXPLAIN is a statement you add to other statements, like SELECT, and it returns information about how MySQL executes the statement. It works with SELECT, DELETE, INSERT, REPLACE, and UPDATE. For example, EXPLAIN SELECT * FROM myTable;.

Use EXPLAIN to identify where you can:

Troubleshoot

For other Cloud SQL issues, see the troubleshooting page.

Error messages

For specific API error messages, see the Error messages reference page.

Troubleshoot customer-managed encryption keys (CMEK)

Cloud SQL administrator operations, such as create, clone, or update, might fail due to Cloud KMS errors, and missing roles or permissions. Common reasons for failure include a missing Cloud KMS key version, a disabled or destroyed Cloud KMS key version, insufficient IAM permissions to access the Cloud KMS key version, or the Cloud KMS key version is in a different region than the Cloud SQL instance. Use the following troubleshooting table to diagnose and resolve common problems.

Customer-managed encryption keys troubleshooting table

For this error... The issue might be... Try this...
Per-product, per-project service account not found The service account name is incorrect. Make sure you created a service account for the correct user project. GO TO THE SERVICE ACCOUNTS PAGE.
Cannot grant access to the service account The user account does not have permission to grant access to this key version. Add the Organization Administrator role to your user or service account. GO TO THE IAM ACCOUNTS PAGE
Cloud KMS key version is destroyed The key version is destroyed. If the key version is destroyed, you cannot use it to encrypt or decrypt data.
Cloud KMS key version is disabled The key version is disabled. Re-enable the Cloud KMS key version. GO TO THE CRYPTO KEYS PAGE
Insufficient permission to use the Cloud KMS key The cloudkms.cryptoKeyEncrypterDecrypter role is missing on the user or service account you are using to run operations on Cloud SQL instances, or the Cloud KMS key version doesn't exist. In the Google Cloud project that hosts the key, add thecloudkms.cryptoKeyEncrypterDecrypter role to your user or service account. GO TO THE IAM ACCOUNTS PAGE If the role is already granted to your account, seeCreating a key to learn how to create a new key version. See note.
Cloud KMS key is not found The key version does not exist. Create a new key version. See Creating a key. See note.
EKM key is unreachable The External Key Manager (EKM) key is unreachable for several hours. Even after multiple retries, the EKM key remains unreachable. Verify EKM connection status and troubleshoot the issue with your EKM provider. GO TO THE CRYPTO KEYS PAGE
Cloud SQL instance and Cloud KMS key version are in different regions The Cloud KMS key version and Cloud SQL instance must be in the same region. It does not work if the Cloud KMS key version is in a global region or multi-region. Create a key version in the same region where you want to create instances. SeeCreating a key. See note.
Cloud KMS key version is restored but the instance is still suspended a few minutes later. The internal validation process for the instance can take up to 10 minutes before the instance becomes available again. Wait for 10 minutes for the instance to become available.
Cloud KMS key version is restored but the instance is still suspended more than 10 minutes later. The key version is disabled or doesn't grant proper permissions. Re-enable the key version, and grant the cloudkms.cryptoKeyEncrypterDecrypter role to your user or service account in the Google Cloud project that hosts the key.

Re-encryption troubleshooting table

For this error... The issue might be... Try this...
CMEK resource re-encryption failed because the Cloud KMS key is inaccessible. Please ensure that the primary key version is enabled and the permission is granted properly. The key version is disabled or doesn't grant proper permissions. Re-enable the Cloud KMS key version: GO TO THE CRYPTO KEYS PAGE In the Google Cloud project that hosts the key, confirm the cloudkms.cryptoKeyEncrypterDecrypter role is granted to your user or service account: GO TO THE IAM ACCOUNTS PAGE
CMEK resource re-encryption failed due to server internal error. Please retry later There is a server internal error. Retry re-encryption. For more information, see Re-encrypt an existing CMEK-enabled instance or replica