Overview:
- A MySQL configuration is a collection of variables that define the operation of a MySQL DB system. It is analogous to the my.ini or my.cnf files that you use in on-premises MySQL server installation
- Each configuration is linked to the shape of the MySQL DB system
- There are two types of configuration:
- Default Configuration is defined in MySQL Database service and designed for a specific shape and contains a default set of configuration variables
- Custom Configuration is defined
- Types of Configuration Variables:
- System variables are not user-configurable. For the same shape, there are different configurations for standalone and HA
- User variables are those variables that you can edit when creating or copying a configuration
- Initialization variables apply for the life span of the MySQL instance and, once you apply it, you cannot change it later. There is currently only one initialization variable lower_case_table_name
- Service-specific variables are those variables that are specific only to MySQL database OCI service. Currently, there are two variables:
- thread_pool_dedicated_listeners
- thread_pool_max_transactions_limit
- Updating the DB system configuration to a new config that contains only dynamic user variables does not require a DB system restart
In this blog, I’ll demonstrate the steps to update the configuration of an existing MySQL DB system to use another MySQL configuration (MyConfig3) from the OCI console
Prerequisites:
Limitations:
- You cannot update/select a configuration that changes the initialization variables of a DB System
Steps to Update a MySQL DB System Configuration
1. Sign in to the OCI Console
2. Open the navigation menu and navigate to “Databases -> DB Systems“
data:image/s3,"s3://crabby-images/9a9ac/9a9ac8f8dd3cee6d89c0f51be1e8e5610ce7d7ee" alt="oci oci"
3. Choose your compartment. The list of MySQL DB systems is displayed. Click your DB system name
data:image/s3,"s3://crabby-images/1b8a4/1b8a4a49886cb1caa551808ab9b3f26ba84daf84" alt="oci2 oci2"
4. In the DB system details page and under the DB system configuration section, click Edit next to the Configuration option
data:image/s3,"s3://crabby-images/8bf46/8bf46c1fc5d395d51519abb05db5521dde0e18bc" alt="oci3 oci3"
5. In the “Edit DB system” window and under the Configuration section, click the “Change configuration” button
data:image/s3,"s3://crabby-images/c7ecd/c7ecd5cf15d4954df941e816814eecc977626516" alt="oci4 oci4"
6. In the Browse Configurations window, select MyConfig3 from the list
data:image/s3,"s3://crabby-images/2c161/2c16144cad8119de32766a3d38e3a9682522c9ba" alt="oci5 oci5"
Note: in my example selecting MyConfig2 is not an option because it attempts to change the initialization variables of the DB system.
data:image/s3,"s3://crabby-images/df3f9/df3f9d96bbc1ee84912a9c600e587ae66f98ff42" alt="oci6 oci6"
7. Once you select the new config, the Edit DB system window will show the name of the new config and a compare configurations table that shows variables compared. Click the “save changes” buttons
data:image/s3,"s3://crabby-images/5647d/5647d5b629a041f7d4edbb8fe1d42fcf4b9b95e9" alt="oci7 oci7"
8. DB system status will be UPDATING, but the database will NOT restart because all changed variables are dynamic.
data:image/s3,"s3://crabby-images/eaf29/eaf29ba9c9c089f477c55d314a7e772bd93d679b" alt="oci8 oci8"
9. Once the update finishes, the configuration name will be changed to the new config
data:image/s3,"s3://crabby-images/ce468/ce468be050517d4a357d804badc6d61b761d9af8" alt="oci9 oci9"