MySQL
Definition
A MySQL Resource is defined in convox.yml and linked to one or more Services.
resources:
  database:
    type: mysql
services:
  web:
    resources:
      - database
Options
A MySQL Resource can have the following options configured for it (default values are shown):
resources:
  database:
    type: mysql
    options:
      version: 5.7.23
      storage: 10
AWS RDS Managed MySQL Resources
In addition to containerized resources, Convox v3 allows the creation of MySQL resources via AWS RDS. This provides enhanced durability and managed service benefits. Below is a general example of how to define AWS RDS resources:
resources:
  database:
    type: rds-mysql
    options:
      class: db.m5.large
      storage: 100
      version: 5.7.33
      deletionProtection: true
      durable: true
      encrypted: true
      backupRetentionPeriod: 7
      preferredBackupWindow: 02:00-03:00
      preferredMaintenanceWindow: sun:05:00-sun:06:00
services:
  web:
    resources:
      - database
Features
- Read Replica Support: AWS RDS resources support integrated AWS read replicas. You can configure read replicas for improved read scalability and reliability. Additionally, read replicas can be promoted to active primaries if needed.
- Snapshot Restoration: Easily restore from a snapshot to create a new database instance with your desired specifications.
- Import Existing RDS Database: Import existing AWS RDS databases into a Convox rack for management or access via linking.
Configuration Options
Below is a chart of configuration options available for AWS RDS MySQL resources:
| Attribute | Type | Default | Description | 
|---|---|---|---|
| class | string | db.t3.micro | The compute and memory capacity of the DB instance. | 
| encrypted | boolean | false | Whether to enable storage encryption. | 
| deletionProtection | boolean | false | Whether to enable deletion protection for the DB instance. | 
| durable | boolean | false | Whether to create a Multi-AZ DB instance. | 
| storage | int | 20 | The amount of storage (in GB) to allocate for the DB instance. | 
| version | string | 5.7.33 | The version of the database engine. | 
| preferredBackupWindow | string | AWS managed | The daily time range during which automated backups are created if automated backups are enabled, using the backupRetentionPeriodoption. Must be in the format hh24:mi-hh24:mi, in UTC, at least 30 minutes, and must not conflict with the preferred maintenance window. If not set, AWS decides based on usage. | 
| backupRetentionPeriod | int | 1 | The number of days for which automated backups are retained. Setting this parameter to a positive number enables backups. Setting this parameter to 0 disables automated backups. | 
| iops | int | AWS managed | The amount of provisioned IOPS. | 
| port | int | 3306 | The port on which the database accepts connections. | 
| masterUserPassword | string | Convox managed | The password for the master user. Should be set as an environment variable to avoid hardcoding. | 
| allowMajorVersionUpgrade | boolean | true | Whether major version upgrades are allowed. | 
| autoMinorVersionUpgrade | boolean | true | Whether minor version upgrades are applied automatically. | 
| preferredMaintenanceWindow | string | AWS managed | The weekly time range during which system maintenance can occur. Must be in the format ddd:hh24:mi-ddd:hh24:mi, in UTC, at least 30 minutes, and must not conflict with the preferred backup window. If not set, AWS decides based on usage. | 
| readSourceDB | string | `` | The source database identifier for creating a read replica. | 
| import | string | `` | The database identifier used for database import. Requires the correct masterUserPasswordoption set. | 
| snapshot | string | `` | The snapshot identifier for restoring from a snapshot. | 
Note: The readSourceDB option is used for the read replica feature.
Note: The import option requires the correct masterUserPassword to be set for importing a database.
Note: The masterUserPassword should be set as an environment variable to avoid hardcoding the password.
Command Line Interface
Listing Resources
$ convox resources -a myapp
NAME      TYPE       URL
database  rds-mysql  mysql://username:password@host.name:port/database
Getting Information about a Resource
$ convox resources info database -a myapp
Name  database
Type  rds-mysql
URL   mysql://username:password@host.name:port/database
Getting the URL for a Resource
$ convox resources url database -a myapp
mysql://username:password@host.name:port/database
Launching a Console
$ convox resources console database -a myapp
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.7.33 MySQL Community Server (GPL)
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
Starting a Proxy to a Resource
$ convox resources proxy database -a myapp
Proxying localhost:3306 to host.name:port
Proxying allows you to connect tools on your local machine to Resources running inside the Rack.
Exporting Data from a Resource
$ convox resources export database -f /tmp/db.sql
Exporting data from database... OK
Importing Data to a Resource
$ convox resources import database -f /tmp/db.sql
Importing data to database... OK