- #####################
- //設定
- ############### #######
- // バックアップ ディレクトリの名前を定義します
- define('BACKUP_DIR', './myBackups' ) ;
- // データベース資格情報を定義します
- define('HOST', 'localhost' ) ;
- define('USER', 'testd!b' ) ;
- define('パスワード', 'k^$2y4n9@#VV' ) ;
- define('DB_NAME', 'test123' ) ;
- /*
- SQL ファイルのファイル名を定義します
- ファイルを Amazon の S3 サービスにアップロードする場合は、小文字のみを使用してください
- */
- $fileName = 'mysqlbackup--' 。 date('d-m-Y') 。 '@'.date('h.i.s').'.sql' ;
- // 実行時間制限を設定します
- if(function_exists('max_execution_time')) {
- if( ini_get('max_execution_time') > 0 ) set_time_limit(0) ;
- }
- ######## #################
- //設定終了
- ######################## ###
- // ディレクトリが既に作成されており、適切な権限があるかどうかを確認します
- if (!file_exists(BACKUP_DIR)) mkdir(BACKUP_DIR , 0700) ;
- if (!is_writable(BACKUP_DIR)) chmod(BACKUP_DIR , 0700) ;
- // ".htaccess" ファイルを作成します。これにより、バックアップ ディレクトリへの直接アクセスが制限されます。
- $content = 'すべてから拒否' ;
- $file = new SplFileObject(BACKUP_DIR . '/.htaccess', "w") ;
- $file->fwrite($content) ;
- $mysqli = new mysqli(HOST , USER , PASSWORD , DB_NAME) ;
- if (mysqli_connect_errno())
- {
- printf("Connect failed: %s", mysqli_connect_error());
- exit();
- }
- // 紹介情報
- $return .= "--n";
- $return .= "-- Mysql バックアップ システム n";
- $return .= "--n";
- $return .= '-- エクスポートが作成されました: ' . date("Y/m/d") 。 ' の上 ' 。 date("h:i") 。 "nnn";
- $return = "--n";
- $return .= "-- データベース : " . DB_NAME 。 "n";
- $return .= "--n";
- $return .= "-- ------------------------- -----------------------n";
- $return .= "------- ------------------------------------n";
- $return .= 'SET AUTOCOMMIT = 0 ;' ."n" ;
- $return .= 'SET FOREIGN_KEY_CHECKS=0 ;' ."n" ;
- $tables = array() ;
- // このデータベースにどのようなテーブルがあるかを調査します
- $result = $mysqli->query('SHOW TABLES' ) ;
- // "$result" を循環させ、コンテンツを配列に入れます
- while ($row = $result->fetch_row())
- {
- $tables[] = $row[0] ;
- }
- // Cycle各テーブルを通して
- foreach($tables as $table)
- {
- // 各テーブルの内容を取得します
- $result = $mysqli->query('SELECT * FROM '. $table) ;
- // 各テーブルのフィールド(列)数を取得
- $num_fields = $mysqli->field_count ;
- // テーブル情報を追加
- $return .= "--n" ;
- $return .= '-- Tabelテーブル `' の構造。 $テーブル 。 「」。 "n" ;
- $return .= "--n" ;
- $return.= 'DROP TABLE IF EXISTS `'.$table.'`;' 。 「ん」 ;
- // テーブルシェマを取得
- $shema = $mysqli->query('SHOW CREATE TABLE '.$table) ;
- // テーブルシェマを抽出
- $tableshema = $shema->fetch_row() ;
- // コードにテーブル シェマを追加します
- $return.= $tableshema[1].";" 。 「ん」 ;
- // 各テーブル行を循環します
- while($rowdata = $result->fetch_row())
- {
- // テーブルにデータを挿入するコードを準備します
- $return .= 'INSERT INTO `'.$table .'` VALUES ( ' ;
- // 各行のデータを抽出します
- for($i=0; $i{
- $return .= '"'.$rowdata[$i] . ""," ;
- }
- // 最後のカンマを削除しましょう
- $return = substr("$return", 0, -1) ;
- $return .= ");" ."n" ;
- }
- $return .= "nn" ;
- }
- // 接続を閉じます
- $mysqli->close() ;
- $return .= 'SET FOREIGN_KEY_CHECKS = 1 ; ' 。 「ん」 ;
- $return .= 'コミット ; ' 。 "n" ;
- $return .= 'SET AUTOCOMMIT = 1 ; ' 。 「ん」 ;
- //$file = file_put_contents($fileName , $return) ;
- $zip = new ZipArchive() ;
- $resOpen = $zip->open(BACKUP_DIR . '/' .$fileName.".zip" , ZIPARCHIVE::CREATE) ;
- if( $resOpen ){
- $zip ->addFromString( $fileName , "$return" ) ;
- }
- $zip->close() ;
- $fileSize = get_file_size_unit(filesize(BACKUP_DIR . "/". $fileName . '.zip')) ;
- $message = <<
バックアップが完了しました、
- アーカイブの名前は次のとおりです: $ファイル名 ファイルサイズは $fileSize です。
- この zip アーカイブは保護されたディレクトリに保存されているため、Web ブラウザからはアクセスできません。
- このバックアップを別のファイルシステムに転送し、お気に入りの FTP クライアントを使用してアーカイブをダウンロードすることを強くお勧めします。
- msg;
- echo $message ;
-
- // file-size の後に適切な Unit を追加する関数。
- function get_file_size_unit($file_size){
- switch (true) {
- case ($file_size/1024 return intval($file_size ) ." バイト" ;
- Break;
- case ($file_size/1024 > = 1 && $file_size/(1024*1024) < 1) :
- return intval($file_size/1024) ." KB" ;
- ブレーク;
- デフォルト:
- return intval($file_size/(1024*1024)) 。 " MB" ;
- }
- }
-
复制代
|