用 Bytebase 实现批量、多环境、多租户数据库的丝滑变更
创始人
2024-11-16 03:04:05
0

Bytebase 提供了多种功能来简化批量变更管理,适用于多环境或多租户情况。本教程将指导您如何使用 部署配置 和 数据库组 在不同场景下进行数据库批量变更。

file

默认流水线 vs 部署配置

file

图片数据库 vs 数据库组

1. 准备

  1. 请确保已安装 Docker,如果本地没有重要的现有 Bytebase 数据,可以通过 rm -rf ~/.bytebase/data 从头开始。

  2. 这是企业版的功能,您可以通过添加小助手申请(见文末二维码)。

2. 过程

第一步 - 启动 Bytebase 并准备数据库

为了演示批量更改,我们需要先准备一些数据库。

  1. 复制并粘贴命令,通过 Docker 启动 Bytebase。
docker run --rm --init \  --name bytebase  --publish 8080:8080 --pull always \  --volume ~/.bytebase/data:/var/opt/bytebase \  bytebase/bytebase:2.22.0(这里的 2.22.0 可以替换成最新版本)
  1. 注册第一个账户,它将自动获得工作区管理员角色。
  2. Bytebase 提供了两个 PostgreSQL 实例示例。点击顶部栏的选择项目,在弹出窗口中点击新建,然后点击创建。

file

  1. 进入项目,点击左侧栏上的数据库 > 数据库。目前还没有属于此项目的数据库。点击新建数据库。要模拟真实世界的场景,首先创建 demo-test,它应在样本测试实例上创建。将自动创建一个工单,因为我们没有配置任何发布机制或自定义审批工作流程,所以它会自动发布。工单创建完成后,数据库将被建立。

file

file

  1. 用同样的方法,创建 demo-prod-1、demo-prod-2、demo-prod-3、demo-prod-4、demo-prod-5、demo-prod-6、other-prod-1 和 other-prod-2。

file

  1. 选择 demo-prod-1 和 demo-prod-2 ,单击编辑标签。指定:标签键「位置」,值「asia」。用同样的方法将 eu 和 na 分配给其他 demo-prod 数据库。

file

file

第二步 - 部署配置 (社区版)

这部分将向你展示部署配置给发布流水线带来的不同。

  1. 进入项目中的 数据库 > 数据库,选择 demo-test 和 demo-prod-1~demo-prod-6 并单击编辑 schema 。填写 SQL,然后单击创建。可以看到流水线有两个阶段 -- 测试和生产,并且有六个数据库,这意味着 SQL 将同时在这六个数据库运行。
CREATE TABLE t2("id" INTEGER NOT NULL);

file

file

  1. 如果想先变更亚洲 asia,然后更改欧盟 eu,最后更改北美 na,可以留在项目中,单击左侧栏上的部署配置,添加带有标签过滤功能的新阶段。

file

  1. 到项目中的数据库 > 数据库,选择 demo-test 和 demo-prod-1~demo-prod-6 并单击编辑模式。填写 SQL,然后单击创建。可以看到流程有四个阶段,就像我们配置的那样。
CREATE TABLE t1("id" INTEGER NOT NULL);

file

第三步 - 数据库组(企业版)

这部分开始需要升级系统到企业版才能激活。

  1. 点击右上角的设置齿轮图标,然后点击工作区 > 订阅上传许可。

  2. 单击铅笔图标,选择要启用企业功能的实例,然后单击确认。这里是将许可分配给了实例,为对应实例开启企业版功能。

file

  1. 到项目中的数据库 > 组,单击新建数据库组,填写以下字段,向下滚动时,你会看到有一个选项多租户,暂时不要选中它,然后单击保存。

名称:demo-prod-all

条件:环境 == Prod,数据库名称以 demo-prod- 开头

file

file

  1. 到项目中的 数据库 > 组,单击编辑 schema,选择数据库组,然后单击下一步。

file

  1. 可以看到六个数据库分为三个阶段。填写 SQL,然后单击创建。
CREATE TABLE t3("id" INTEGER NOT NULL);

file

  1. 到项目中的数据库 > 数据库,然后单击新建数据库。创建属于数据库组的数据库 demo-prod-7。检查 schema,它是空的。

file

第四步 - 多租户数据库组(企业版)

  1. 数据库组启用多租户功能后,新数据库将自动继承数据库组的 schema。

  2. 到项目中的数据库 > 组,单击配置,这次我们选中多租户,然后单击确认。

  3. 到项目中的数据库 > 数据库,然后单击新建数据库。创建属于数据库组的数据库 demo-prod-8。检查 schema,它与其他 demo-prod 数据库的schema 相同。请注意,即使在工单执行或称重问题,新数据库也会被添加。

file

总结

现在,你已学会如何使用部署配置和数据库分组在 Bytebase 中运行批量更改。动手试试吧!


💡 更多资讯,请关注 Bytebase 公号:Bytebase

相关内容

热门资讯

安卓系统怎么设壁纸桌面,轻松设... 亲爱的手机控们,你是不是也和我一样,对手机壁纸和桌面布局情有独钟?想要让你的安卓手机焕然一新,个性化...
安卓系统6.0怎么root教程... 亲爱的安卓用户们,你是否曾梦想过让你的手机拥有超能力?没错,我说的就是root!今天,就让我带你一步...
安卓2.2系统当贝市场,体验升... 你有没有想过,那些老旧的安卓设备,虽然已经不再流行,但它们在某个角落里,可能还在默默无闻地发挥着余热...
安卓14系统为啥卡顿,探究性能... 最近是不是发现你的安卓手机有点儿不给力了?打开应用慢吞吞的,滑动页面卡得像老牛拉车,这可真是让人头疼...
采集无锡安卓系统的公司,技术驱... 你有没有想过,在这个科技飞速发展的时代,手机操作系统的重要性简直不言而喻?而在中国,有一个城市,它的...
安卓新系统有问题,揭秘常见故障... 最近你的安卓手机是不是也遇到了点小麻烦?别急,让我来给你细细道来,看看这个新系统到底有哪些让人头疼的...
u盘安卓随身系统,U盘随身携带... 你有没有想过,把安卓系统随身携带,随时随地都能用上?没错,今天就要给你揭秘一个神奇的小玩意——u盘安...
安卓手机有俩系统吗,体验双重魅... 你有没有发现,安卓手机的世界里,好像藏着两个神秘的小秘密呢?没错,就是那个让人又爱又恨的安卓系统。今...
安卓系统恢复怎么搞,轻松应对系... 手机突然卡壳了,系统崩溃了,是不是瞬间感觉整个人都不好了?别慌,今天就来教你一招,让你的安卓手机重获...
windows和安卓系统的关系... 你有没有想过,为什么你的手机和电脑有时候会像好朋友一样,互相配合得天衣无缝?其实,这背后有一个大大的...
安卓11怎么降级系统,轻松还原... 你有没有发现,安卓11系统虽然功能强大,但有时候也会有点小闹心呢?比如,某些应用不支持,或者系统运行...
正版授权!游戏推荐斗牛房卡出售... 今 日消息,天蝎大厅房卡添加微信33549083 苹果今日发布了 iOS 16.1 正式版更新,简单...
推荐一款!金花房卡批发女娲大厅... 女娲大厅房卡更多详情添加微:33549083、 2、在商城页面中选择房卡选项。 3、根...
安卓系统误删无法开机,紧急修复... 手机里的照片、联系人、重要文件,说没就没了!最近,身边的朋友纷纷向我抱怨,他们的安卓手机因为误删数据...
玩家攻略,牛牛充值房卡新大圣/... 玩家攻略,牛牛充值房卡新大圣/新道游/微信链接房卡购买渠道新大圣/新道游是一款非常受欢迎的游戏,咨询...
一分钟了解!牛牛房卡出售红桃众... 红桃众娱是一款非常受欢迎的棋牌游戏,咨询房/卡添加微信:【3329006910】或QQ:332900...
IA解析/金花房卡批发玄灵大厅... IA解析/金花房卡批发玄灵大厅/微信链接房卡最低价格Sa9Ix苹果iPhone 17手机即将进入量产...
我来教你/牛牛房卡代理新518... 新518互娱房卡更多详情添加微:33549083、 2、在商城页面中选择房卡选项。 3...
正规平台有哪些,金花房卡代理零... 微信游戏中心:九天大厅房卡在哪里买打开微信,添加客服微信【88355042】,进入游戏中心或相关小程...
荣耀magic是安卓系统吗,探... 你有没有听说过荣耀Magic这款手机?最近它可是手机圈里的热门话题呢!很多人都在问,荣耀Magic是...