🔒 Secure-first SQL Editor with data access control and masking 🎭

Announcement

Introducing Terraform Bytebase Provider

Candy
Candy2 min read
Introducing Terraform Bytebase Provider

Why Terraform

Terraform is the most widely used open-source tool that allows you to manage and provision infrastructure using code. It is known for its ability to work across multiple cloud providers, reusability, versioning, flexibility, and active community. Terraform providers are plugins that enable Terraform to communicate and manage resources on various cloud platforms such as AWS, Google Cloud, Azure, as well as SaaS vendors like Datadog, MongoDB, Elastic, and etc.

Some Bytebase customers use Terraform to manage their infrastructure resources, and they want to use it to manage their Bytebase resources such as environments and database instances. Previously, we offered customers the web-based Bytebase Console and OpenAPI to do that. Today, we are excited to reveal our latest feature, Terraform Bytebase Provider, which enables you to manage Bytebase resources through Terraform. This is a great opportunity for you to simplify and streamline your database change management.

Terraform Bytebase Provider

The latest Terraform Bytebase Provider allows you to easily manage the following Bytebase resources.

  • Environments: They are modeled after different stages in the development pipeline, such as dev, test, and prod.
  • Database instances: They are modeled after a single database instance and can be accessed using an address such as host:port.
  • Instance roles: At this time, it is only compatible with PostgreSQL. We are working on supporting for MySQL.

Taking the database instances as an example, you want to add a MySQL instance to the environment prod. Initially, the environment prod has only one PostgreSQL instance Postgres Sample Instance as shown below. before-terraform-config

The code block below demonstrates how to add the instance prod_instance to the environment prod: access-control-code

Run terraform init, terraform plan and terraform apply in the terminal. The output below shows that the instance prod_instance has been successfully added. run-terraform

After running the Terraform commands, you can verify the instances list via the Bytebase Console, where you will observe the MySQL instance prod_instance listed in the instances list. after-terraform

Conclusion

If you are already using Terraform to manage your infrastructure, the Terraform Bytebase Provider will allow you to codify the database configuration and consolidate your workflow. To get started, you can follow this tutorial Manage databases in Bytebase with Terraform and try it out by yourself. Additionally, you can find more examples on GitHub.

You are welcome to join our discord to learn more about database change management and discuss related topics.

Jointhe community

At Bytebase, we believe in the power of collaboration and open communication, and we have a number of communities that you can join to connect with other like-minded.

Subscribe to Newsletter

By subscribing, you agree with Bytebase's Terms of Service and Privacy Policy.