>백엔드 개발 >PHP 튜토리얼 >MySQL 데이터를 백업하는 PHP 코드

MySQL 데이터를 백업하는 PHP 코드

WBOY
WBOY원래의
2016-07-25 08:45:50898검색
  1. ###################
  2. //구성
  3. ###################
  4. // 백업 디렉터리 이름 정의
  5. define('BACKUP_DIR', './myBackups' ) ;
  6. // 데이터베이스 자격 증명 정의
  7. define('HOST', 'localhost' ) ;
  8. define('USER', 'testd!b' ) ;
  9. define('PASSWORD', 'k^$2y4n9@#VV' ) ;
  10. define('DB_NAME', 'test123' ) ;
  11. /*
  12. sql 파일의 파일 이름 정의
  13. Amazon의 S3 서비스에 파일을 업로드하려는 경우 소문자만 사용하세요.
  14. */
  15. $fileName = 'mysqlbackup- -' . 날짜('d-m-Y') . '@'.date('h.i.s').'.sql' ;
  16. // 실행 시간 제한 설정
  17. if(function_exists('max_execution_time')) {
  18. if( ini_get('max_execution_time') > 0 ) set_time_limit(0) ;
  19. }
  20. #########################
  21. //구성 종료
  22. #### #####################
  23. // 디렉터리가 이미 생성되었고 적절한 권한이 있는지 확인
  24. if (!file_exists( BACKUP_DIR)) mkdir(BACKUP_DIR , 0700) ;
  25. if (!is_writable(BACKUP_DIR)) chmod(BACKUP_DIR , 0700) ;
  26. // ".htaccess" 파일을 생성하면 백업 디렉터리에 대한 직접 액세스가 제한됩니다.
  27. $content = '모두 거부' ;
  28. $file = new SplFileObject(BACKUP_DIR . '/.htaccess', "w") ;
  29. $file->fwrite($content) ;
  30. $mysqli = new mysqli(HOST , USER , PASSWORD , DB_NAME) ;
  31. if (mysqli_connect_errno())
  32. {
  33. printf("연결 실패: %s", mysqli_connect_error());
  34. exit();
  35. }
  36. // 소개 정보
  37. $return .= "--n";
  38. $return .= "-- A MySQL 백업 시스템 n";
  39. $return .= "--n";
  40. $return .= '-- 내보내기 생성됨: ' . 날짜("연/월/일") . ' 에 ' . 날짜("h:i") . "nnn";
  41. $return = "--n";
  42. $return .= "-- 데이터베이스: " . DB_NAME. "n";
  43. $return .= "--n";
  44. $return .= "-- ---------- --------------n";
  45. $return .= "-- ---------- ---------------n";
  46. $return . = '자동 커밋 설정 = 0;' ."n" ;
  47. $return .= 'SET FOREIGN_KEY_CHECKS=0 ;' ."n" ;
  48. $tables = 배열() ;
  49. // 이 데이터베이스에 어떤 테이블이 있는지 탐색
  50. $result = $mysqli->query('SHOW TABLES' ) ;
  51. // "$result"를 순환하고 콘텐츠를 배열에 넣습니다
  52. while ($row = $result->fetch_row())
  53. {
  54. $tables[] = $row[0 ] ;
  55. }
  56. // 각 테이블 순환
  57. foreach($tables as $table)
  58. {
  59. // 각 테이블의 콘텐츠 가져오기
  60. $result = $mysqli-> ;query('SELECT * FROM'.$table) ;
  61. // 각 테이블의 필드(열) 개수 가져오기
  62. $num_fields = $mysqli->field_count ;
  63. // 테이블 정보 추가
  64. $return .= "--n" ;
  65. $return .= '-- 테이블 `' 의 테이블 구조. $테이블 . ''' . "n" ;
  66. $return .= "--n" ;
  67. $return.= '존재하는 경우 테이블 삭제 `'.$table.'`;' . "N" ;
  68. // 테이블 셰마 가져오기
  69. $shema = $mysqli->query('SHOW CREATE TABLE '.$table) ;
  70. // 테이블 셰마 추출
  71. $tableshema = $shema- >fetch_row() ;
  72. // 코드에 table-shema 추가
  73. $return.= $tableshema[1].";" . "nn" ;
  74. // 각 테이블 행을 순환
  75. while($rowdata = $result->fetch_row())
  76. {
  77. // 테이블에 데이터를 삽입할 코드 준비
  78. $return .= 'INSERT INTO `'.$table .'` VALUES ( ' ;
  79. // 각 행의 데이터 추출
  80. for($i=0; $i{
  81. $return .= '"'.$rowdata[$i] . ""," ;
  82. }
  83. // 마지막 쉼표를 삭제합니다
  84. $return = substr("$return", 0, -1) ;
  85. $return .= ");" ."n" ;
  86. }
  87. $return .= "nn" ;
  88. }
  89. // 연결 닫기
  90. $mysqli->close() ;
  91. $return .= 'SET FOREIGN_KEY_CHECKS = 1 ; ' . "N" ;
  92. $return .= '커밋 ; ' . "n" ;
  93. $return .= 'SET AUTOCOMMIT = 1 ; ' . "N" ;
  94. //$file = file_put_contents($fileName , $return) ;
  95. $zip = 새 ZipArchive() ;
  96. $resOpen = $zip->open(BACKUP_DIR . '/' .$fileName.".zip" , ZIPARCHIVE::CREATE) ;
  97. if( $ resOpen ){
  98. $zip->addFromString( $fileName , "$return" ) ;
  99. }
  100. $zip->close() ;
  101. $fileSize = get_file_size_unit(filesize(BACKUP_DIR . "/". $fileName . '.zip')) ;
  102. $message = <<

    백업 완료,


  103. 아카이브 이름은 $fileName 파일 크기는 $fileSize 입니다.
  104. 이 zip 아카이브는 보호된 디렉토리에 저장되어 있으므로 웹 브라우저를 통해 접근할 수 없습니다.
  105. 이 백업을 다른 파일 시스템으로 전송하는 것이 좋습니다. 즐겨 사용하는 FTP 클라이언트를 사용하여 아카이브를 다운로드하세요.
  106. msg;
  107. echo $message ;
  108. // 파일 크기 뒤에 적절한 단위를 추가하는 기능입니다.
  109. function get_file_size_unit($file_size){
  110. switch (true) {
  111. case ($file_size/1024 < 1) :
  112. return intval($file_size ) ." Bytes" ;
  113. break ;
  114. 케이스 ($file_size/1024 >= 1 && $file_size/(1024*1024) < 1) :
  115. return intval($file_size/1024) ." KB" ;
  116. break;
  117. 기본값:
  118. return intval($file_size/(1024*1024)) ." MB" ;
  119. }
  120. }
复system代码

MySQL, PHP


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.