Overview
MariaDB is an open-source relational database management system and a drop-in replacement for MySQL. This template deploys a single-replica MariaDB instance with persistent storage and an optional phpMyAdmin web interface for database management.MariaDB on Control Plane operates as a single-replica deployment. Do not scale up the replica count, as this would result in multiple isolated instances rather than a replicated cluster.
What Gets Created
- MariaDB Workload — A single-replica MariaDB database container with configurable resources.
- Volume Set — Persistent storage for MariaDB data, with optional autoscaling.
- Secret — An opaque secret storing the database name, root password, and user credentials, injected into the container at startup.
- Identity & Policy — An identity bound to the workload with
revealaccess to the database credentials secret. - phpMyAdmin Workload (optional) — A web-based database management interface. Enabled when
enablePhpMyAdmin: true.
This template does not create a GVC. You must deploy it into an existing GVC.
Installation
This template has no external prerequisites. To install, follow the instructions for your preferred method:UI
Browse, install, and manage templates visually
CLI
Manage templates from your terminal
Terraform
Declare templates in your Terraform configurations
Pulumi
Declare templates in your Pulumi programs
Configuration
The defaultvalues.yaml for this template:
Credentials
config.db— Name of the database created on startup.config.rootPassword— Password for the MariaDB root user. Change before deploying to production.config.user— Name of the non-root database user created on startup.config.password— Password for the non-root user. Change before deploying to production.
These values are only applied on first startup when the data directory is empty. Updating them after the initial deployment will have no effect on the running database. To change credentials or the database name on an existing instance, use MariaDB’s native commands (e.g.
ALTER USER, RENAME DATABASE).Resources
resources.minCpu/resources.minMemory— Minimum CPU and memory guaranteed to the workload.resources.maxCpu/resources.maxMemory— Maximum CPU and memory the workload can use.timeoutSeconds— Workload timeout in seconds.
Storage
volumeset.capacity— Initial volume size in GiB (minimum 10).volumeset.autoscaling.enabled— Automatically expand the volume as it fills. When enabled:maxCapacity— Maximum volume size in GiB.minFreePercentage— Trigger a scale-up when free space drops below this percentage.scalingFactor— Multiply the current capacity by this factor when scaling up.
Internal Access
internalAccess.type— Controls which workloads can connect to MariaDB on port3306:
| Type | Description |
|---|---|
none | No internal access allowed |
same-gvc | Allow access from all workloads in the same GVC |
same-org | Allow access from all workloads in the same organization |
workload-list | Allow access only from specific workloads listed in workloads |
phpMyAdmin
enablePhpMyAdmin— Whentrue, deploys a phpMyAdmin workload for browser-based database management. Disable by setting tofalse.