1 简介

Cloud SQL 是GCP上的关系型数据库,常用的有三种方式来创建:

(1) 界面操作

(2) 命令行 gcloud

(3) Terraform

在开始之前,可以查看:《初始化一个GCP项目并用gcloud访问操作》。

2 GCP 操作界面

登陆GCP,选择SQL,可以创建MySQL、PostgreSQL和SQL Server:

以PostgreSQL为例,可以选择很多参数:

3 gcloud命令

通过命令行创建也很方便,可以自动化。命令如下:

$ gcloud sql instances create pkslow-testdb \
--database-version=POSTGRES_13 \
--region=us-west1 \
--cpu=1 \
--memory=3840MB \
--authorized-networks="0.0.0.0/0" Creating Cloud SQL instance...done.
Created [https://sqladmin.googleapis.com/sql/v1beta4/projects/pkslow/instances/pkslow-testdb].
NAME DATABASE_VERSION LOCATION TIER PRIMARY_ADDRESS PRIVATE_ADDRESS STATUS
pkslow-testdb POSTGRES_13 us-west1-a db-custom-1-3840 34.83.146.214 - RUNNABLE

authorized-networks 这个参数很重要,它决定了哪些客户端可以连接上数据库。

设置密码:

$ gcloud sql users set-password postgres \
--instance=pkslow-testdb \
--password=pkpass

给实例创建数据库:

$ gcloud sql databases create billing --instance=pkslow-testdb

Creating Cloud SQL database...done.
Created database [billing].
instance: pkslow-testdb
name: billing
project: pkslow

创建完成后,就可以在本地连接了:

连上之后,我们来创建一张表和插入一些数据来测试一下:

CREATE TABLE pkslow_person (
name varchar not null,
age int not null,
city varchar not null
); insert into pkslow_person(name, age, city) VALUES ('Larry', 1, 'GZ');
insert into pkslow_person(name, age, city) VALUES ('pkslow', 2, 'SZ');
insert into pkslow_person(name, age, city) VALUES ('Deng', 21, 'SZ');
insert into pkslow_person(name, age, city) VALUES ('Eason', 13, 'BJ');
insert into pkslow_person(name, age, city) VALUES ('JJ', 43, 'SH');
insert into pkslow_person(name, age, city) VALUES ('Mi', 28, 'HK');

查看数据:

4 Terraform

当然,更好的方式还是通过Terraform来创建:

provider "google" {
project = "pkslow"
} resource "google_sql_database_instance" "instance" {
name = "pkslow-postgresql"
region = "us-west1"
database_version = "POSTGRES_13"
settings {
tier = "db-f1-micro" ip_configuration {
ipv4_enabled = "true" authorized_networks {
value = "0.0.0.0/0"
name = "allow-all"
expiration_time = "2099-01-01T00:00:00.000Z"
} }
} deletion_protection = "true"
} resource "google_sql_database" "database" {
name = "billing"
instance = google_sql_database_instance.instance.name
} resource "google_sql_user" "users" {
name = "larry"
instance = google_sql_database_instance.instance.name
password = "larry.pass"
}

这段代码为会我们创建三个资源:实例、数据库和用户。

准备好代码好,运行下面命令:

$ terraform init -plugin-dir=${TERRAFORM_PLUGIN}

$ terraform plan

$ terraform apply -auto-approve

Terraform还会自动在Bucket上创建文件来管理Terraform的状态:

创建完成后,检查就有两个数据库实例了:

$ gcloud sql instances list
NAME DATABASE_VERSION LOCATION TIER PRIMARY_ADDRESS PRIVATE_ADDRESS STATUS
pkslow-postgresql POSTGRES_13 us-west1-a db-f1-micro 34.127.53.161 - RUNNABLE
pkslow-testdb POSTGRES_13 us-west1-a db-custom-1-3840 34.83.146.214 - RUNNABLE

本地连接如下:

5 代码

代码请查看GitHub: https://github.com/LarryDpk/pkslow-samples

最新文章

  1. 教你一招:Win10切换输入法与Win7一样(Ctrl + 空格)
  2. [问题2015S05] 复旦高等代数 II(14级)每周一题(第六教学周)
  3. 【动态规划】bzoj1664 [Usaco2006 Open]County Fair Events 参加节日庆祝
  4. JQuery 来获取数据c#中的JSON数据
  5. 如何配置LCD背光和LED,调试方法
  6. 为什么说DOM操作很慢
  7. 联想G510F1F2..功能键和FN+功能键反过来
  8. A*寻路算法入门(一)
  9. mysql-笔记-控制语句/string方法
  10. 你所误解的微信公众号开发、以及微信公众号网页授权、接收url跳转参数等问题
  11. gitlab的安装和基本使用
  12. SQL约束(主键约束、外键约束、自动递增、不允许空值、值唯一、值默认、值限制范围)
  13. 【Web前端】div层调整zindex属性无效原因分析及解决方法
  14. Distribution setup SQL Server Agent error: "RegCreateKeyEx() returned error 5, 'Access is denied.'" (转载)
  15. Google搜索引擎
  16. springmvc基础知识及注解
  17. [leetcode]159. Longest Substring with At Most Two Distinct Characters至多包含两种字符的最长子串
  18. Class.getResource()方法的使用
  19. 【51nod-1091】线段的重叠(贪心)
  20. SC || 记不住的正则

热门文章

  1. Vue学习之--------组件的基本使用(非单文件组件)(代码实现)(2022/7/22)
  2. 构建Springboot项目、实现简单的输出功能、将项目打包成可以执行的JAR包(详细图解过程)
  3. .NET性能系列文章一:.NET7的性能改进
  4. Springboot数据库的配置问题
  5. Archlinux配置fcitx5
  6. 基于SqlSugar的开发框架循序渐进介绍(21)-- 在工作流列表页面中增加一些转义信息的输出,在后端进行内容转换
  7. 随笔——写windows服务的时候如何调试 c# .net
  8. python调用c++生成的dll
  9. VulnHub靶机渗透实战9-vikings
  10. JS笔记合集之对象