2010-07-10 162 views
7

我们正在运行一个PHP(zend框架)应用程序,它为每个用户(安全/备份/等原因)创建一个数据库。所有这些数据库具有完全相同的结构,并且始终如此。当我们部署新功能时,我们需要用新的字段/表扩展所有的数据库。一次更改多个mysql数据库(SAAS数据库更改)

我已经阅读过有关使用dbdeploy的内容,但我不确定它们是否一次支持多个数据库(没有逐个给出名称)。数据库称为user1,user2,user3等。

有没有什么好的工具可以让我们的这个过程更容易一些,而且不那么痛苦? 我们正在运行phing进行自动化部署,并发现指南http://www.davedevelopment.co.uk/2008/04/14/how-to-simple-database-migrations-with-phing-and-dbdeploy/不是很有用,因为它们不像我们那样支持多个数据库。

而且,可以做到这一点Windows或Mac MySQL客户是可行的我们,所以我们是开放的任何

+1

这些数据库都在同一台服务器上吗? – 2010-07-29 12:47:37

+0

是的,所有dbbase都在同一台服务器上! – Jorre 2010-08-16 18:33:35

回答

14

这里是我放在一起为你的PHP脚本。它获取所有数据库的列表,并在数据库名称以user开头时应用更新。

我也有备份每个数据库,然后应用更改。备份部分特定于Linux/Unix,但可以调整为适用于其他操作系统。

这是相当详细的,所以你可以根据需要进行更改。您也可以更改行结束符,具体取决于您是从CLI还是浏览器运行它。我会建议把它放在你的脚本目录中,并从CLI运行它。

让我知道你是否需要别的东西或者这不适合你。

<?php 
// Configure these as needed 
$db_host = 'localhost'; 
$db_user = 'user'; 
$db_pass = 'password'; 

$datetime_pattern  = date('Ymd.His'); 
$backup_file_path  = "/path/to/db_backups/$datetime_pattern/"; 
$backup_file_format  = "db_backup.%s.sql"; 
$backup_syntax_pattern = "/usr/bin/mysqldump --host=%s --user=%s --password=%s --opt %s > $backup_file_path/db_backup.%s.sql"; 
// !!!!!!!!!!!!!!!!!!!!!!!!!!!! 
// CHANGE THE PERMISSIONS!!!!!! 
// !!!!!!!!!!!!!!!!!!!!!!!!!!!! 
$backup_file_permission = 0777; 

// Choose how to terminate your lines 
$line_end = "\n";  // Use for CLI 
//$line_end = "<br/>"; // Use for browser 

// Match words that begin with 'user', case-insensitive 
$pattern = '/^user/i'; 

// What changes will we be applying? 
$db_update_syntax = array("ALTER TABLE foo ADD baz1 VARCHAR(30) AFTER bar1", 
          "ALTER TABLE foo ADD baz2 VARCHAR(30) AFTER bar2", 
          "ALTER TABLE foo ADD baz3 VARCHAR(30) AFTER bar3", 
         ); 

// END OF CONFIGURATION 
///////////////////////////////////////////////////////////// 


// Create the database backup directory 
if (!mkdir($backup_file_path, $backup_file_permission, true)) { 
    die('Failed to create backup directory...'); 
} 

// Connecting to MySQL. 
$conn = @mysql_connect($db_host, $db_user, $db_pass) 
     or die('Not connected : ' . mysql_errno() . ': ' . mysql_error()); 

$db_list = mysql_list_dbs($conn); 

echo "{$line_end}Starting Database Update.{$line_end}"; 
while ($row = mysql_fetch_assoc($db_list)) { 
    $db_name = $row['Database']; 
    if (preg_match($pattern, $db_name)) { 
     echo "{$line_end}A match was found: [$db_name]{$line_end}"; 
     echo "Backing up the database{$line_end}"; 
     // Backup the database 
     $backup_syntax = sprintf($backup_syntax_pattern, $db_host, $db_user, $db_pass, $db_name, $db_name); 
     exec($backup_syntax); 
     $db_selected = mysql_select_db($db_name, $conn) 
         or die("Can't use [$db_name] : " . mysql_error()); 

     foreach ($db_update_syntax as $each_update_syntax) { 
      echo "Altering using: [$alter_syntax]{$line_end}"; 
      $update_status = mysql_query($alter_syntax); 
      if ($update_status) { 
       echo "Success!{$line_end}{$line_end}"; 
      } else { 
       echo "Unable to update [$db_name] : " . mysql_error() . "{$line_end}{$line_end}"; 
      } 
     } 
    } else { 
     echo "Ignoring: [$db_name]{$line_end}"; 
    } 
} 
echo "Finished!{$line_end}"; 
// Free resources/Close MySQL Connection 
mysql_free_result($db_list); 
mysql_close($conn); 
+0

我正在检查这一个,看它是否可以做我们正在寻找的东西。感谢您发布这么大的脚本! – Jorre 2010-08-30 18:15:28

+0

您是否可以预见繁忙的数据库上有关锁定的任何问题? – Jorre 2010-08-30 18:17:49

+0

在没有连接的数据库上工作就像一个魅力。在拥有大量用户的实时数据库中,您有什么体验? – Jorre 2010-08-31 16:21:36