Configurer des options de base de données

Cette page explique comment configurer des indicateurs de base de données pour Cloud SQL et répertorie les indicateurs que vous pouvez définir pour votre instance. Les indicateurs de base de données sont utilisés pour de nombreuses opérations, y compris l'ajustement des paramètres et des options MySQL, ainsi que la configuration et le réglage d'une instance.

Parfois, définir un indicateur implique d'en définir un autre, afin d'activer complètement la fonctionnalité souhaitée. Par exemple, pour activer la journalisation lente des requêtes, vous devez définir à la fois l'indicateur slow_query_log sur on et l'indicateur log_output sur FILE. Grâce à ces deux indicateurs, vos journaux seront disponibles à partir de l'explorateur de journaux de Google Cloud Console.

Lorsque vous définissez, supprimez ou modifiez un indicateur pour une instance de base de données, il peut être nécessaire de la redémarrer. La nouvelle valeur de l'indicateur est ensuite conservée pour l'instance, jusqu'à ce que vous la supprimiez. Si l'instance est la source d'une instance dupliquée et est redémarrée, elle est également redémarrée pour s'aligner sur la configuration actuelle de l'instance.

Configurer des options de base de données

Définir une option de base de données

Console

  1. Dans la console Google Cloud, sélectionnez le projet contenant l'instance Cloud SQL pour laquelle vous souhaitez définir une option de base de données.
  2. Ouvrez l'instance et cliquez sur Modifier.
  3. Faites défiler jusqu'à la section Indicateurs.
  4. Pour définir un nouvel indicateur sur l'instance, cliquez sur Ajouter un élément, choisissez-le dans le menu déroulant et définissez sa valeur.
  5. Cliquez sur Enregistrer pour enregistrer les modifications.
  6. Confirmez les modifications effectuées dans la section Indicateurs à partir de la page de présentation.

gcloud

Modifiez l'instance :

gcloud sql instances patch INSTANCE_NAME --database-flags=FLAG1=VALUE1,FLAG2=VALUE2

Cette commande va écraser tous les indicateurs de base de données précédemment définis. Pour les conserver et en ajouter d'autres, vous devez inclure les valeurs de tous les indicateurs que vous souhaitez définir sur l'instance. Tout indicateur qui n'est pas spécifiquement inclus est défini à sa valeur par défaut. Pour les indicateurs sans valeur, spécifiez le nom de l'indicateur suivi d'un signe égal ("=").

Par exemple, pour définir les indicateurs general_log, skip_show_database et wait_timeout, vous pouvez exécuter la commande suivante :

gcloud sql instances patch INSTANCE_NAME \
  --database-flags=general_log=on,skip_show_database=on,wait_timeout=200000

Terraform

Pour ajouter des options de base de données, utilisez une ressource Terraform.

resource "google_sql_database_instance" "instance" {
  database_version = "MYSQL_8_0"
  name             = "mysql-instance"
  region           = "us-central1"
  settings {
    database_flags {
      name  = "general_log"
      value = "on"
    }
    database_flags {
      name  = "skip_show_database"
      value = "on"
    }
    database_flags {
      name  = "wait_timeout"
      value = "200000"
    }
    disk_type = "PD_SSD"
    tier      = "db-n1-standard-2"
  }
  # set `deletion_protection` to true, will ensure that one cannot accidentally delete this instance by
  # use of Terraform whereas `deletion_protection_enabled` flag protects this instance at the GCP level.
  deletion_protection = false
}

Appliquer les modifications

Pour appliquer votre configuration Terraform dans un projet Google Cloud, suivez les procédures des sections suivantes.

Préparer Cloud Shell

  1. Lancez Cloud Shell.
  2. Définissez le projet Google Cloud par défaut dans lequel vous souhaitez appliquer vos configurations Terraform.

    Vous n'avez besoin d'exécuter cette commande qu'une seule fois par projet et vous pouvez l'exécuter dans n'importe quel répertoire.

    export GOOGLE_CLOUD_PROJECT=PROJECT_ID

    Les variables d'environnement sont remplacées si vous définissez des valeurs explicites dans le fichier de configuration Terraform.

Préparer le répertoire

Chaque fichier de configuration Terraform doit avoir son propre répertoire (également appelé module racine).

  1. Dans Cloud Shell, créez un répertoire et un nouveau fichier dans ce répertoire. Le nom du fichier doit comporter l'extension .tf, par exemple main.tf. Dans ce tutoriel, le fichier est appelé main.tf.
    mkdir DIRECTORY && cd DIRECTORY && touch main.tf
  2. Si vous suivez un tutoriel, vous pouvez copier l'exemple de code dans chaque section ou étape.

    Copiez l'exemple de code dans le fichier main.tf que vous venez de créer.

    Vous pouvez également copier le code depuis GitHub. Cela est recommandé lorsque l'extrait Terraform fait partie d'une solution de bout en bout.

  3. Examinez et modifiez les exemples de paramètres à appliquer à votre environnement.
  4. Enregistrez les modifications.
  5. Initialisez Terraform. Cette opération n'est à effectuer qu'une seule fois par répertoire.
    terraform init

    Vous pouvez également utiliser la dernière version du fournisseur Google en incluant l'option -upgrade :

    terraform init -upgrade

Appliquer les modifications

  1. Examinez la configuration et vérifiez que les ressources que Terraform va créer ou mettre à jour correspondent à vos attentes :
    terraform plan

    Corrigez les modifications de la configuration si nécessaire.

  2. Appliquez la configuration Terraform en exécutant la commande suivante et en saisissant yes lorsque vous y êtes invité :
    terraform apply

    Attendez que Terraform affiche le message "Apply completed!" (Application terminée).

  3. Ouvrez votre projet Google Cloud pour afficher les résultats. Dans la console Google Cloud, accédez à vos ressources dans l'interface utilisateur pour vous assurer que Terraform les a créées ou mises à jour.

Supprimer les modifications

Pour supprimer vos modifications, procédez comme suit :

  1. Pour désactiver la protection contre la suppression, définissez l'argument deletion_protection sur false dans le fichier de configuration Terraform.
    deletion_protection =  "false"
  2. Appliquez la configuration Terraform mise à jour en exécutant la commande suivante et en saisissant yes lorsque vous y êtes invité :
    terraform apply
  1. Supprimez les ressources précédemment appliquées à votre configuration Terraform en exécutant la commande suivante et en saisissant yes à la requête :

    terraform destroy

REST v1

Pour définir un indicateur pour une base de données existante, procédez comme suit :

Avant d'utiliser les données de requête, effectuez les remplacements suivants :

  • project-id : ID du projet
  • instance-id : ID de l'instance.

Méthode HTTP et URL :

PATCH https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id

Corps JSON de la requête :

{
  "settings":
  {
    "databaseFlags":
    [
      {
        "name": "flag_name",
        "value": "flag_value"
      }
    ]
  }
}

Pour envoyer votre requête, développez l'une des options suivantes :

Vous devriez recevoir une réponse JSON de ce type :

Par exemple, pour définir l'indicateur general_log pour une base de données existante, procédez comme suit :

Avant d'utiliser les données de requête, effectuez les remplacements suivants :

  • project-id : ID du projet
  • instance-id : ID de l'instance.

Méthode HTTP et URL :

PATCH https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id

Corps JSON de la requête :

{
  "settings":
  {
    "databaseFlags":
    [
      {
        "name": "general_log",
        "value": "on"
      }
    ]
  }
}

Pour envoyer votre requête, développez l'une des options suivantes :

Vous devriez recevoir une réponse JSON de ce type :

Si des indicateurs sont déjà configurés pour la base de données, modifiez la commande précédente pour les inclure. La commande PATCH remplace les indicateurs existants par ceux spécifiés dans la requête.

REST v1beta4

Pour définir un indicateur pour une base de données existante, procédez comme suit :

Avant d'utiliser les données de requête, effectuez les remplacements suivants :

  • project-id : ID du projet
  • instance-id : ID de l'instance.

Méthode HTTP et URL :

PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id

Corps JSON de la requête :

{
  "settings":
  {
    "databaseFlags":
    [
      {
        "name": "flag_name",
        "value": "flag_value"
      }
    ]
  }
}

Pour envoyer votre requête, développez l'une des options suivantes :

Vous devriez recevoir une réponse JSON de ce type :

Par exemple, pour définir l'indicateur general_log pour une base de données existante, procédez comme suit :

Avant d'utiliser les données de requête, effectuez les remplacements suivants :

  • project-id : ID du projet
  • instance-id : ID de l'instance.

Méthode HTTP et URL :

PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id

Corps JSON de la requête :

{
  "settings":
  {
    "databaseFlags":
    [
      {
        "name": "general_log",
        "value": "on"
      }
    ]
  }
}

Pour envoyer votre requête, développez l'une des options suivantes :

Vous devriez recevoir une réponse JSON de ce type :

Si des indicateurs sont déjà configurés pour la base de données, modifiez la commande précédente pour les inclure. La commande PATCH remplace les indicateurs existants par ceux spécifiés dans la requête.

Réinitialiser les valeurs par défaut des options

Console

  1. Dans la console Google Cloud, sélectionnez le projet contenant l'instance Cloud SQL pour laquelle vous souhaitez réinitialiser toutes les options.
  2. Ouvrez l'instance et cliquez sur Modifier.
  3. Ouvrez la section Indicateurs de base de données.
  4. Cliquez sur le symbole X à côté de tous les indicateurs affichés.
  5. Cliquez sur Enregistrer pour enregistrer les modifications.

gcloud

Réinitialiser les valeurs par défaut des indicateurs d'une instance :

gcloud sql instances patch INSTANCE_NAME \
--clear-database-flags

Vous êtes invité à confirmer le redémarrage de l'instance.

REST v1

Pour effacer tous les indicateurs sur une instance existante :

Avant d'utiliser les données de requête, effectuez les remplacements suivants :

  • project-id : ID du projet
  • instance-id : ID de l'instance.

Méthode HTTP et URL :

PATCH https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id

Corps JSON de la requête :

{
  "settings":
  {
    "databaseFlags": []
  }
}

Pour envoyer votre requête, développez l'une des options suivantes :

Vous devriez recevoir une réponse JSON de ce type :

REST v1beta4

Pour effacer tous les indicateurs sur une instance existante :

Avant d'utiliser les données de requête, effectuez les remplacements suivants :

  • project-id : ID du projet
  • instance-id : ID de l'instance.

Méthode HTTP et URL :

PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id

Corps JSON de la requête :

{
  "settings":
  {
    "databaseFlags": []
  }
}

Pour envoyer votre requête, développez l'une des options suivantes :

Vous devriez recevoir une réponse JSON de ce type :

Afficher les valeurs actuelles des options de base de données

Pour afficher toutes les valeurs actuelles des variables de système MySQL, connectez-vous à votre instance avec le client mysql et saisissez l'instruction suivante :

 SHOW VARIABLES;

Notez que vous ne pouvez modifier la valeur que des indicateurs compatibles (répertoriés ci-dessous).

Déterminer les options de base de données définies pour une instance

Pour savoir quelles options ont été définies pour une instance Cloud SQL :

Console

  1. Dans la console Google Cloud, sélectionnez le projet contenant l'instance Cloud SQL pour laquelle vous souhaitez afficher les options de base de données définies.
  2. Sélectionnez l'instance pour ouvrir la page Présentation de l'instance.

    Les indicateurs de base de données définis sont répertoriés dans la section Indicateurs de base de données.

gcloud

Afficher l'état de l'instance :

gcloud sql instances describe INSTANCE_NAME

Dans le résultat, les indicateurs de base de données sont répertoriés sous la section settings dans la collection databaseFlags. Pour en savoir plus sur la représentation des options dans le résultat, consultez la page Représentation des ressources d'instances.

REST v1

Pour répertorier les indicateurs configurés pour une instance :

Avant d'utiliser les données de requête, effectuez les remplacements suivants :

  • project-id : ID du projet
  • instance-id : ID de l'instance.

Méthode HTTP et URL :

GET https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id

Pour envoyer votre requête, développez l'une des options suivantes :

Vous devriez recevoir une réponse JSON de ce type :

Dans le résultat, recherchez le champ databaseFlags.

REST v1beta4

Pour répertorier les indicateurs configurés pour une instance :

Avant d'utiliser les données de requête, effectuez les remplacements suivants :

  • project-id : ID du projet
  • instance-id : ID de l'instance.

Méthode HTTP et URL :

GET https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id

Pour envoyer votre requête, développez l'une des options suivantes :

Vous devriez recevoir une réponse JSON de ce type :

Dans le résultat, recherchez le champ databaseFlags.

Options gérées par Cloud SQL

Cloud SQL ajuste certaines options système en fonction du type de machine de l'instance.

innodb_buffer_pool_instances
  • 1 pour db-f1-micro et db-g1-small.
  • 1 si la mémoire RAM est inférieure à 7,5 Go.
  • 2 si la mémoire RAM est comprise entre 7,5 Go et 13 Go
  • 4 si la mémoire RAM est comprise entre 13 Go et 26 Go.
  • 8 si la mémoire RAM est supérieure à 26 Go.

Indicateurs compatibles

Les indicateurs compatibles avec Cloud SQL correspondent aux indicateurs MySQL les plus courants. Les indicateurs qui n'apparaissent pas ci-dessous ne sont pas compatibles.

Pour un indicateur donné, Cloud SQL peut être compatible avec une valeur ou une plage différentes de celles du paramètre ou de l'option MySQL correspondants.

Les indicateurs s'appliquent à toutes les versions de MySQL prises en charge par Cloud SQL, sauf indication contraire.

A | B | C | D | E | F | G | H | I | L | M | N | O | P | Q | R | S | T | U | W

Indicateur Cloud SQL Valeurs
acceptables et remarques pour le type
Redémarrage
nécessaire ?
activate_all_roles_on_login boolean
on | off
Par défaut : off
Non
autocommit boolean
on | off
par défaut : on
Non
auto_increment_increment integer
1 ... 65535
Non
auto_increment_offset integer
1 ... 65535
Non
automatic_sp_privileges boolean
on | off
par défaut : on
Non
back_log integer
1 ... 65535
par défaut : max_connections
Oui
binlog_cache_size integer
4096 ... 9223372036854775807
Non
binlog_expire_logs_seconds integer
0 ou 86400 (1 day) ... 4294967295 (max value)
La valeur par défaut est 2 592 000, soit 30 jours.

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
binlog_group_commit_sync_delay 0 ... 1 000 000

Compatible avec MySQL 5.7, 8.0

La valeur par défaut est 0.

Non
binlog_group_commit_sync_no_delay_count 0 ... 1 000 000

Compatible avec MySQL 5.7, 8.0

La valeur par défaut est 0.

Non
binlog_gtid_simple_recovery boolean
on | off
par défaut : on
Oui
binlog_order_commits boolean
on | off
par défaut : on

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
binlog_row_image enumeration
full (par défaut), minimal ou noblob
Non
binlog_row_metadata enumeration
full ou minimal (par défaut)
Non
binlog_row_value_options string
PARTIAL_JSON
Non
binlog_rows_query_log_events boolean
on | off
par défaut : off
Non
binlog_stmt_cache_size 4096 ... 9223372036854775807 Non
binlog_transaction_dependency_history_size integer

Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

Non
binlog_transaction_dependency_tracking enumeration

Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

Non
block_encryption_mode string
aes-keylen-mode
par défaut : aes-128-ECB
Non
bulk_insert_buffer_size integer
0 ... 4294967295
par défaut : 8388608
Non
collation_connection string
valeur par défaut :
MySQL 8.0 - utf8mb4_0900_ai_ci

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
collation_server string
Valeur par défaut :
MySQL 5.7 :utf8_general_ci
MySQL 8.0 :utf8mb4_0900_ai_ci
Non
character_set_client string

par défaut :
MySQL 5.7 : utf8
MySQL 8.0 : utf8mb4

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
character_set_connection string
par défaut :
MySQL 5.7 : utf8
MySQL 8.0 : utf8mb4

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
character_set_results string
utf8 ou utf8mb4
Valeur par défaut :
MySQL 5.7 : utf8
MySQL 8.0 : utf8mb4

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
character_set_server string
utf8 ou utf8mb4 (recommandé)
Oui
check_proxy_users boolean
on | off
par défaut : off
Non
cloudsql_allow_analyze_table boolean on | off
Par défaut : off
Non
cloudsql_iam_authentication boolean on | off
Par défaut : off
Compatible avec MySQL 5.7 et 8.0 pour Cloud SQL.
Non
cloudsql_ignore_innodb_encryption boolean on | off
Par défaut : off
Non
cloudsql_mysql_audit_data_masking_cmds string
"", dql, dml, ddl, dcl, show, call, create_udf, drop_function, create_procedure, create_function, drop_procedure, alter_procedure, alter_function, create_trigger, drop_trigger, create_event, alter_event, drop_event, create_db, drop_db, alter_db, create_user, drop_user, rename_user, alter_user, create_table, create_index, alter_table, drop_table, drop_index, create_view, drop_view, rename_table, update, insert, insert_select, delete, truncate, replace, replace_select, delete_multi, update_multi, load, select, call_procedure, connect, disconnect, grant, revoke, revoke_all, show_triggers, show_create_proc, show_create_func, show_procedure_code, show_function_code, show_create_event, show_events, show_create_trigger, show_grants, show_binlog_events, show_relaylog_events

par défaut : create_user, alter_user, grant, et update
Non
cloudsql_mysql_audit_data_masking_regex string
max_string_length: 2048
Par défaut : cliquez ici.
Non
cloudsql_mysql_audit_log_write_period integer
0...5000 millisecondes
par défaut : 500 millisecondes
Non
cloudsql_mysql_audit_max_query_length integer
-1...1073741824
par défaut : -1
Non
cloudsql_vector boolean on | off
Par défaut : off
Oui
cloudsql_vector_max_mem_size integer
1073741824...innodb_buffer_pool_size/2
Valeur par défaut : 1073741824 en octets
Oui
completion_type enumeration
NO_CHAIN (par défaut), CHAIN, ou RELEASE
Non
concurrent_insert enumeration
NEVER, AUTO (par défaut), ou ALWAYS
Non
connect_timeout integer
2 ... 31536000
par défaut : 10
Non
cte_max_recursion_depth integer
0 ... 4294967295
par défaut : 1000
Non
default_authentication_plugin string
mysql_native_password|caching_sha2_password
Oui
default_password_lifetime integer 0...65535
Par défaut : 0
Non
default_time_zone string
Il existe deux façons de spécifier des fuseaux horaires : en tant que décalages de fuseau horaire et en tant que noms de fuseau horaire. Par exemple, +00:00 est le décalage horaire pour Londres (qui est dans le fuseau horaire UTC) et Europe/London est le nom de fuseau horaire.

Pour spécifier des décalages de fuseaux horaires, on utilise des valeurs de -12:59 à +13:00. Des zéros doivent être ajoutés au début.

Si vous utilisez des noms de fuseau horaire, le passage automatique à l'heure d'été est possible. Lorsque vous utilisez des décalages de fuseau horaire, le passage automatique à l'heure d'été n'est pas possible. Consultez la liste des noms de fuseaux horaires compatibles avec Cloud SQL pour MySQL. Vous devez mettre à jour cette option manuellement sur l'instance principale et sur toutes les instances dupliquées lues pour qu'elle soit prise en compte.

Pour définir le fuseau horaire sans redémarrer l'instance Cloud SQL, exécutez la commande set time_zone=timezone_offset ou timezone_name avec l'option init_connect.

Oui
default_week_format integer
0 ... 7
par défaut : 0
Non
delay_key_write enumeration
OFF, ON (par défaut), ou ALL
Non
disconnect_on_expired_password boolean on | off
Par défaut : on
Oui
div_precision_increment integer
0 ... 30
par défaut : 4
Non
end_markers_in_json boolean
on | off
par défaut : off
Non
eq_range_index_dive_limit integer
0 ... 2147483647
Non
event_scheduler boolean
on | off

Si vous utilisez le planificateur d'événements, configurez votre instance avec une règle d'activation définie sur TOUJOURS, afin de garantir l'exécution des événements planifiés.

Consultez la section Conseils pour plus d'informations sur cette option.

Non
expire_logs_days integer
0 ... 99
La valeur par défaut est 0, ce qui signifie qu'il n'y a aucune suppression automatique.

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
explicit_defaults_for_timestamp boolean
on | off

Non
flush_time integer
0 ... 31536000
par défaut : 0
Non
foreign_key_checks boolean
on | off
Par défaut : on

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
ft_max_word_len integer
10 ... 252
Oui
ft_min_word_len integer
1 ... 16
Oui
ft_query_expansion_limit integer
0 ... 1000
Oui
ft_stopword_file string
Oui
general_log boolean
on | off

Consultez la section Conseils pour plus d'informations sur les journaux généraux.

Non
generated_random_password_length integer 5-255
Par défaut : 20
Non
group_concat_max_len integer
4 ... 17179869184
Non
gtid_executed_compression_period integer
0 ... 4294967295
par défaut (jusqu'à la version 8.0.22) : 1000
par défaut (version 8.0.23+) : 0
Non
histogram_generation_max_mem_size integer
1000000 ... 4294967295
par défaut : 20000000
Non
init_connect string Non
innodb_adaptive_hash_index boolean
on | off
Non
innodb_adaptive_hash_index_parts integer
1 ... 512
Oui
innodb_adaptive_max_sleep_delay integer
0 ... 1000000
Non
innodb_autoextend_increment integer
1 ... 1000
Non
innodb_autoinc_lock_mode integer
0 ... 2
Oui
innodb_buffer_pool_chunk_size integer
1048576 ... (innodb_buffer_pool_size/innodb_buffer_pool_instances)

Cette valeur d'option dépend de innodb_buffer_pool_size et de innodb_buffer_pool_instances. MySQL peut ajuster automatiquement la valeur de innodb_buffer_pool_chunk_size en fonction de ces deux options.

Oui
innodb_buffer_pool_dump_pct integer
1 ... 100
Par défaut : 25
Non
innodb_buffer_pool_dump_at_shutdown boolean
on | off
Non
innodb_buffer_pool_dump_now boolean
on | off

Consultez la section Conseils pour en savoir plus sur cette option.

Non
innodb_buffer_pool_instances integer
1 ... 64
Oui
innodb_buffer_pool_load_abort boolean
on | off

Consultez la section Conseils pour en savoir plus sur cette option.

Non
innodb_buffer_pool_load_at_startup boolean
on | off
Oui
innodb_buffer_pool_load_now boolean
on | off

Consultez la section Conseils pour en savoir plus sur cette option.

Non
innodb_buffer_pool_size integer

La définition de cette option pour MySQL 5.6 nécessite un redémarrage. Consultez la section Conseils pour plus d'informations sur cette option.

Non
innodb_change_buffer_max_size integer
0 ... 50
Non
innodb_change_buffering string

Options : none, inserts, deletes, changes, purges, all.

Non
innodb_checksum_algorithm string

Options : crc32, strict_crc32, innodb, strict_innod, none, strict_none.

Non
innodb_cmp_per_index_enabled boolean
on | off
Non
innodb_commit_concurrency integer
0 ... 1000
Oui
innodb_compression_failure_threshold_pct integer
0 ... 100
Non
innodb_compression_level integer
0 ... 9
Non
innodb_compression_pad_pct_max integer
0 ... 75
Non
innodb_concurrency_tickets integer
1 ... 4294967295
Non
innodb_deadlock_detect boolean
on | off

Compatible avec MySQL 5.7 et 8.0.

Valeur par défaut : on

Non
innodb_disable_sort_file_cache boolean
on | off
Non
innodb_doublewrite_batch_size integer
0 ... 256
Par défaut : 0
Oui
innodb_doublewrite_files integer
2 ... 128
Oui
innodb_doublewrite_pages integer
4 ... 512
Par défaut : 64
Oui
innodb_file_per_table boolean
on | off

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
innodb_fill_factor integer
10 ... 100
Non
innodb_flush_log_at_timeout double
0.0001... 2700
Par défaut : 1

Compatible avec MySQL 5.7 et 8.0.

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
innodb_flush_log_at_trx_commit integer
1, 2
Par défaut : 1

Si vous promouvez une instance dupliquée avec cette option activée, l'option est automatiquement supprimée, ce qui permet à l'instance dupliquée promue d'être entièrement durable par défaut. Pour utiliser cette option avec un instance répliquée promu,e vous pouvez le mettre à jour sur le réplica après la promotion.

Consultez la section Conseils pour plus d'informations sur cet indicateur.

Non
innodb_flush_neighbors enumeration
0 ... 2

Compatible avec MySQL 5.6, 5.7, 8.0

Valeurs par défaut :

  • MySQL 5.6 : 0
  • MySQL 5.7 : 2
  • MySQL 8.0 : 2
  • Non
    innodb_flush_sync boolean
    on | off
    Non
    innodb_ft_aux_table string

    Consultez la section Conseils pour plus d'informations sur cet indicateur.

    Oui
    innodb_ft_cache_size integer
    1600000 ... 80000000
    Oui
    innodb_ft_enable_diag_print boolean
    on | off
    Non
    innodb_ft_enable_stopword boolean
    on | off
    Non
    innodb_ft_max_token_size integer
    10 ... 252

    Compatible uniquement avec MySQL 5.6 et versions ultérieures.

    Oui
    innodb_ft_min_token_size integer
    0 ... 16

    Compatible uniquement avec MySQL 5.6 et versions ultérieures.

    Oui
    innodb_ft_num_word_optimize integer
    1000 ... 10000
    Non
    innodb_ft_result_cache_limit integer
    1000000 ... 4294967295
    Non
    innodb_ft_server_stopword_table string

    Compatible uniquement avec MySQL 5.6 et versions ultérieures.

    Non
    innodb_ft_sort_pll_degree integer
    1 ... 32
    Oui
    innodb_ft_total_cache_size integer
    32000000 ... 1600000000
    Oui
    innodb_ft_user_stopword_table string Non
    innodb_io_capacity integer
    100 ... 100000
    Par défaut : 5000

    Compatible avec MySQL 5.6, 5.7, 8.0

    Pour en savoir plus sur la configuration des performances des disques, consultez le tableau VM E2 dans la section Configurer des disques pour répondre aux exigences de performances.

    Non
    innodb_io_capacity_max integer
    100 ... 100000
    Par défaut : 10000

    Compatible avec MySQL 5.6, 5.7, 8.0

    Pour en savoir plus sur la configuration des performances des disques, consultez le tableau VM E2 dans la section Configurer des disques pour répondre aux exigences de performances.

    Non
    innodb_large_prefix boolean
    on | off

    Uniquement compatible avec MySQL 5.6.

    Non
    innodb_lock_wait_timeout integer
    1 ... 1073741824
    Non
    innodb_log_buffer_size integer
    262144 ... 4294967295
    Oui
    innodb_log_checksums boolean
    on | off
    par défaut : on
    Non
    innodb_log_compressed_pages boolean
    on | off
    par défaut : on
    Non
    innodb_log_file_size integer
    MySQL 5.6 : 1048576 ... 274877906944
    MySQL 5.7 : 4194304 ... 274877906944
    Oui
    innodb_log_spin_cpu_abs_lwm integer
    0 ... 4294967295
    par défaut : 80
    Non
    innodb_log_spin_cpu_pct_hwm integer
    0 ... 100
    par défaut : 50
    Non
    innodb_log_wait_for_flush_spin_hwm integer
    0 ... 4294967295
    par défaut : 400
    Non
    innodb_log_write_ahead_size integer
    512 ... 65536
    par défaut : 8192
    Non
    innodb_lru_scan_depth integer
    100 ... 9223372036854775807
    Non
    innodb_max_dirty_pages_pct float
    0 ... 99.99
    par défaut : 90
    Non
    innodb_max_dirty_pages_pct_lwm float
    0 ... 99.99
    par défaut : 10
    Non
    innodb_max_purge_lag integer
    0 ... 4294967295
    par défaut : 0
    Non
    innodb_max_undo_log_size integer
    10485760 ... 9223372036854775807
    par défaut : 1073741824
    Non
    innodb_max_purge_lag_delay integer
    0 ... 10000000
    par défaut : 0
    Non
    innodb_monitor_disable string Non
    innodb_monitor_enable string Non
    innodb_monitor_reset string
    counter, module, pattern, all
    Non
    innodb_monitor_reset_all enumeration
    Valeurs valides : counter, module, pattern, all
    Non
    innodb_old_blocks_pct integer
    5 ... 95
    Non
    innodb_old_blocks_time integer
    0 ... 4294967295
    Non
    innodb_online_alter_log_max_size integer
    65536 ... 9223372036854775807
    Non
    innodb_open_files integer
    100 ... 2147483647
    par défaut :
    MySQL 5.7 : 2000
    MySQL 8.0 : 4000
    8.0.28 : Non
    8.0.27 : Oui
    innodb_optimize_fulltext_only boolean
    on | off
    Non
    innodb_page_cleaners integer
    1 ... 64
    Compatible avec MySQL 5.7 et 8.0. Par défaut : 4. Pour la version 5.7, la valeur par défaut est 32.
    Oui
    innodb_parallel_read_threads integer
    1 ... 256
    par défaut : 4
    Non
    innodb_print_all_deadlocks boolean
    on | off
    par défaut : off
    Non
    innodb_print_ddl_logs boolean
    on | off
    Non
    innodb_purge_batch_size integer
    1 ... 5000
    par défaut : 300
    Non
    innodb_purge_rseg_truncate_frequency integer
    1 ... 128
    par défaut : 128
    Non
    innodb_purge_threads 1 ... 32

    Compatible avec MySQL 5.6, 5.7, 8.0

    La valeur par défaut est 1.

    Oui
    innodb_random_read_ahead boolean
    on | off
    Non
    innodb_read_ahead_threshold integer
    0 ... 64
    Non
    innodb_read_io_threads integer
    1 ... 64
    Oui
    innodb_replication_delay integer
    0 ... 4294967295
    Non
    innodb_rollback_on_timeout boolean
    on | off
    Oui
    innodb_rollback_segments integer
    1 ... 128
    Non
    innodb_segment_reserve_factor float
    .03 ... 40
    par défaut : 12.5
    Non
    innodb_sort_buffer_size integer
    65536 ... 67108864
    Oui
    innodb_spin_wait_delay integer
    MySQL 5.7 : 0 ... 1000000
    MySQL 8.0.13+ : 0 ... 1000
    par défaut : 6
    Non
    innodb_stats_auto_recalc boolean
    on | off
    Non
    innodb_stats_include_delete_marked boolean
    on | off
    par défaut : off
    Non
    innodb_stats_method enumeration
    nulls_equal | nulls_unequal | nulls_ignored
    Non
    innodb_stats_on_metadata boolean
    on | off
    Non
    innodb_stats_persistent boolean
    on | off
    Non
    innodb_stats_persistent_sample_pages integer
    1 ... 9223372036854775807
    Non
    innodb_stats_sample_pages integer
    1 ... 9223372036854775807
    Non
    innodb_stats_transient_sample_pages integer
    1 ... 9223372036854775807
    Non
    innodb_status_output boolean
    on | off
    Non
    innodb_status_output_locks boolean
    on | off
    Non
    innodb_strict_mode boolean
    on | off
    Non
    innodb_sync_array_size 1 ... 1024

    Compatible avec MySQL 5.6, 5.7, 8.0

    La valeur par défaut est 1.

    Oui
    innodb_sync_spin_loops integer
    0 ... 4294967295
    par défaut : 30
    Non
    innodb_table_locks boolean
    on | off
    par défaut : on
    Non
    innodb_thread_concurrency integer
    0 ... 1000
    Non
    innodb_thread_sleep_delay integer
    0 ... 1000000
    Non
    innodb_undo_log_truncate boolean
    on | off
    par défaut : on
    Non
    innodb_use_native_aio boolean
    on | off
    par défaut : on
    Oui
    innodb_write_io_threads integer
    1 ... 64
    Oui
    interactive_timeout integer
    1 ... 31536000
    Non
    internal_tmp_disk_storage_engine enumeration
    INNODB | MYISAM
    Par défaut : INNODB
    Cette option n'est utilisée que pour MySQL 5.7.
    Non
    internal_tmp_mem_storage_engine enumeration
    MEMORY, TempTable
    Cette option n'est utilisée que pour MySQL 8.0.
    Non
    join_buffer_size integer
    128 ... 9223372036854775807
    Non
    keep_files_on_create boolean
    on | off
    par défaut : off
    Non
    key_buffer_size integer
    4096 ... 4294967295
    par défaut : 8388608
    Non
    key_cache_age_threshold integer
    100 ... 9223372036854775807
    par défaut : 300
    Non
    key_cache_block_size integer
    512 ... 16384
    par défaut : 1024
    Non
    key_cache_division_limit integer
    1 ... 100
    par défaut : 100
    Non
    lc_times_names string
    en_US | cs_CZ | da_DK | nl_NL | et_EE | fr_FR | de_DE | el_GR | hu_HU | it_IT | ja_JP | ko_KR | no_NO | nb_NO | pl_PL | pt_PT | ro_RO | ru_RU | sr_RS | sk_SK | es_ES | sv_SE | uk_UA
    par défaut : en_US
    Non
    local_infile boolean
    on | off
    Non
    lock_wait_timeout integer
    1 ... 31536000
    Non
    log_bin_trust_function_creators boolean
    on | off
    Non
    log_output set
    FILE | TABLE | NONE
    Non
    log_error_verbosity integer
    1 ... 3
    par défaut :
    MySQL 5.7 : 3
    MySQL 8.0 : 2
    Non
    log_queries_not_using_indexes boolean
    on | off
    Non
    log_slow_admin_statements boolean
    on | off
    par défaut : off
    Non
    log_slow_extra boolean
    on | off
    par défaut : off
    Non
    log_slow_replica_statements boolean
    on | off Par défaut : off
    Non
    log_slow_slave_statements boolean
    on | off Par défaut : off
    Non
    log_throttle_queries_not_using_indexes integer
    0 ... 9223372036854775807
    Non
    log_timestamps string
    "UTC | SYSTEM"
    par défaut : UTC
    Non
    long_query_time float
    0 ... 30000000

    Cloud SQL autorise à définir cet indicateur avec une valeur inférieure à 1 si nécessaire.

    Si l'indicateur log_queries_not_using_indexes est également activé, vous pouvez voir des requêtes dont la durée est inférieure à celle spécifiée ici.

    Non
    lower_case_table_names 5.7 | 8.0 integer
    0 ou 1
    Par défaut : 0

    Si vous utilisez la valeur par défaut de 0 pour cette option, les noms de table et de base de données sont sensible à la casse. Si la valeur est 1, les noms de table et de base de données ne sont pas sensibles à la casse.

    Pour les instances MySQL 5.7, vous pouvez modifier la valeur de cette option à tout moment. Dans ce cas, assurez-vous de bien comprendre l'impact de ce changement sur les tables et bases de données existantes.

    Pour les instances MySQL 8.0, vous ne pouvez définir la valeur de cette option que sur la valeur souhaitée pendant la création d'une instance. Une fois cette valeur définie, vous ne pouvez pas la modifier. De plus, pour une instance existante, vous ne pouvez pas modifier la valeur de cette option.

    Lorsque vous créez des instances répliquées avec accès en lecture pour MySQL 5.7 ou MySQL 8.0, l'instance répliquée hérite de cette valeur d'option de l'instance principale.

    Oui
    mandatory_roles string role name
    Par défaut : empty string
    Non
    master_verify_checksum boolean
    on | off Par défaut : off
    Non
    max_allowed_packet integer
    16384 ... 1073741824

    Cette valeur doit être un multiple de 1 024, si sql_mode=TRADITIONAL ou sql_mode=STRICT_ALL_TABLES.

    Non
    max_binlog_cache_size integer
    4096 ... 4294967296
    par défaut : 4294967296
    Non
    max_binlog_size integer
    4096 ... 1073741824
    Non
    max_binlog_stmt_cache_size integer
    4096 ... 4294967296
    par défaut : 4294967296
    Non
    max_connect_errors integer
    1 ... 9223372036854775807
    par défaut : 100
    Non
    max_connections integer
    1 ... 100000
    Non
    max_digest_length integer
    0 ... 1048576
    Oui
    max_error_count integer
    0 ... 65535
    par défaut :
    MySQL 5.7 ou version antérieure : 64
    MySQL 8.0+ : 1024
    Non
    max_execution_time integer
    0 ... 9223372036854775807
    Non
    max_heap_table_size integer
    16384 ... 67108864

    Consultez la section Conseils pour plus d'informations sur cet indicateur.

    Non
    max_join_size integer
    16 ... 9223372036854775807
    Non
    max_length_for_sort_data integer
    4 ... 8388608
    Non
    max_points_in_geometry integer
    3 ... 1048576
    Non
    max_prepared_stmt_count integer
    0 ... 1048576
    Non
    max_seeks_for_key integer
    1 ... 9223372036854775807
    Non
    max_sort_length integer
    4 ... 8388608
    Non
    max_sp_recursion_depth integer
    0 ... 255
    Non
    max_user_connections integer
    0 ... 4294967295
    Non
    max_write_lock_count integer
    1 ... 9223372036854775807
    Non
    min_examined_row_limit integer
    0 ... 4294967295
    par défaut : 0
    Non
    myisam_data_pointer_size integer
    2...7
    Par défaut : 6
    Non
    myisam_max_sort_file_size integer
    0...9223372036853727232
    Par défaut : 9223372036853727232
    Non
    myisam_mmap_size integer
    7...9223372036854775807
    Par défaut : 9223372036854775807
    Oui
    myisam_sort_buffer_size integer
    4096...4294967295
    Par défaut : 8388608
    Non
    myisam_stats_method string
    "nulls_unequal, nulls_equal, nulls_ignored"
    par défaut : nulls_unequal
    Non
    myisam_use_mmap boolean
    on | off
    par défaut : off
    Non
    mysql_native_password_proxy_users boolean
    on | off
    par défaut : off
    Non
    net_buffer_length integer
    1024 ... 1048576
    par défaut : 16384
    Non
    net_read_timeout integer
    30 ... 4294967295
    Non
    net_retry_count integer
    10 ... 4294967295
    Non
    net_write_timeout integer
    60 ... 4294967295
    Non
    ngram_token_size integer
    1 ... 10
    par défaut : 2
    Oui
    optimizer_prune_level integer
    0 ... 1
    Non
    optimizer_search_depth integer
    0 ... 62
    Non
    optimizer_switch multi-value repeated string

    Consultez la section Conseils pour en savoir plus sur les options à valeurs multiples.

    Non
    optimizer_trace multi-value repeated string
    enabled=on, enabled=off, one_line=on, one_line=off

    Consultez la section Conseils pour plus d'informations sur les options à valeurs multiples.

    Non
    optimizer_trace_features multi-value repeated string

    Consultez la section Conseils pour en savoir plus sur les options à valeurs multiples.

    Non
    optimizer_trace_max_mem_size integer
    0 ... 9223372036854775807
    Non
    optimizer_trace_offset integer
    -9223372036854775808 ... 9223372036854775807
    Non
    parser_max_mem_size integer
    10000000 ... 9223372036854775807
    Non
    password_history integer 0-4294967295
    Par défaut : 0
    Non
    password_require_current boolean on | off
    Par défaut : off
    Non
    password_reuse_interval integer 0-4294967295
    Par défaut : 0
    Non
    performance_schema boolean
    on | off

    Valeur par défaut : off, pour MySQL 5.6, 5.7 et pour 8.0 si la mémoire RAM de l'instance est inférieure à 15 Go.

    Valeur par défaut : on, pour MySQL 8.0 si la mémoire RAM de l'instance est supérieure à 15 Go

    Consultez la section Conseils pour en savoir plus sur les indicateurs performance_schema.

    Oui
    performance_schema_accounts_size integer
    -1 ... 1048576

    Consultez la section Conseils pour en savoir plus sur les indicateurs performance_schema.

    Oui
    performance_schema_digests_size integer
    -1 ... 1048576

    Consultez la section Conseils pour en savoir plus sur les indicateurs performance_schema.

    Oui
    performance_schema_error_size integer
    0 ... 1048576
    Oui
    performance_schema_events_stages_history_long_size integer
    -1 ... 1048576
    Oui
    performance_schema_events_stages_history_size integer
    -1 ... 1024

    Consultez la section Conseils pour en savoir plus sur les indicateurs performance_schema.

    Oui
    performance_schema_events_statements_history_long_size integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_events_statements_history_size integer
    -1 ... 1024

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_events_transactions_history_long_size integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_events_transactions_history_size integer
    -1 ... 1024

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_events_waits_history_long_size integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_events_waits_history_size integer
    -1 ... 1024

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_hosts_size integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_cond_classes integer
    0 ... 256

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_cond_instances integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_digest_length integer
    0 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_digest_sample_age integer
    0 ... 1048576
    par défaut : 60
    Non
    performance_schema_max_file_classes integer
    0 ... 256

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_file_handles integer
    0 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_file_instances integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_index_stat integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_memory_classes integer
    0 ... 1024

    Consultez la section Conseils pour en savoir plus sur les indicateurs performance_schema.

    Oui
    performance_schema_max_metadata_locks integer
    -1 ... 104857600

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_mutex_classes integer
    0 ... 256

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_mutex_instances integer
    -1 ... 104857600

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_prepared_statements_instances integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_program_instances integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_rwlock_classes integer
    0 ... 256

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_rwlock_instances integer
    -1 ... 104857600

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_socket_classes integer
    0 ... 256

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_socket_instances integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_sql_text_length integer
    0 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_stage_classes integer
    0 ... 256

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_statement_classes integer
    0 ... 256

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_statement_stack integer
    1 ... 256

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_table_handles integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_table_instances integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_table_lock_stat integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_thread_classes integer
    0 ... 256

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_max_thread_instances integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_session_connect_attrs_size integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_setup_actors_size integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_setup_objects_size integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    performance_schema_users_size integer
    -1 ... 1048576

    Consultez la section Conseils pour plus d'informations sur les indicateurs performance_schema.

    Oui
    preload_buffer_size integer
    1024 ... 1073741824
    par défaut : 32768
    Non
    query_alloc_block_size integer
    1024 ... 4294967295
    Non
    query_cache_limit integer
    0 ... 223338299392

    Cette option n'est pas disponible pour MySQL 8.0, car le cache de requêtes est devenu obsolète à partir de MySQL 5.7.20 et a été supprimé dans MySQL 8.0.

    Non
    query_cache_min_res_unit integer
    0 ... 9223372036854775807

    Cette option n'est pas disponible pour MySQL 8.0, car le cache de requêtes est devenu obsolète à partir de MySQL 5.7.20 et a été supprimé dans MySQL 8.0.

    Non
    query_cache_size integer
    0 ... 223338299392

    Cette option n'est pas disponible pour MySQL 8.0, car le cache de requêtes est devenu obsolète à partir de MySQL 5.7.20 et a été supprimé dans MySQL 8.0.

    Non
    query_cache_type enumeration
    0 ... 2

    Cette option n'est pas disponible pour MySQL 8.0, car le cache de requêtes est devenu obsolète à partir de MySQL 5.7.20 et a été supprimé dans MySQL 8.0.

    Oui
    query_cache_wlock_invalidate boolean
    on | off

    Cette option n'est pas disponible pour MySQL 8.0, car le cache de requêtes est devenu obsolète à partir de MySQL 5.7.20 et a été supprimé dans MySQL 8.0.

    Non
    query_prealloc_size integer
    8192 ... 9223372036854775807
    Non
    range_alloc_block_size integer
    4096 ... 4294967295
    Non
    range_optimizer_max_mem_size integer
    0 ... 9223372036854775807
    Non
    read_buffer_size integer
    8192 ... 2147483647
    Non
    read_only boolean
    on | off

    Aucun effet sur les instances dupliquées.

    Non
    read_rnd_buffer_size integer
    1 ... 2147483647
    Non
    regexp_stack_limit integer
    0 ... 2147483647
    Non
    regexp_time_limit integer
    0 ... 2147483647
    par défaut : 32
    Non
    replica_checkpoint_group integer
    32 ... 524280
    La valeur par défaut est 512.

    Cette option n'affecte pas les instances dupliquées pour lesquelles le multithreading n'est pas activé.

    Non
    replica_checkpoint_period integer
    1 ... 4294967295
    La valeur par défaut est 300.

    Cette valeur est exprimée en millisecondes.

    Non
    replica_compressed_protocol boolean
    on | off
    Non
    replica_net_timeout integer
    1 ... 31536000

    Cette valeur est exprimée en secondes.

    Non
    replica_parallel_type enumeration
    DATABASE, LOGICAL_CLOCK
    Par défaut :
    MySQL 8.0.26 ou version antérieure : DATABASE
    MySQL 8.0.27 ou version ultérieure : LOGICAL_CLOCK

    Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

    Non
    replica_parallel_workers integer

    Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

    Non
    replica_pending_jobs_size_max integer

    Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

    Non
    replica_preserve_commit_order boolean

    Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

    Non
    replica_skip_errors string
    Par défaut : OFF

    Pour en savoir plus sur cette option consultez la section Conseils.

    Oui
    replica_sql_verify_checksum boolean
    on | off
    Non
    replica_transaction_retries integer
    0 ... 9223372036854775807
    Non
    replica_type_conversions String
    Valeurs : ALL_LOSSY, ALL_NON_LOSSY, ALL_SIGNED, ALL_UNSIGNED
    Non
    replicate_do_db string

    Pour en savoir plus sur l'utilisation de cette option, consultez la section Filtres de réplication.

    Non
    replicate_do_table string

    Pour en savoir plus sur l'utilisation de cette option, consultez la section Filtres de réplication.

    Non
    replicate_ignore_db string

    Pour en savoir plus sur l'utilisation de cette option, consultez la section Filtres de réplication.

    Non
    replicate_ignore_table string

    Pour en savoir plus sur l'utilisation de cette option, consultez la section Filtres de réplication.

    Non
    replicate_wild_do_table string

    Pour en savoir plus sur l'utilisation de cette option, consultez la section Filtres de réplication.

    Non
    replicate_wild_ignore_table string

    Pour en savoir plus sur l'utilisation de cette option, consultez la section Filtres de réplication.

    Non
    rpl_read_size integer
    8192 ... 4294959104
    par défaut : 8192
    Non
    schema_definition_cache integer
    256 ... 524288
    par défaut : 256
    Non
    session_track_gtids string
    OFF | OWN_GTID | ALL_GTIDS
    par défaut : OFF
    Non
    session_track_schema boolean
    on | off
    par défaut : on
    Non
    session_track_state_change boolean
    on | off
    par défaut : off
    Non
    session_track_transaction_info string
    OFF | STATE | CHARACTERISTICS
    par défaut : OFF
    Non
    sha256_password_proxy_users boolean
    on | off
    par défaut : off
    Non
    show_create_table_verbosity boolean
    on | off
    par défaut : off
    Non
    show_compatibility_56 boolean
    on | off

    Uniquement compatible avec MySQL 5.7.

    Non
    skip_character_set_client_handshake boolean
    on | off
    par défaut : off
    Oui
    skip_show_database flag
    on | off
    Oui
    slave_checkpoint_group integer
    32 ... 524280
    La valeur par défaut est 512.

    Cette option n'affecte pas les instances dupliquées pour lesquelles le multithreading n'est pas activé.

    Non
    slave_checkpoint_period integer
    1 ... 4294967295
    La valeur par défaut est 300.

    Cette valeur est exprimée en millisecondes.

    Non
    slave_compressed_protocol boolean
    on | off
    Non
    slave_net_timeout integer
    1 ... 31536000

    Cette valeur est exprimée en secondes.

    Non
    slave_parallel_type enumeration
    DATABASE, LOGICAL_CLOCK
    Par défaut :
    MySQL 8.0.26 ou version antérieure : DATABASE
    MySQL 8.0.27 ou version ultérieure : LOGICAL_CLOCK

    Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

    Non
    slave_parallel_workers integer

    Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

    Non
    slave_preserve_commit_order boolean

    Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

    Non
    slave_pending_jobs_size_max integer

    Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

    Non
    slave_skip_errors string
    Par défaut : OFF

    Pour en savoir plus sur cette option, consultez la section Conseils.

    Oui
    slave_sql_verify_checksum boolean
    on | off
    Non
    slave_transaction_retries integer
    0 ... 9223372036854775807
    Non
    slave_type_conversions string
    Valeurs : ALL_LOSSY, ALL_NON_LOSSY, ALL_SIGNED, ALL_UNSIGNED
    Non
    slow_launch_time Integer
    0 ... 31536000
    Par défaut : 2
    Non
    slow_query_log boolean
    on | off

    Consultez la section Conseils pour plus d'informations sur les journaux de requêtes lentes.

    Non
    sort_buffer_size integer
    32768 ... 9223372036854775807
    Non
    source_verify_checksum boolean
    on | off
    Par défaut : off
    Non
    sql_mode string

    Consultez la page sur les modes SQL du serveur dans la documentation MySQL pour connaître les valeurs autorisées, y compris pour les modes combinés tels que ANSI. NO_DIR_IN_CREATE n'est pas accepté.

    Cloud SQL pour MySQL n'accepte pas de valeurs vides pour l'option sql_mode. Au lieu d'utiliser une valeur vide, définissez cette option sur le mode NO_ENGINE_SUBSTITUTION.

    Non
    sql_require_primary_key boolean
    on | off
    Par défaut : off
    Non
    sql_select_limit integer 0...18446744073709551615
    Par défaut : 18446744073709551615

    Consultez la section Conseils pour plus d'informations sur cet indicateur.

    Non
    stored_program_cache integer
    16 ... 524288
    Non
    stored_program_definition_cache integer
    256 ... 524288
    Par défaut : 256
    Non
    sync_binlog integer
    0 ... 4294967295

    La valeur 1 par défaut active la synchronisation du journal binaire sur le disque avant le commit des transactions.

    Si vous promouvez une instance dupliquée avec cette option activée, l'option est automatiquement supprimée, ce qui permet à l'instance dupliquée promue d'être entièrement durable par défaut. Pour utiliser cette option avec un instance répliquée promu,e vous pouvez le mettre à jour sur le réplica après la promotion.

    Consultez la section Conseils pour plus d'informations sur cet indicateur.

    Non
    sync_master_info integer
    0 ... 4294967295
    Par défaut : 10000
    Non
    sync_relay_log integer
    0 ... 4294967295
    Par défaut : 10000
    Non
    sync_relay_log_info integer
    0 ... 4294967295
    Par défaut : 10000
    Non
    sync_source_info integer
    0 ... 4294967295
    Par défaut : 10000
    Non
    sysdate_is_now boolean
    on | off
    par défaut : off
    Oui
    table_definition_cache integer
    400 ... 524288
    Non
    tablespace_definition_cache integer
    256 ... 524288
    Par défaut : 256
    Non
    table_open_cache integer
    1 ... 524288
    Non
    table_open_cache_instances integer
    1 ... 64
    Oui
    temptable_max_mmap integer
    0 ... 68719476736
    Par défaut : 1073741824
    Non
    temptable_max_ram integer
    2097152 ... 68719476736
    Par défaut : 1073741824
    Non
    thread_cache_size integer
    0 ... 16384
    Non
    thread_stack integer
    131072 ... 9223372036854775807
    Oui
    tls_version String

    Version 5.7 à 8.0.27 : TLSv1, TLSv1.1
    Version 8.0.28 ou ultérieure : TLSv1.2
    Version 5.7 : Oui

    Version 8.0 ou ultérieure : Non
    tmp_table_size integer
    1024 ... 67108864

    Consultez la section Conseils pour plus d'informations sur cet indicateur.

    Non
    transaction_alloc_block_size integer
    1024 ... 131072
    Non
    transaction_isolation enumeration
    READ-UNCOMMITTED | READ-COMMITTED | REPEATABLE-READ | SERIALIZABLE
    Oui
    transaction_prealloc_size integer
    1024 ... 131072
    Non
    transaction_write_set_extraction enumeration

    Pour savoir comment utiliser cet indicateur et les valeurs qu'il accepte, consultez Configurer la réplication parallèle.

    Non
    unique_checks boolean
    on | off
    Par défaut : on

    Consultez la section Conseils pour plus d'informations sur cet indicateur.

    Non
    updatable_views_with_limit integer
    0 ... 1
    Non
    wait_timeout integer
    1 ... 31536000
    Non
    windowing_use_high_precision boolean
    on | off
    Par défaut : on
    Non

    Noms de fuseaux horaires

    Dans cette section, vous allez découvrir les noms de fuseaux horaires compatibles avec Cloud SQL pour MySQL.

    Le tableau de cette section affiche les éléments suivants :

    • Nom de fuseau horaire : nom accepté par Cloud SQL pour MySQL.
    • STD (Standard Time) : décalage de fuseau horaire à l'heure standard.
    • DST (Daylight Savings Time) : décalage de fuseau horaire à l'heure d'été.
    • Noms synonymes : noms des fuseaux horaires que vous souhaitez utiliser, mais qui ne sont pas pris en charge par Cloud SQL pour MySQL. Dans ce cas, utilisez le nom du fuseau horaire correspondant.
    nom de fuseau horaire STD DST Noms synonymes
    Africa/Cairo +02:00 +02:00 Égypte
    Africa/Casablanca +01:00 +00:00
    Africa/Harare +02:00 +02:00 Africa/Maputo
    Africa/Monrovia +00:00 +00:00
    Africa/Nairobi +03:00 +03:00 Africa/Addis_Ababa
    Africa/Asmera
    Africa/Dar_es_Salaam
    Africa/Djibouti
    Africa/Kampala
    Africa/Mogadishu
    Indian/Antananarivo
    Indian/Comoro
    Indian/Mayotte
    Africa/Tripoli +02:00 +02:00 Libye
    Africa/Windhoek +02:00 +02:00
    America/Araguaina −03:00 −03:00
    America/Asuncion −04:00 −03:00
    America/Bogota −05:00 −05:00
    America/Buenos_Aires −03:00 −03:00 America/Argentina/Buenos_Aires
    America/Caracas −04:00 −04:00
    America/Chicago −06:00 −05:00
    America/Chihuahua −07:00 −06:00 America/Ojinaga
    America/Cuiaba −04:00 −04:00
    America/Denver −07:00 −06:00 America/Shiprock
    Navajo
    MST7MDT
    US/Mountain
    America/Detroit −05:00 −04:00
    America/Fortaleza −03:00 −03:00
    America/Guatemala −06:00 −06:00
    America/Halifax −04:00 −03:00 Canada/Atlantic
    America/Los_Angeles −08:00 −07:00
    America/Manaus −04:00 −04:00 Brazil/West
    America/Matamoros −06:00 −05:00
    America/Mexico_City −06:00 −05:00
    America/Monterrey −06:00 −05:00
    America/Montevideo −03:00 −03:00
    America/New_York −05:00 −04:00
    America/Phoenix −07:00 −07:00 US/Arizona
    MST
    America/Creston
    America/Santiago −04:00 −03:00 Chile/Continental
    America/Sao_Paolo −03:00 −03:00
    America/Tijuana −08:00 −07:00 Mexico/BajaNorte
    America/Ensenada
    America/Santa_Isabel
    Asia/Amman +02:00 +03:00
    Asia/Ashgabat +05:00 +05:00 Asia/Ashkhabad
    Asia/Baghdad +03:00 +03:00
    Asia/Baku +04:00 +04:00
    Asia/Bangkok +07:00 +07:00 Asia/Phnom_Penh
    Asia/Vientiane
    Asia/Beirut +02:00 +03:00
    Asia/Calcutta +05:30 +05:30 Asia/Kolkata
    Asia/Damascus +02:00 +03:00
    Asia/Dhaka +06:00 +06:00 Asia/Dacca
    Asia/Irkutsk +08:00 +08:00
    Asia/Jerusalem +02:00 +03:00 Asia/Tel_Aviv
    Israel
    Asia/Kabul +04:30 +04:30
    Asia/Karachi +05:00 +05:00
    Asia/Kathmandu +05:45 +05:45 Asia/Katmandu
    Asia/Kolkata +05:30 +05:30
    Asia/Krasnoyarsk +07:00 +07:00
    Asia/Magadan +11:00 +11:00
    Asia/Muscat +04:00 +04:00 Asia/Dubai
    Asia/Novosibirsk +07:00 +07:00
    Asia/Riyadh +03:00 +03:00 Asia/Kuwait
    Antarctica/Syowa
    Asia/Aden
    Asia/Seoul +09:00 +09:00 ROK
    Asia/Shanghai +08:00 +08:00 Asia/Chongqing
    Asia/Chungking
    Asia/Harbin
    PRC
    Asia/Singapore +08:00 +08:00 Singapour
    Asia/Taipei +08:00 +08:00 ROC
    Asia/Tehran +03:30 +04:30 Iran
    Asia/Tokyo +09:00 +09:00 Japon
    Asia/Ulaanbaatar +08:00 +08:00 Asia/Ulan_Bator
    Asia/Vladivostok +10:00 +10:00
    Asia/Yakutsk +09:00 +09:00
    Asia/Yerevan +04:00 +04:00
    Atlantic/Azores −01:00 +00:00
    Australia/Adelaide +09:30 +10:30 Australia/South
    Australia/Brisbane +10:00 +10:00 Australia/Queensland
    Australia/Darwin +09:30 +09:30 Australia/North
    Australia/Hobart +10:00 +11:00 Australia/Currie
    Australia/Tasmania
    Australia/Perth +08:00 +08:00 Australia/West
    Australia/Sydney +10:00 +11:00 Australia/NSW
    Australia/ACT
    Australia/Canberra
    Brazil/East −03:00 −03:00 America/Sao_Paulo
    Canada/Newfoundland −03:30 −02:30 America/St_Johns
    Canada/Saskatchewan −06:00 −06:00 America/Regina
    Canada/Yukon −07:00 −07:00 America/Whitehorse
    Europe/Amsterdam +01:00 +02:00
    Europe/Athens +02:00 +03:00
    Europe/Dublin +01:00 +00:00 Eire
    Europe/Helsinki +02:00 +03:00 Europe/Mariehamn
    Europe/Istanbul +03:00 +03:00 Turkey
    Asia/Istanbul
    Europe/Kaliningrad +02:00 +02:00
    Europe/Madrid +01:00 +02:00
    Europe/Moscow +03:00 +03:00 W-SU
    Europe/Paris +01:00 +02:00 MET
    CET
    Europe/Prague +01:00 +02:00 Europe/Bratislava
    Europe/Sarajevo +01:00 +02:00 Europe/Belgrade
    Europe/Ljubljana
    Europe/Podgorica
    Europe/Skopje
    Europe/Zagreb
    Pacific/Auckland +12:00 +13:00 NZ
    Antarctica/McMurdo
    Antarctica/South_Pole
    Pacific/Fiji +12:00 +13:00
    Pacific/Guam +10:00 +10:00 Pacific/Saipan
    Pacific/Honolulu −10:00 −10:00 US/Hawaii
    Pacific/Johnston
    HST
    Pacific/Samoa −11:00 −11:00 Pacific/Pago_Pago
    US/Samoa
    US/Alaska −09:00 −08:00 America/Anchorage
    America/Juneau
    America/Metlakatla
    America/Nome
    America/Sitka
    America/Yakutat
    US/Central −06:00 −05:00 America/Chicago
    US/Eastern −05:00 −04:00 America/New_York
    US/East-Indiana −05:00 −04:00 America/Indiana/Indianapolis
    America/Indianapolis
    America/Fort_Wayne
    US/Mountain −07:00 −06:00 America/Denver
    US/Pacific −08:00 −07:00 America/Los_Angeles
    UTC +00:00 +00:00 Etc/UTC
    Etc/UCT
    Etc/Universal
    Etc/Zulu

    Les tables de fuseau horaire dans Cloud SQL doivent peut-être être actualisées avec les dernières données. Par exemple, un pays peut passer d'un fuseau horaire DST à un décalage DST ou un pays peut introduire un nouveau fuseau horaire.

    Pour chaque version d'agent de service critique (CSA) de Cloud SQL, les tables de fuseau horaire sont actualisées avec les dernières données. Dans ce cas, les instances répliquées sont actualisées pendant l'intervalle hors maintenance. Les instances principales sont ensuite actualisées pendant l'intervalle de maintenance.

    Vous pouvez attendre l'intervalle de maintenance standard de la version de l'agent de service critique ou procéder à une maintenance en libre-service pour actualiser les tables de fuseau horaire avec les dernières données. Pour en savoir plus sur l'affichage des versions de maintenance disponibles, consultez Déterminer la version de maintenance cible.

    Conseils pour l'utilisation d'indicateurs

    general_log, slow_query_log

    Pour que vos journaux general ou slow query soient disponibles, activez l'option correspondante et définissez l'option log_output sur FILE. De cette façon, la sortie du journal sera disponible dans la visionneuse de journaux de la console Google Cloud. Notez que les frais de journalisation de Google Cloud Observability s'appliquent. Afin de réduire les coûts de stockage des instances, les journaux general et slow query stockés sur le disque de l'instance font l'objet d'une rotation lorsque l'âge du fichier journal dépasse 24 heures (et qu'aucune modification n'a été effectuée pendant cette période) ou sa taille est supérieure à 100 Mo. Les anciens fichiers journaux sont automatiquement supprimés après la rotation.

    Si log_output est défini sur NONE, vous ne pouvez pas accéder aux journaux. Si vous définissez log_output sur TABLE, la sortie du journal est placée dans une table de la base de données système mysql. Cela peut conduire à utiliser une quantité considérable d'espace disque. Si cette table devient trop volumineuse, cela peut affecter le temps de redémarrage de l'instance ou compromettre sa couverture par le contrat de niveau de service. Pour cette raison, l'option TABLE n'est pas recommandée. De plus, le contenu de ces journaux n'est pas disponible dans l'explorateur de journaux et ne fait pas l'objet d'une rotation. Si nécessaire, vous pouvez tronquer vos tables de journal à l'aide de l'API. Pour plus d'informations, consultez la page de la documentation de référence sur la méthode instances.truncateLog.

    expire_logs_days, binlog_expire_logs_seconds
    Si vous activez la récupération à un moment précis, la période d'expiration de vos journaux binaires est déterminée par la valeur la plus faible entre la durée de conservation du journal des transactions et les valeurs de ces options. Vous pouvez utiliser ces options pour gérer la durée de stockage des journaux binaires sur vos instances dupliquées. Pour plus d'informations, consultez la page Conservation des journaux de transactions.
    innodb_buffer_pool_size

    La valeur de "innodb_buffer_pool_size" correspond à la taille, en octets, du pool de mémoire tampon. Vous ne pouvez pas activer cet indicateur sur des instances disposant de moins de 3 840 Mio de RAM.

    Cette option n'est pas configurable pour les types de machines à cœur partagé (f1_micro et g1_small). La modification de cette option sur MySQL 5.6 nécessite un redémarrage.

    Dans Cloud SQL, les valeurs par défaut, minimales et maximales autorisées de l'option "innodb_buffer_pool_size" dépendent de la mémoire de l'instance. Ces valeurs peuvent être calculées de manière approximative sous forme de pourcentage de la mémoire RAM de l'instance. Par défaut, la valeur de cette option est généralement définie sur la valeur maximale autorisée. Le pourcentage d'allocation maximal autorisé augmente avec la taille de l'instance. La valeur minimale autorisée correspond généralement à environ 20 % de la mémoire RAM de l'instance.

    Valeurs approximatives pour cette option :

    Plage de la mémoire RAM de l'instance% min.% par défaut% max.
    0 — 4,0 Go de RAM~34 %
    4,0 Go — 7,5 Go~20 %~34 %~34 %
    7,5 Go — 12 Go~20 %~52 %~52 %
    12 Go — 24 Go~20 %~67 %~67 %
    24 Go et plus~20 %~72 %~72 %

    Vos valeurs exactes peuvent varier. Pour calculer la valeur actuelle de votre instance, vous pouvez exécuter la requête suivante :

      show global variables like 'innodb_buffer_pool_size';
      

    Pour référence, les valeurs par défaut, minimales et maximales autorisées sont fournies pour les types de machines ci-dessous.

    Type de machine RAM d'instance (Go) Min. (Go)
    (% du total)
    Par défaut (Go)
    (% du total)
    Max. (Go)
    (% du total)
    db-f1-micro 0,6 - 0,053 -
    db-g1-small 1,7 - 0,625 -
    db-custom-1-3840 3,75 0,875
    (23 %)
    1,375
    (37 %)
    1,375
    (37 %)
    db-custom-2-7680 7,5 1,5
    (20 %)
    4
    (53 %)
    4
    (53 %)
    db-custom-4-15360 15 3
    (20 %)
    10,5
    (70 %)
    10,5
    (70 %)
    db-custom-8-30720 30 6
    (20 %)
    22
    (73 %)
    22
    (73 %)
    db-custom-16-61440 60 12
    (20 %)
    44
    (73 %)
    44
    (73 %)
    db-custom-32-122880 120 24
    (20 %)
    87
    (73 %)
    87
    (73 %)
    db-custom-64-245760 240 48
    (20 %)
    173
    (72 %)
    173
    (72 %)
    db-custom-96-368640 360 72
    (20 %)
    260
    (72 %)
    260
    (72 %)
    db-custom-2-13312 13 3
    (23 %)
    9
    (69 %)
    9
    (69 %)
    db-custom-4-26624 26 6
    (23 %)
    19
    (73 %)
    19
    (73 %)
    db-custom-8-53248 52 11
    (21 %)
    38
    (73 %)
    38
    (73 %)
    db-custom-16-106496 104 21
    (20 %)
    75
    (72 %)
    75
    (72 %)
    db-custom-32-212992 208 42
    (20 %)
    150
    (72 %)
    150
    (72 %)
    db-custom-64-425984 416 84
    (20 %)
    300
    (72 %)
    300
    (72 %)
    db-custom-96-638976 624 125
    (20 %)
    450
    (72 %)
    450
    (72 %)

    innodb_file_per_table

    Pour toutes les versions MySQL 5.6 et ultérieures, la valeur par défaut est ON.

    innodb_flush_log_at_trx_commit, sync_binlog
    Pour assurer la conformité totale aux normes ACID et pour maintenir la durabilité et la cohérence d'une configuration de réplication, les options innodb_flush_log_at_trx_commit et sync_binlog doivent être définies sur la valeur par défaut 1. Si vous modifiez la valeur par défaut, alors la durabilité peut diminuer, ce qui peut entraîner une incohérence entre l'instance principale et les instances répliquées. Par conséquent, l'instance perd sa couverture par le contrat de niveau de service. En outre, l'un des événements suivants peut se produire :
    • Perte de données dans certaines situations, telles qu'un plantage ou un basculement de VM pour une instance régionale à haute disponibilité
    • Désynchronisation des données dans le journal binaire et les fichiers de données InnoDB
    • Perte de données ou échec PITR
    • Incohérence des données entre une instance principale et ses instances répliquées
    • Une interruption de la réplication

    En définissant la valeur du paramètre innodb_flush_log_at_trx_commit ou sync_binlog sur des valeurs autres que celles par défaut pour les instances principales, autonomes et haute disponibilité réduit la durabilité.

    Si vous avez besoin de performances plus élevées pour les instances répliquées avec accès en lecture, nous vous recommandons de définir la valeur innodb_flush_log_at_trx_commit sur 2. Cloud SQL ne permet pas de définir la valeur de cette option sur 0. Si vous définissez la valeur de l'option sur 2, vous devez désactiver le journal binaire sur l'instance dupliquée, ou définir sync_binlog sur une valeur autre que 1 pour obtenir des performances supérieures.

    Cloud SQL peut temporairement remplacer les valeurs des options innodb_flush_log_at_trx_commit et sync_binlog par leurs valeurs par défaut lors d'une sauvegarde. Cela pourrait de limiter les performances lors des sauvegardes. Pour éviter cela, vous pouvez déplacer l'intervalle de sauvegarde à un moment où l'utilisation de l'instance est faible. Pour plus d'informations, consultez la section Créer et gérer des sauvegardes à la demande et automatiques.

    innodb_flush_log_at_timeout

    innodb_flush_log_at_timeout vous permet de modifier la fréquence de vidage des pages afin d'éviter toute incidence sur les performances du commit de groupe des journaux binaires. Le paramètre par défaut est d'une fois par seconde.

    Cloud SQL a étendu cette option pour permettre de spécifier une période en microsecondes.

    Exemples :

    • 0.001 pour spécifier 1 ms
    • 0.0001 pour spécifier 100 µs
    • 12.5 pour spécifier 12,5 secondes
    • 12.005 pour spécifier 12 secondes et 5 ms
    • 0.005100 pour spécifier 5 ms et 100 µs

    Pour certaines charges de travail, l'utilisation de la précision à la seconde pour le vidage des pages peut être inacceptable en termes de perte potentielle de transactions. Au lieu de cela, vous pouvez vider les pages avec une précision de l'ordre de la microseconde pour maintenir les performances sans compromettre considérablement la durabilité.

    Les périodes en microsecondes pour l'option innodb_flush_log_at_timeout ne s'appliquent que lorsque l'option de durabilité innodb_flush_log_at_trx_commit est définie sur 2.

    Le vidage des pages peut se produire plus ou moins fréquemment que la valeur spécifiée pour innodb_flush_log_at_timeout, et la valeur ne correspond pas à la limite supérieure.

    max_heap_table_size, tmp_table_size

    La mémoire d'instance disponible peut s'épuiser lorsque vous définissez des valeurs trop élevées pour tmp_table_size et max_heap_table_size par rapport au nombre de requêtes traitées simultanément par l'instance. L'épuisement de la mémoire provoque le plantage et le redémarrage de l'instance.

    Pour en savoir plus sur l'utilisation de ces indicateurs, reportez-vous aux pages Comment MySQL utilise les tables temporaires internes et Moteur de stockage MEMORY.

    performance_schema

    Vous ne pouvez pas activer cette option sur les instances avec un cœur partagé (moins de 3 Go de RAM). Si vous activez cette option, vous ne pouvez pas remplacer votre type de machine par une taille non compatible avec l'option. Vous devez d'abord désactiver cette option.

    event_scheduler
    Les événements MySQL, également appelés événements planifiés, sont des tâches que vous pouvez planifier. Les événements planifiés sont un groupe d'une ou plusieurs instructions SQL qui sont définies pour s'exécuter à un ou plusieurs intervalles spécifiés. La valeur par défaut de MySQL 5.7 est OFF et la valeur par défaut de MySQL 8.0 est ON. Pour en savoir plus sur l'option event_scheduler, consultez event_scheduler. Si l'option event_scheduler est définie sur ON pour une instance dupliquée avec accès en lecture, cela peut entraîner des erreurs en fonction du type d'instruction défini dans les événements :
    • Si votre événement planifié est un événement write sur une instance répliquée avec accès en lecture, cela provoque une erreur, car les instances répliquées avec accès en lecture sont en lecture seule. Pour en savoir plus, consultez la section Instances répliquées avec accès en lecture.
    • Si votre événement planifié contient une opération d'arrêt, telle que kill, event_scheduler l'applique à l'instance répliquée. Cela entraîne l'arrêt de l'opération et supprime l'instance répliquée.
    Pour éviter de telles erreurs, définissez l'option event_scheduler sur OFF lors de la création d'instances répliquées.

    Pour savoir comment activer ou désactiver event_scheduler, consultez Configurer des options de base de données.

    replica_skip_errors,slave_skip_errors
    Définir l'option replica_skip_errors ou slave_skip_errors peut entraîner des problèmes de réplication. En général, si une erreur se produit lors de l'exécution d'une instruction, la réplication est arrêtée. L'utilisation de cette option entraînera le saut de l'erreur et la continuation de la réplication, ce qui entraîne une incohérence entre l'instance principale et l'instance répliquée. Cela peut également rendre la résolution des problèmes de réplication plus difficile.

    Cloud SQL recommande d'utiliser cette option uniquement si nécessaire. Si vous rencontrez des erreurs de réplication, consultez la page Résoudre les problèmes liés à Cloud SQL : Réplication pour savoir comment résoudre ce problème.

    character_set_client
    character_set_connection
    character_set_results
    collation_connection
    innodb_buffer_pool_dump_now
    innodb_buffer_pool_load_abort
    innodb_buffer_pool_load_now
    innodb_ft_aux_table
    foreign_key_checks
    sql_select_limit
    unique_checks
    Ces options ne peuvent pas être sélectionnées directement dans la console Google Cloud ou à l'aide de la gcloud CLI. Pour utiliser ces options, exécutez la commande suivante :

    SET GLOBAL FLAG_NAME=FLAG_VALUE
    

    L'utilisation de la commande SET GLOBAL nécessite le droit CLOUDSQL_SPECIAL_SYSEM_VARIABLES_ADMIN, qui est accordé au rôle cloudsqlsuperuser.

    Pour en savoir plus sur la manière d'accorder un accès spécial à un utilisateur spécifique, consultez À propos des utilisateurs MySQL. Ces options ne sont pas conservées. Lorsque votre instance Cloud SQL est recréée ou redémarrée, les paramètres de l'option sont réinitialisés à la valeur par défaut.

    binlog_order_commits

    La valeur par défaut de l'option binlog_order_commits est ON. Cloud SQL recommande de ne pas modifier la valeur par défaut de cette option. Si la valeur par défaut est remplacée par OFF, les transactions du même groupe de journaux binaires seront validées dans un ordre différent de celui où elles ont été écrites dans le journal binaire. Cela a un impact sur les opérations suivantes qui exécutent des transactions dans l'ordre du journal binaire :

    • Réplication : peut entraîner une incohérence des données entre la source et les instances répliquées
    • Point-in-time-recovery : cette opération peut entraîner une incohérence dans les données entre l'état restauré de la récupération PITR et l'état historique.

    optimizer_switch,optimizer_trace,optimizer_trace_features

    Les options d'optimisation contiennent des valeurs séparées par une virgule. Vous pouvez définir ces options à l'aide de la console ou de gcloud. Pour savoir comment définir cette option à l'aide de la console, consultez Configurer des options de base de données. Si vous utilisez gcloud, vous pouvez spécifier la valeur de ces options de deux manières différentes :

    Pour définir plusieurs sous-options d'optimiseur dans une même commande, utilisez la virgule pour séparer chaque nom d'option. Si vous définissez une seule valeur de sous-option à l'aide de la commande gcloud, elle remplace toutes les sous-options précédemment définies. Par exemple, si vous exécutez la commande suivante, la valeur attendue de la sous-option batched_key_access est définie sur on et toutes les autres sous-options de optimizer_flags sont définies sur leurs valeurs par défaut.
    gcloud sql instances patch my-instance --database-flags=^~^optimizer_switch=batched_key_access=on
    
    Si vous exécutez la commande suivante, la valeur de la sous-option block_nested_loop est définie sur on et toutes les autres sous-options de optimizer_switch sont écrasées et définies sur leurs valeurs par défaut.
    gcloud sql instances patch my-instance --database-flags=^~^optimizer_switch=block_nested_loop=on
    
    Cela inclut batched_key_access, qui a été défini sur on par la commande précédente. Pour conserver toutes les sous-options précédemment définies et en ajouter de nouvelles, vous devez ajouter les valeurs de toutes les sous-options que vous souhaitez définir lorsque vous ajoutez une nouvelle sous-option.

    Options système modifiées dans Cloud SQL

    Toutes les autres options système de base de données qui ne sont pas répertoriées dans la section Options compatibles sont appelées "options gérées". Pour certaines options gérées, Cloud SQL définit l'option sur une valeur autre la valeur par défaut afin de garantir l'exécution fiable des instances Cloud SQL. Vous ne pouvez pas modifier les valeurs de ces options système.

    Les options gérées ayant une valeur autre que la valeur par défaut sont répertoriées ci-dessous.

    Nom de la variable Paramètre dans Cloud SQL. Remarques
    binlog_format ROW Différent dans MySQL 5.6 uniquement
    binlog_error_action ABORT_SERVER Différent dans MySQL 5.6 uniquement
    innodb_doublewrite_pages 64 S'applique à MySQL 8.0.26 et versions ultérieures
    innodb_file_format Barracuda Différent dans MySQL 5.6 uniquement
    innodb_flush_method O_DIRECT
    memlock vrai
    skip_name_resolve ON
    relay_log_info_repository TABLE
    relay_log_recovery ON
    master_info_repository TABLE
    rpl_semi_sync_master_enabled 1
    rpl_semi_sync_master_timeout 3000
    admin_address 127.0.0.1 Différent dans MySQL 8.0 uniquement
    create_admin_listener_thread ON
    port-open-timeout 120 Différent dans MySQL 8.0 uniquement
    partial_revokes ON MySQL 8.0 uniquement. Pour en savoir plus sur cette option, consultez la section Option système partial_revokes dans MySQL 8.0.

    Option système partial_revokes dans MySQL 8.0

    L'option partial_revokes vous permet de limiter l'accès des utilisateurs sur un schéma de base de données. Dans Cloud SQL pour MySQL version 8.0, l'option partial_revokes est définie sur ON. Cela limite l'utilisation des caractères génériques lors de l'attribution ou de la révocation des droits d'un utilisateur sur des schémas de base de données dans MySQL 8.0. Mettez à jour votre instruction GRANT pour utiliser le nom complet du schéma de base de données au lieu d'utiliser des caractères génériques.

    Par exemple, si vous exécutez la commande suivante avec le caractère générique %\ pour accorder des droits à un utilisateur dans MySQL 5.7, celui-ci disposera de droits sur toutes les bases de données se terminant par _foobar.

    GRANT ALL PRIVILEGES ON `%\_foobar`.*  TO  'testuser'@'%';
    

    Cependant, dans MySQL 8.0, les utilisateurs n'auront accès qu'à la base de données qui correspond exactement à %\_foobar.

    Deux méthodes permettent d'accorder l'accès à plusieurs bases de données dans MySQL 8.0.

    1. Vous pouvez accorder des autorisations sur des bases de données spécifiques à l'aide de leur nom complet, comme indiqué dans la commande ci-dessous :

        grant select on test1_foobar.* to 'testuser'@'%';
        grant select on test2_foobar.* to 'testuser'@'%';
        grant select on test3_foobar.* to 'testuser'@'%';
      
    2. Avec partial_revokes, vous pouvez exécuter les commandes grant et revoke pour accorder des droits à un utilisateur sur tous les schémas de base de données, tout en limitant l'accès à quelques schémas de base de données.

        grant select on *.* to 'testuser'@'%';
        revoke select on test3_foobar.* from 'testuser'@'%';
      

      Cela fournit un accès à tous les schémas de base de données tout en limitant l'accès à test3_foobar.*.

    Filtres de réplication

    Les filtres de réplication ne peuvent être définis que sur des instances répliquées Cloud SQL. Chaque filtre de réplication est défini comme une option unique pour plusieurs bases de données où les noms des bases de données sont séparés par une virgule. Vous pouvez configurer un filtre de réplication sur une instance répliquée Cloud SQL à l'aide de la console ou de la commande suivante :

    gcloud sql instances patch REPLICA_NAME --database-flags=^~^REPLICATION_FILTER_NAME=DATABASE_NAME1,DATABASE_NAME, etc
    

    Les filtres de réplication ne sont pas compatibles avec les noms de bases de données contenant des valeurs de virgule. La valeur ^~^ de la commande précédente est nécessaire pour les options de base de données qui sont des valeurs séparées par une virgule.

    Lorsque vous définissez une option de filtre de réplication, tenez compte des points suivants :

    • Si l'instance répliquée n'est plus opérationnelle, les données filtrées par les filtres de réplication peuvent apparaître sur l'instance répliquée, car Cloud SQL utilise les données sources de l'instance principale pour reconstruire l'instance répliquée.
    • Vous ne pouvez pas définir de filtres de réplication sur le schéma mysql.
    • Les règles de filtre de réplication ne s'appliquent pas aux exportations sans serveur.

    Options du conseiller d'index

    Voici la liste des options de base de données que Cloud SQL pour MySQL utilise pour activer et gérer les fonctionnalités spécifiques au conseiller d'index.

    Nom de l'option Valeurs
    acceptables et remarques pour le type
    Redémarrage
    nécessaire ?
    cloudsql_index_advisor boolean
    on | off
    Par défaut: off
    Oui
    cloudsql_index_advisor_auto_advisor_schedule string
    Par défaut: 00:00
    Non
    cloudsql_index_advisor_run_at_timestamp Datetime
    Par défaut: 00:00:00
    Non

    Options avec alias

    La liste suivante contient les noms d'option qui ont été modifiés par Cloud SQL pour MySQL versions 8.0.26 et ultérieures.

    Nom d'option obsolète Nouveau nom d'option
    log_slow_slave_statements log_slow_replica_statements
    master_verify_checksum source_verify_checksum
    slave_checkpoint_group replica_checkpoint_group
    slave_checkpoint_period replica_checkpoint_period
    slave_compressed_protocol replica_compressed_protocol
    slave_net_timeout replica_net_timeout
    slave_parallel_type replica_parallel_type
    slave_parallel_workers replica_parallel_workers
    slave_pending_jobs_size_max replica_pending_jobs_size_max
    slave_preserve_commit_order replica_preserve_commit_order
    slave_skip_errors replica_skip_errors
    slave_sql_verify_checksum replica_sql_verify_checksum
    slave_transaction_retries replica_transaction_retries
    slave_type_conversions replica_type_conversions
    sync_master_info sync_source_info

    Si votre instance Cloud SQL utilise un nom d'option obsolète, modifiez-la, supprimez le nom d'option obsolète, puis ajoutez le nouveau nom d'option à votre instance. Pour en savoir plus, consultez la section Configurer une option de base de données.

    Dépannage

    Problème Dépannage
    Une fois que vous avez activé une option, une boucle se produit entre la panique et le plantage de l'instance. Contactez le service client pour demander la suppression de l'option et un hard drain. Cela force l'instance à redémarrer sur un autre hôte avec une nouvelle configuration, sans option ni paramètre indésirables.
    Le message d'erreur Bad syntax for dict arg s'affiche lorsque vous tentez de définir une option. Les valeurs de paramètre complexes, telles que les listes d'éléments séparés par une virgule, nécessitent un traitement particulier lorsqu'elles sont utilisées avec des commandes gcloud.

    Étape suivante