报名参加CloudWeGo黑客松,奖金直推双丰收! 了解详情
写点什么

在 DevOps 中以 API 看待共享数据库

  • 2017-10-15
  • 本文字数:1223 字

    阅读完需:约 4 分钟

WinOps 2017 大会上,Sabin.io 首席顾问 Simon Sabin 做了一个演讲,介绍如何将数据库更改加入到持续部署模型中。从数据库所有者的角度看,要实现在多个服务或应用间共享数据库,关键之一就是将这些共享数据库看成是API。

Sabin 建议考虑使用视图、触发器和存储过程等机制。它们可以更改数据库的内部结构,并同时保持向后兼容的应用数据操作。他举了一个例子,一个存储信用卡号的数据库表已经从纯文本改为被加密的,但要保证应用依然以纯文本方式检索卡号。例子中是通过查询视图实现的,而实际的数据库表通过触发器实现信息的加密和解密。处理结构如下图所示:

数据库向应用提供隐式的合约和接口,其中数据库的内部更改(通常出于性能、安全和其它一些改进的需要)不应该影响到应用。这一原则可以类比为 API,突破性更改同样遵循最小化原则,并应给出大量的通知信息,保证应用在实际数据更改之前采纳和部署前向兼容更改。对数据库应用消费者驱动合约,这样的方法是可延展的。

按Sabin 的说法,需要这一方法去调和对共享数据库的不同视角。应用开发人员总是将数据库看成是“沉默的存储”,而数据库管理员(DBA)则将数据库看成是关键业务数据的仓储之所。理想情况下,每个应用团队会有自己的数据库,团队中也应具有DBA 角色,但这通常难以达到。

当应用本身就需要模式或其它更改时,Sabin 建议降低批处理的规模(因为在数据库中实现可靠性和一致性是一个复杂的任务),一次应用一个小更改,并更改相应的应用代码。选取何种迁移机制,是金模式(Gold Schema)还是迁移脚本方式,依赖于更改的具体类型。在Sabin 看来,相比于对抗式的,这一机制更多是补充式的。对于模式更改,适用于金模式机制。金模式定义了目标模式(期望状态),并使用类似于 SQLCompare 这类的工具做了当前状态和期望状态间的“差异比较”。迁移脚本包括 DBDeploy Flyway ReadyRoll 等,该机制可能更适用于更复杂的修改。

Sabin 还推荐了其它一些方法,包括:指定数据库去适合自身工具而非其它方法,将部署信息添加到数据库自身中以便于追踪和诊断问题,将数据库更改作为交付流水线一部分看待以提升可审校性和合规性。演讲的最后,Sabin 建议使用区分在“私有”和“公开”的方法极大地改进数据安全(在持续发生关键数据泄漏时)。例如,让一个可访问(“公开”)的小型数据库中提供对较大规模的安全(“私有”)数据库的视图,而“私有”数据库是不应被应用本身直接访问的。

正如 DevSecOps 运动是经过一段时间后才得以确立,将数据库更改加入到集成持续部署过程中的理念业已存在一段时间了,并被冠以各种称法。Sabin 将其称为“Data DevOps”,也有人将其称为“数据库生命周期管理”(DLM,Database Lifecycle Management)。另一位WinOps 2017 大会演讲者 Eduardo Piairo ,指出:

DevOps 并非是要定义一个处理数据库更改的新过程,而是将数据库更改和应用及架构代码一并集成到服务生命周期中。

查看英文原文: Treating Shared Databases Like APIs in a DevOps World

2017-10-15 19:001695
用户头像

发布了 391 篇内容, 共 142.3 次阅读, 收获喜欢 257 次。

关注

评论

发布
暂无评论
发现更多内容

RocketMQ存储设计到底强在哪?

慕枫技术笔记

架构 后端 28天写作 12月日更

自动驾驶车辆控制 最终项目作业 实现分析 易筋 ARTS 打卡 Week 78

John(易筋)

ARTS 打卡计划

架构训练营 -- 模块一

LJK

架构训练营

JVM分代回收机制和垃圾回收算法

Ayue、

JVM 技术专题合集

【LeetCode】赎金信Java题解

Albert

算法 LeetCode 12月日更

了解 JVM 的方法调用

Ayue、

JVM 技术专题合集

给弟弟的信第2封|关于时间管理这件事

大菠萝

28天写作

日志归一管理的一种解决方案

为自己带盐

redis elasticsearch 28天写作 签约计划第二季 12月日更

全方位认识 JVM

Ayue、

内容合集 技术专题合集

「2021年11月复盘」买了个小太阳很暖和

宋天伦

复盘

架构训练营 Week1 学习总结

红莲疾风

「架构实战营」

Java面向对象精讲【上】

XiaoLin_Java

面向对象 java基础 12月日更

纯css实现117个Loading效果(中)

德育处主任

CSS css3 大前端 纯CSS

音视频学习--X264码率控制起航

Fenngton

音视频 视频编解码 签约计划第二季

Arthas阿里开源的Java诊断工具

Ayue、

JVM 技术专题合集

JVM性能调优之内存优化与GC优化实战

Ayue、

JVM jvm调优 技术专题合集

乔布斯家app下架上架杂记

张老蔫

28天写作

音视频学习--日常开发踩坑系列(1)

Fenngton

音视频 传输协议 签约计划第二季

纯css实现117个Loading效果(上)

德育处主任

CSS 大前端 纯CSS 特效

音视频学习--SRTP优化

Fenngton

音视频 传输协议 签约计划第二季

JVM 性能诊断工具

Ayue、

JVM 技术专题合集

flutter如何从TextWidget复制文本【Flutter专题17】

坚果

flutter 28天写作 12月日更

react源码解析14.手写hooks

buchila11

React React Hooks

一次redis节点宕机引发的后续操作--部署哨兵集群

为自己带盐

redis redis哨兵模式 28天写作 签约计划第二季 12月日更

JVM类加载机制

Ayue、

JVM 技术专题合集

react源码解析13.hooks源码

buchila11

React React Hooks

23种设计模式第一种——单例模式

李子捌

28天写作 12月日更

音视频学习--新codec适配和兼容

Fenngton

音视频 视频编解码 签约计划第二季

程序员写作模版献给懵逼的你

jerry

音视频学习合集

Fenngton

内容合集 签约计划第二季

音视频学习--VLC优化

Fenngton

音视频 RTSP 签约计划第二季

在DevOps中以API看待共享数据库_数据库_Manuel Pais_InfoQ精选文章