引言
本文是《持续交付》一书学习总结的第五篇。主要内容涉及数据管理以及Git分支管理的实践。
数据管理
软件代码的部署可以简单地用新的版本替换旧的版本,但是数据可不是如此。自从产品上线后,数据就一直在增长,每个版本发布时,数据可能都是全新的。然而,有时我们的确有这样的需求,去改数据的结构或者内容。这就要求我们在做出修改的同时,保证产品运行和部署的可靠性。
首先,数据库的部署也需要脚本化。与代码部署一样,脚本有助于实现自动化,并容易使用版本控制工具来管理。需要注意的是,数据库的部署脚本(建库、建表、插入数据等)需要与最新的代码保持一致。因为只有新的代码可能用到了最新的数据库设计和数据,如果代码版本有误,很可能数据库部署会失败。
版本化你的数据库。我们可以用版本号来标记数据库的状态。这个版本号可以存储在一个独立的表中,每当数据库的设计和内容(元数据)发生变化时,就要更新这个版本号字段。另外,在应用程序的配置中,也要维护一个数据库的版本号,以便于在部署时对应到正确的数据。
除了版本号,每当我们更改数据库时,同时需要编写配套的发布(roll-forward)脚本和回滚(roll-back)脚本。前者用于将此次改动脚本化,让数据库进入新的版本;后者用于回滚这次操作,让数据库回到当前版本。当应用程序中配置的数据库版本号领先于数据库最新的版本时&#x