簡體   English   中英

mysqldump命令不執行,只是保存在文件中

[英]mysqldump command is not executed just it is saved on a file

我正在編寫一個用於備份數據庫的php腳本,其思想是使用mysqldump命令,然后下載帶有結果的sql文件,不幸的是mysqldump的輸出未保存在文件中,僅保存在源代碼中。 這是代碼:

    $archivo = 'bkbiblioteca_' . date("d-m-Y_H:i:s") . '.sql';      
    $comando = "mysqldump --add-drop-table --host=$servidor --user=$usuario --password=$clave $base > $archivo";
    try{
        $archivo_manejador = fopen($archivo, 'w+');
        fwrite($archivo_manejador, $comando);
        fclose($archivo_manejador);
        header('Content-Description: File Transfer');
        header('Content-Type: application/octet-stream');
        header('Content-Disposition: attachment; filename=' . basename($archivo));
        header('Content-Transfer-Encoding: binary');
        header('Expires: 0');
        header('Cache-Control: must-revalidate');
        header('Pragma: public');
        header('Content-Length: ' . filesize($archivo));
        ob_clean();
        flush();
        readfile($archivo);
        unlink($archivo);      
      }catch(\Exception $e){
        echo 'error en el proceso de bk' . $e->getMessage(); //TODO: favor incluir en la bitacora global del sistema
      }//fin de catch

現在,我正在使用以下行獲取文件:mysqldump --add-drop-table --host = $ servidor --user = $ usuario --password = $ clave $ base> $ archivo

我已經嘗試使用此命令:

system("$comando");

但這是行不通的,因此我無法弄清楚如何執行mysqldump命令並在文件中獲取結果,而不是獲取源代碼行。

提前致謝

刪除此行可解決問題:

$archivo_manejador = fopen($archivo, 'w+');

現在,我得到所需的輸出。 感謝FrancoisHuppé的評論。

使用mysqldump--result-file選項創建轉儲文件,然后可以將其發送到瀏覽器進行下載。 完整的命令為(根據需要插入文件名):

exec('mysqldump --user=backup --password="yourpasswordhere#" --routines --insert-ignore --complete-insert --force --result-file=name_of_your_dump_file_here.sql --databases ' . $yourdatabasename);

嘗試:

system($comando);

或者可能:

exec($comando);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM