在产品迭代开发发布过程中,由于业务需求的增加,数据库难免会有结构调整等操作.

在每个版本发布过程中怎么控制每个版本server端程序与数据库版本保持一致,以及数

据库升级、回滚等操作.

本博文宅鸟将向大家推荐一款mysql数据库迁移工具mysql-php-migrations

由于具体需求不同,宅鸟根据自己公司的情况将mysql-php-migrations做了一些修改来满应用!

宅鸟修改改程序后的mysql迁移程序有以下目录:

config 配置文件

dbscript sql脚本目录

lib 迁移程序类库

migrate.php 迁移命令执行入口

执行php migrate.php

可以看到如下结果

我们可以看到migrate.php有很多命令

php migrate.php add  test

结果:

__ __         __      __

|\/|  (_ /  \|   __ |__)|__||__) __ |\/|. _  _ _ |_. _  _  _

|  |\/__)\_\/|__    |   |  ||       |  ||(_)| (_||_|(_)| )_)

/                                    _/

******************************************************************** v2.0.1 ***

New migration created: file

/var/www/mysqlMigrations/dbscript/2013_12_18_14_50_45_test.php

*******************************************************************************

cd dbscript

total 16

-rw-r--r-- 1 www-data www-data 4837 Sep 29 09:21 2013_06_18_17_14_16_v1.php

-rw-r--r-- 1 www-data www-data  802 Sep 29 13:29 2013_09_29_12_00_12_v1.php

-rw-r--r-- 1 root     www-data  240 Dec 18 14:50 2013_12_18_14_50_45_test.php

此时dbscript目录已经新添加一个2013_12_18_14_50_45_test.php文件,改文件格式如下:

<?php

class Migration_2013_12_18_14_50_45 extends MpmMysqliMigration

{

public function up(ExceptionalMysqli &$mysqli)

{

$mysqli->exec("DO 0");

}

public function down(ExceptionalMysqli &$mysqli)

{

$mysqli->exec("DO 0");

}

}

?>

把需要修改的数据库脚本写在up函数中:

把对应修改修改所做的回滚操作卸载down函数中

注意:在生产环境下建议只做数据库的向上变迁,不做down操作,避免用户有用数据丢失.

执行php migrate.php list 返回结果:

WARNING: Migration numbers may not be in order due to interleaving.

#         Timestamp

========================================================================

version           createtime              active  current note

1371546856        2013-06-18 17:14:16     1       0       v1

1380427212        2013-09-29 12:00:12     1       1       v1

1387349445        2013-12-18 14:50:45     0       0       test

Page 1 of 1, 3 migrations in all.

cd config 目录

cat db_config.php

<?php

$db_config = (object) array();

$db_config->host = '127.0.0.1';

$db_config->port = '3306';

$db_config->user = 'dbuser';

$db_config->pass = 'dbpasswd';

$db_config->name = 'dbname';

$db_config->db_path = 'var/www/mysqlMigrations/dbscript/';

$db_config->method = 2;   //1 pdo,2 mysqli

?>

了解该程序基本结构后,我们来开始使用一下它:

cd mysqlMigrations

php migrate.php add test2

在dbscript下生成 2013_12_18_15_06_14_test2.php

执行命令:php migrate.php list

可以看到版本结果:

#         Timestamp

========================================================================

version           createtime              active  current note

1371546856        2013-06-18 17:14:16     1       0       v1

1380427212        2013-09-29 12:00:12     1       1       v1

1387349445        2013-12-18 14:50:45     0       0       test

1387350374        2013-12-18 15:06:14     0       0       test2

Page 1 of 1, 4 migrations in all.

说明:

version 每次迁移的版本号

createtime 创建时间

active  是否已经激活生效

current 数据库当前所在版本标志

note  迁移的注释

执行命令:php migrate.php up 1387349445   可以把数据版本从 1380427212 迁移到 1387349445

#         Timestamp

========================================================================

version           createtime              active  current note

1371546856        2013-06-18 17:14:16     1       0       v1

1380427212        2013-09-29 12:00:12     1       0       v1

1387349445        2013-12-18 14:50:45     1       1       test

1387350374        2013-12-18 15:06:14     0       0       test2

Page 1 of 1, 4 migrations in all.

执行命令:php migrate.php down 1380427212        可以把数据版本从 1387349445 回滚到 1380427212

执行php migrate.php list查看数据库版本回滚结果

#         Timestamp

========================================================================

version           createtime              active  current note

1371546856        2013-06-18 17:14:16     1       0       v1

    1380427212        2013-09-29 12:00:12     1       1       v1

1387349445        2013-12-18 14:50:45     0       0       test

1387350374        2013-12-18 15:06:14     0       0       test2

Page 1 of 1, 4 migrations in all.

如果要迁移到数据库最大版本可以执行一下命令:

php migrate.php up max_version

返回结果:

Migrating to 2013-12-18 15:06:14 (ID 1387350374)...

Performing UP migration 2013-12-18 14:50:45 (ID 1387349445)... done.

Performing UP migration 2013-12-18 15:06:14 (ID 1387350374)... done.

*******************************************************************************

查看php migrate.php list

#         Timestamp

========================================================================

version           createtime              active  current note

1371546856        2013-06-18 17:14:16     1       0       v1

1380427212        2013-09-29 12:00:12     1       0       v1

1387349445        2013-12-18 14:50:45     1       0       test

1387350374        2013-12-18 15:06:14     1       1       test2

Page 1 of 1, 4 migrations in all.

执行回滚:

php migrate.php down 1380427212

返回一下结果:

Migrating to 2013-09-29 12:00:12 (ID 1380427212)...

Performing DOWN migration 2013-12-18 15:06:14 (ID 1387350374)... done.

Performing DOWN migration 2013-12-18 14:50:45 (ID 1387349445)... done.

#         Timestamp

========================================================================

version           createtime              active  current note

1371546856        2013-06-18 17:14:16     1       0       v1

1380427212        2013-09-29 12:00:12     1       1       v1

1387349445        2013-12-18 14:50:45     0       0       test

1387350374        2013-12-18 15:06:14     0       0       test2

Page 1 of 1, 4 migrations in all.

通过执行一下操作,查看数据库中数据变化

Mysql迁移工具在生产环境下的使用的更多相关文章

  1. mysql在生产环境下有大量锁表,又不允许重启的情况下的处理办法

    mysql在生产环境下有大量锁表,又不允许重启的情况下的处理办法 满头大汗的宅鸟该怎么办呢? mysql -u root -e "show processlist"|grep -i ...

  2. 四步法分析定位生产环境下MySQL上千条SQL中的问题所在

    第一步:通过以下两种方式之一来打开慢查询功能 (1)方式一:通过修改mysql的my.cnf文件 如果是5.0或5.1等版本需要增加以下选项: log-slow-queries="mysql ...

  3. 生产环境下,MySQL大事务操作导致的回滚解决方案

    如果mysql中有正在执行的大事务DML语句,此时不能直接将该进程kill,否则会引发回滚,非常消耗数据库资源和性能,生产环境下会导致重大生产事故. 如果事务操作的语句非常之多,并且没有办法等待那么久 ...

  4. 生产环境下JAVA进程高CPU占用故障排查

    问题描述:生产环境下的某台tomcat7服务器,在刚发布时的时候一切都很正常,在运行一段时间后就出现CPU占用很高的问题,基本上是负载一天比一天高. 问题分析:1,程序属于CPU密集型,和开发沟通过, ...

  5. 一次生产环境下MongoDB备份还原数据

    最近开发一个版本的功能当中用到了MongoDB分页,懒于造数据,于是就研究了下从生产环境上导出数据到本地来进行测试. 研究了一下,发现MongoDB的备份还原和MySQL语法还挺类似,下面请看详细介绍 ...

  6. 生产环境下JAVA进程高CPU占用故障排查---temp

    问题描述:生产环境下的某台tomcat7服务器,在刚发布时的时候一切都很正常,在运行一段时间后就出现CPU占用很高的问题,基本上是负载一天比一天高. 问题分析:1,程序属于CPU密集型,和开发沟通过, ...

  7. 生产环境下lnmp的权限说明

    https://www.cnblogs.com/zrp2013/p/4183546.html 有关权限说明:-rwxrw-r‐-1 root root 1213 Feb 2 09:39 50.html ...

  8. Python开发程序:生产环境下实时统计网站访问日志信息

    日志实时分析系统 生产环境下有需求:要每搁五分钟统计下这段时间内的网站访问量.UV.独立IP等信息,用直观的数据表格表现出来 环境描述: 网站为Nginx服务,系统每日凌晨会对日志进行分割,拷贝到其他 ...

  9. 生产环境下一定要开启mysqlbinlog

    在没有备份数据库的情况下,可以用binlog进行恢复 在生产环境下安全第一,损失一点点效率换来的安全还是值得的. http://www.cnblogs.com/zc22/archive/2013/06 ...

随机推荐

  1. IronPython 设置包路径

    C#中添加对python文件或者对python包的引用时出现"no module .."的问题时的解决办法. 对hello.py 做一些简单的修改 添加 import syssys ...

  2. 庭审精彩语录整理 z

    公诉人:用百度搜索淫秽关键字+快播,搜索结果得出超过4200万结果,可见快播在传播淫秽视频方面的巨大影响.王欣:这个没有任何意义,您可以用百度搜索淫秽关键字+QQ看有多少结果. 新浪科技讯 1月8日下 ...

  3. 学习“要件审判九步法”,正确处理五个关系 z

    学习“要件审判九步法”,正确处理五个关系 2015-06-29 07:39:07 | 来源:人民法院报第二版 | 作者:阮丹军 “要件审判九步法”,是邹碧华法官总结审判和审判管理双重经验后的心血之作, ...

  4. [Flex] PopUpButton系列——CornerRadius的运用

    <?xml version="1.0" encoding="utf-8"?><!--设置主按钮圆角半径 PopUpButtonCornerRa ...

  5. [ActionScript 3.0] AS3.0 对象在一定范围随机显示不重叠

    import flash.geom.Rectangle; import flash.display.MovieClip; import flash.display.Sprite; var arr:Ar ...

  6. 算法库:基础线性代数子程序库(Basic Linear Algebra Subprograms,BLAS)介绍

    调试DeepFlow光流算法,由于作者给出的算法是基于Linux系统的,所以要在Windows上运行,不得不做大量的修改工作.移植到Windows平台,除了一些头文件找不到外,还有一些函数也找不到.这 ...

  7. HDU 3068 [最长回文子串]

    #include<iostream> #include<string> #include<string.h> #include<algorithm> # ...

  8. 自动以读写方式挂载ntfs-黑苹果之路

    在mac下ntfs分区总是以只读方式挂载,双操作系统,尤其有些时候需要用u盘,需要手工umount再mount,很麻烦,找了一些资料,通过修改/etc/fstab文件无效,要么就是使用第三方软件,不合 ...

  9. 最小二乘拟合(转)good

    在物理实验中经常要观测两个有函数关系的物理量.根据两个量的许多组观测数据来确定它们的函数曲线,这就是实验数据处理中的曲线拟合问题.这类问题通常有两种情况:一种是两个观测量x与y之间的函数形式已知,但一 ...

  10. 【Flex教程】#009 As/typeof /instanceof /is的作用

    “as” :主要用它做类型转化 假设有一个类叫做Class1,我们声明了一个它的对象 c1,如果想要将它转换成Class2类型,只要这样写: Class2(c1); AS3 中的操作符: as 实现就 ...