Questa pagina descrive alcuni dei messaggi di errore riscontrati in Cloud SQL.
Panoramica
I messaggi di errore in Cloud SQL provengono da molte fonti e vengono visualizzati in molti punti. Alcuni messaggi di errore provengono dai motori di database stessi, altri dal servizio Cloud SQL, altri ancora dalle applicazioni client e alcuni vengono restituiti dalle chiamate all'API Cloud SQL Admin.
Questa pagina include alcuni degli errori più comuni riscontrati in Cloud SQL. Se non trovi il codice o il messaggio di errore che stai cercando, puoi consultare il materiale di riferimento della fonte qui:
- Pagine di riferimento degli errori di MySQL
- Pagine di riferimento degli errori di PostgreSQL
- Pagine di riferimento degli errori di SQL Server
Se non trovi il materiale di riferimento per il messaggio di errore che visualizzi, puoi anche cercare in questi luoghi in cui altri utenti potrebbero avere esperienze pertinenti:
- Domande su Cloud SQL su Stack Overflow
- Public issue tracker per Cloud SQL
- DBA Stack Exchange
- Gruppo di discussione Cloud SQL
- Community Slack di Google Cloud
- Google Cloud su Reddit
Errori operativi
A | B | C | D | E | F | G | I | L | M | N | O | P | Q | R | S | T | U | W
Messaggio di errore | Risoluzione dei problemi |
---|---|
Connessione xxx interrotta al database: DB_NAME. | L'applicazione non termina correttamente le connessioni.
Verifica la presenza delle seguenti condizioni:
|
Accesso negato. Per questa operazione devi disporre di almeno uno dei privilegi SUPER. | Potrebbe esserci una vista, una funzione o una procedura nel database di origine che fa riferimento a DEFINER in un modo non supportato da Cloud SQL.
Aggiorna il definer nei database esterni, ad esempio
da |
Accesso negato per l'utente "XXX"@"XXX" (utilizzo della password: XXX) | Potrebbero esserci diverse cause, tra cui:
Prova a fare queste cose…
|
Intervallo IP allocato non trovato nella rete. | I peering VPC non sono stati aggiornati dopo la modifica
o la rimozione di un intervallo allocato.
Devi
modificare la connessione privata. Utilizza il seguente comando e assicurati di utilizzare l'argomento gcloud services vpc-peerings update \ --network=VPC_NETWORK \ --ranges=ALLOCATED_RANGES \ --service=servicenetworking.googleapis.com \ --force |
ANY command denied to user 'root'@'%' for table ... | L'utente non dispone di tutte le autorizzazioni necessarie per questa operazione.
Prova questa procedura:
|
Messaggio di errore | Risoluzione dei problemi |
---|---|
Richiesta errata. | Questo messaggio può essere causato da diversi motivi. Illegal Argument è uno dei più comuni. In questo caso, la richiesta utilizza l'argomento
errato o un valore non valido per l'argomento. Per le molte altre
cause, il messaggio di errore potrebbe contenere un suggerimento utile.
Per |
Messaggio di errore | Risoluzione dei problemi |
---|---|
Impossibile modificare gli intervalli allocati in CreateConnection. Utilizza UpdateConnection. | I peering VPC non sono stati aggiornati dopo la modifica o la rimozione di un intervallo allocato.
Devi modificare la connessione privata.
Utilizza il seguente comando e assicurati di utilizzare l'argomento gcloud services vpc-peerings update \ --network=VPC_NETWORK \ --ranges=ALLOCATED_RANGES \ --service=servicenetworking.googleapis.com \ --force |
Connessione reimpostata dal peer. | Se stai tentando di eseguire un'esportazione e Cloud Storage non riceve dati entro un determinato periodo di tempo, la connessione viene reimpostata. Prova un'esportazione manuale utilizzando |
Constraints/sql.restrictAuthorizedNetworks. | L'operazione di clonazione è bloccata dalla
configurazione Authorized Networks . Authorized Networks
sono configurati per indirizzi IP pubblici nella sezione Connettività della console Google Cloud e la clonazione non è consentita per motivi di sicurezza.
Se possibile, rimuovi tutte le voci |
Impossibile allocare una nuova pagina per il database database_name
a causa di spazio su disco insufficiente nel filegroup PRIMARY . |
Il filegroup PRIMARY , che è il filegroup principale e predefinito in un
database, ha esaurito lo spazio.
Utilizza il comando Prendi in considerazione le seguenti soluzioni:
|
Messaggio di errore | Risoluzione dei problemi |
---|---|
Il database user non esiste. |
gcloud sql connect --user funziona solo con l'utente
postgres predefinito.
Connettiti all'utente predefinito e poi cambia utente. |
Lo spazio sul disco è esaurito. | La dimensione del disco dell'istanza principale può esaurirsi durante la creazione della replica.
Modifica l'istanza principale per eseguire l'upgrade a una dimensione del disco maggiore. |
Messaggio di errore | Risoluzione dei problemi |
---|---|
Impossibile creare la subnet. | Non sono disponibili altri indirizzi nell'intervallo IP.
Impossibile trovare blocchi liberi negli intervalli IP allocati. Assegna nuovi intervalli per questo fornitore di servizi. Non sono disponibili altri indirizzi nell'intervallo IP allocato. Considera questi possibili scenari:
Per ciascuno degli scenari precedenti, puoi scegliere di espandere l'intervallo esistente o allocare un intervallo IP aggiuntivo alla connessione al servizio privato. Se stai allocando un nuovo intervallo, fai attenzione a non creare un'allocazione che si sovrapponga a quelle esistenti. Dopo aver creato un nuovo intervallo IP, aggiorna il peering VPC con il seguente comando: gcloud services vpc-peerings update \ --service=servicenetworking.googleapis.com --ranges=OLD_RESERVED_RANGE_NAME,NEW_RESERVED_RANGE_NAME \ --network=VPC_NETWORK --project=PROJECT_ID \ --force Se stai espandendo un'allocazione esistente, fai attenzione ad aumentare solo l'intervallo di allocazione e non a diminuirlo. Ad esempio, se l'allocazione originale era 10.0.10.0/24, la nuova allocazione deve essere almeno 10.0.10.0/23. In generale, se si parte da un'allocazione /24, diminuire la maschera di 1 per ogni condizione (gruppo di tipi di istanza aggiuntivo, regione aggiuntiva) è una buona regola pratica. Ad esempio, se provi a creare entrambi i gruppi di tipi di istanza nella stessa allocazione, è sufficiente passare da /24 a /23. Dopo aver espanso un intervallo IP esistente, aggiorna il peering VPC con il seguente comando: gcloud services vpc-peerings update \ --service=servicenetworking.googleapis.com --ranges=RESERVED_RANGE_NAME \ --network=VPC_NETWORK \ --project=PROJECT_ID \ --force |
Messaggio di errore | Risoluzione dei problemi |
---|---|
(gcloud.sql.connect) Sembra che il tuo client non abbia connettività IPv6 e l'istanza del database non abbia un indirizzo IPv4. | Stai tentando di connetterti all'istanza IP privato utilizzando Cloud Shell.
La connessione da Cloud Shell a un'istanza con solo un indirizzo IP privato non è attualmente supportata. |
Ricevuto pacchetto più grande di max_allowed_packet byte durante
il dump della tabella. |
Il pacchetto era più grande di quanto consentito dalle impostazioni.
Utilizza Per scoprire di più sull'utilizzo dei flag |
Messaggio di errore | Risoluzione dei problemi |
---|---|
InnoDB: Write to file ./ibtmp1 failed at offset XXXX, YYYY bytes should have been written, only 0 were written. | L'istanza ha raggiunto un limite rigido durante l'esecuzione di un backup automatico.
Verifica che il sistema operativo e il file system supportino file di queste dimensioni. Verifica che il disco non sia pieno o che non abbia superato la quota disco. Puoi richiedere l'incremento delle tue quote dalla consoleGoogle Cloud o modificare l'istanza per eseguire l'upgrade a una dimensione del disco maggiore. |
Errore interno. | Al progetto potrebbe mancare il account di servizio Service Networking
necessario per questa funzionalità.
Per riparare le autorizzazioni del servizio, disattiva
|
Richiesta non valida: configurazione di Service Networking errata per l'istanza. | Service Networking API non è abilitata nel progetto.
Abilita |
Messaggio di errore | Risoluzione dei problemi |
---|---|
Accesso non riuscito per l'utente "XXX". | Verifica che l'utente disponga dei privilegi sull'istanza e sul database a cui sta tentando di connettersi e assicurati che vengano utilizzate le credenziali corrette. |
Messaggio di errore | Risoluzione dei problemi |
---|---|
Tabella dei metadati bloccata. | Un'altra query, un altro processo o un'altra transazione sta bloccando la tua query e ha bloccato
la tabella.
Trova il processo che ha bloccato la tabella e interrompilo:
|
Messaggio di errore | Risoluzione dei problemi |
---|---|
Associazione di rete non riuscita. | Service Networking API non è abilitato nel progetto.
Abilita |
Messaggio di errore | Risoluzione dei problemi |
---|---|
Operazione non riuscita perché è già in corso un'altra operazione. | La maggior parte delle operazioni in Cloud SQL sono sincrone. Puoi
eseguirne solo una alla volta.
Attendi il completamento dell'operazione precedente prima di iniziarne un'altra. |
L'operazione non è valida per questa istanza. | Questo errore viene restituito da una chiamata API a instances.restoreBackup ,
e significa che non puoi eseguire il ripristino dal backup a un'istanza con una dimensione dello spazio di archiviazione
(XX GB) inferiore alla dimensione del backup (YY GB).
Modifica l'istanza di destinazione per aumentare le dimensioni dello spazio di archiviazione. |
Messaggio di errore | Risoluzione dei problemi |
---|---|
Autenticazione con password non riuscita per l'utente "postgres". | Quando crei una nuova istanza di Cloud SQL per PostgreSQL, viene creato l'utente amministratore predefinito postgres , ma non la password.
Devi
impostare una password per questo utente prima che possa accedere. |
Messaggio di errore | Risoluzione dei problemi |
---|---|
Quota superata. | Hai raggiunto il limite della quota al minuto o giornaliera. Esamina le
quote e i limiti per Cloud SQL.
Richiedi un aumento delle quote dalla Google Cloud console. |
Messaggio di errore | Risoluzione dei problemi |
---|---|
Gli slot di connessione rimanenti sono riservati. | È stato raggiunto il numero massimo di connessioni consentite.
Aumenta il valore del flag |
La richiesta non contiene una chiave API valida. | Potresti non avere un file JSON della chiave del account di servizio valido o potrebbe
non essere archiviato nella posizione prevista.
Verifica di avere un file JSON della chiave account di servizio valido nella posizione archiviata nella variabile di ambiente |
Messaggio di errore | Risoluzione dei problemi |
---|---|
La chiave specificata era troppo lunga. La lunghezza massima della chiave è 767 byte. | L'istanza principale esterna potrebbe avere impostata la variabile innodb_large_prefix .
Imposta il flag |
Errore SSL: spaziatura interna non valida. | Errore del certificato del server.
Crea un nuovo certificato server e ruotalo. |
Si è verificato un errore di sistema. |
Prova a fare queste cose…
|
Messaggio di errore | Risoluzione dei problemi |
---|---|
Definizione della tabella modificata. | Durante la procedura di esportazione si è verificata una modifica nella tabella.
L'operazione di dump può non riuscire se utilizzi le seguenti istruzioni durante l'operazione di esportazione:
Rimuovi una qualsiasi di queste istruzioni dall'operazione di dump. |
Le dimensioni del file temporaneo superano temp_file_limit. | Il flag temp_file_limit è impostato su un valore troppo basso per l'utilizzo del database.
Aumenta le dimensioni di |
La tabella db.table non esiste | Se una o più tabelle InnoDB sono scomparse dopo il riavvio di MySQL e
il log degli errori di MySQL contiene i seguenti avvisi contemporaneamente, il problema è dovuto
alla mancata sincronizzazione delle colonne della chiave esterna e della chiave di riferimento.
[Warning] InnoDB: Load table db.table failed, the table has missing foreign key indexes. Turn off 'foreign_key_checks' and try again. [Warning] InnoDB: Cannot open table db/table from the internal data dictionary of InnoDB though the .frm file for the table exists. See InnoDB troubleshooting for more information. Dopo il riavvio di un database, MySQL deve caricare le tabelle nella cache del dizionario InnoDB al primo accesso. Se rileva la discrepanza, blocca l'accesso a quella tabella. mysql> select * from db.table; ERROR 1146 (42S02): Table db.table doesn't exist La disattivazione di La mancata corrispondenza della chiave esterna deve essere corretta per evitare ulteriori problemi.
|
(Timeout) durante l'esportazione. | I formati CSV e SQL vengono esportati in modo diverso. Il formato SQL include l'intero database e probabilmente richiederà più tempo per essere completato.
Utilizza il formato CSV ed esegui più job di esportazione più piccoli per ridurre le dimensioni e la durata di ogni operazione. |
Troppe connessioni. | L'impostazione di un valore troppo alto per il flag max_connections può causare questo errore. Questo può anche essere causato dall'attivazione di un flag fuori sequenza.
Abbassa il valore del flag |
Messaggio di errore | Risoluzione dei problemi |
---|---|
Autorizzazione di connessione non concessa. | Le cause possono essere molteplici, perché l'autorizzazione avviene a molti livelli:
Prova a fare queste cose…
|
Tabella sconosciuta COLUMN_STATISTICS in information_schema. |
Ciò si verifica se utilizzi il binario mysqldump di MySQL 8.0 per eseguire il dump dei dati da un database MySQL 5.7 e importarli in un database MySQL 8.0.
Se esegui il dump dei dati da un database MySQL 5.7 e li importi in un database MySQL 8.0,
assicurati di utilizzare il binario |
Messaggio di errore | Risoluzione dei problemi |
---|---|
x509: certificate isn't valid for any names. | Problema noto: al momento,
Cloud SQL Proxy Dialer non è compatibile con Go 1.15.
Fino alla correzione, consulta questa discussione su GitHub, che include una soluzione alternativa. |
Errori sconosciuti
La seguente tabella mostra alcuni casi noti in cui può verificarsi un Unknown Error
ed elenca rimedi specifici, ove applicabile. Tuttavia, questo non è
un elenco esaustivo. Se non trovi la tua richiesta nella tabella, controlla lo
strumento di monitoraggio dei problemi pubblici per Cloud SQL.
Se non trovi il problema, valuta la possibilità di
inviare una segnalazione o di esaminare
altre opzioni di assistenza.
Operazione | Il problema potrebbe essere... | Cose da provare… |
---|---|---|
Aggiungi utente | Se l'utente esiste già nel database, questo errore può verificarsi quando tenti di aggiungerlo. | Controlla che l'utente non esista già nel database. |
Backup | Se visualizzi questo messaggio durante i backup automatici o manuali, è probabile che il disco dell'istanza sia pieno. | Se le dimensioni del file temporaneo occupano troppo spazio, puoi riavviare l'istanza per rimuovere il file e liberare spazio su disco. In caso contrario, potrebbe essere necessario eseguire l'upgrade dell'istanza a una dimensione del disco maggiore. |
Clona | Ciò può verificarsi quando le risorse nella zona selezionata sono insufficienti. | Prova un'altra zona nella regione oppure attendi e riprova più tardi. |
Crea istanza |
|
|
Esporta | Se visualizzi questo messaggio mentre tenti di esportare un database in un bucket Cloud Storage, il trasferimento potrebbe non riuscire a causa di un problema di larghezza di banda. | L'istanza Cloud SQL potrebbe trovarsi in una regione diversa rispetto al bucket Cloud Storage. La lettura e la scrittura di dati da un continente all'altro comportano un utilizzo elevato della rete e possono causare problemi intermittenti come questo. |
Failover (automatico) | Un'operazione di failover automatico può generare questo messaggio di errore quando il servizio rileva che l'istanza principale risponde ancora. | In questo caso non è possibile fare nulla. Il failover non si verifica perché non è necessario. |
Importa | Il file di importazione potrebbe contenere istruzioni che richiedono il ruolo di superutente. | Modifica il file per rimuovere tutte le istruzioni che richiedono il ruolo di superutente. |
Cloud SQL utilizza anche alcuni binari di terze parti (ad esempio,
mysqld
), che possono generare messaggi di errore sconosciuti. Questi errori sono
interni ai binari di terze parti e non rientrano nell'ambito di Cloud SQL.
Tuttavia, a volte è possibile trovare un errore più specifico nei
file di log di Cloud SQL all'incirca nello stesso
momento.
Inoltre, a volte si tratta di un codice di errore sconosciuto. In questo caso,
il messaggio completo può essere Unknown Error Code
.