5

MySQLバックアップを実行してメールで送信することになっている短いPHPスクリプトがあります。ただし、データも構造体もmysqldumpによって書き込まれていません。mysqldumpを呼び出すコマンドは次のようになります。

mysqldump --host=localhost --user=xxx --pass=xxx xxx_license > xxx2012-12-28.sql

(xxxのユーザー名とパスワードは、phpとデータベースで機能する別のスクリプトのものと同じであるため、資格情報が正しいことがわかります)。

出力は次のとおりです。

-- MySQL dump 10.13  Distrib 5.5.28, for Linux (x86_64)
--
-- Host: localhost    Database: xxx_license
-- ------------------------------------------------------
-- Server version   5.5.28-cll

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--
-- Current Database: `xxx_license`
--

CREATE DATABASE /*!32312 IF NOT EXISTS*/ `xxx_license` /*!40100 DEFAULT CHARACTER SET latin1 */;

USE `xxx_license`;

CREATEステートメントとUSEステートメントは、オプションに--databasesを追加した場合にのみ存在します。

また、-helpを使用してデフォルトのオプションを表示するのは次のとおりです。

mysqldump  Ver 10.13 Distrib 5.5.28, for Linux (x86_64)

<snip>

Variables (--variable-name=value)
and boolean options {FALSE|TRUE}  Value (after reading options)
--------------------------------- ----------------------------------------
all-databases                     FALSE
all-tablespaces                   FALSE
no-tablespaces                    FALSE
add-drop-database                 FALSE
add-drop-table                    TRUE
add-locks                         TRUE
allow-keywords                    FALSE
apply-slave-statements            FALSE
character-sets-dir                (No default value)
comments                          TRUE
compatible                        (No default value)
compact                           FALSE
complete-insert                   FALSE
compress                          FALSE
create-options                    TRUE
databases                         FALSE
debug-check                       FALSE
debug-info                        FALSE
default-character-set             utf8
delayed-insert                    FALSE
delete-master-logs                FALSE
disable-keys                      TRUE
dump-slave                        0
events                            FALSE
extended-insert                   TRUE
fields-terminated-by              (No default value)
fields-enclosed-by                (No default value)
fields-optionally-enclosed-by     (No default value)
fields-escaped-by                 (No default value)
flush-logs                        FALSE
flush-privileges                  FALSE
force                             FALSE
hex-blob                          FALSE
host                              (No default value)
include-master-host-port          FALSE
insert-ignore                     FALSE
lines-terminated-by               (No default value)
lock-all-tables                   FALSE
lock-tables                       TRUE
log-error                         (No default value)
master-data                       0
max-allowed-packet                25165824
net-buffer-length                 1046528
no-autocommit                     FALSE
no-create-db                      FALSE
no-create-info                    FALSE
no-data                           FALSE
order-by-primary                  FALSE
port                              0
quick                             TRUE
quote-names                       TRUE
replace                           FALSE
routines                          FALSE
set-charset                       TRUE
single-transaction                FALSE
dump-date                         TRUE
socket                            (No default value)
ssl                               FALSE
ssl-ca                            (No default value)
ssl-capath                        (No default value)
ssl-cert                          (No default value)
ssl-cipher                        (No default value)
ssl-key                           (No default value)
ssl-verify-server-cert            FALSE
tab                               (No default value)
triggers                          TRUE
tz-utc                            TRUE
user                              (No default value)
verbose                           FALSE
where                             (No default value)
plugin-dir                        (No default value)
default-auth                      (No default value)

これらのオプションの何かが間違っている場合、どうすればそれを変更/オーバーライドできますか?構成ファイルが見つからず、アクションを実行するためのWebサーバーへのSSHアクセスがありません。

ありがとう。

4

5 に答える 5

5

ユーザーの権限を確認し、すべてのテーブルに対するSELECT権限があることを確認してください。また、テーブルをロックする権限がない場合は、を使用して--skip-lock-tablesください。

于 2012-12-29T01:08:15.583 に答える
1

MySql 5.7でも、テーブル構造をキャプチャしようとして同じ問題が発生しました。これを機能させるには、コマンドラインに--databases--tablesを明示的に配置する必要がありました。たとえば、データと構造の場合:

mysqldump --defaults-extra-file=$confFile --databases $db --tables $tables > ./backup_db.sql

1つのテーブルの定義だけの例:

mysqldump --defaults-extra-file=$confFile -d --databases $db --tables $table > ./table_cre.sql
于 2018-05-24T17:22:50.337 に答える
0

手順を試してください:

mysqldump –u[ユーザー名]–p[データベース名]>[ダンプファイル]

エンターキーを押す

パスワード

エンターキーを押す

mysqldump –uxxx –p xxx_license > xxx2012-12-28.sql

press enter key

ここでパスワードを入力します

xxx

press enter key

私のために働きます。

于 2012-12-28T21:35:05.420 に答える
0

同じ問題が発生しました。「mysqldump.exe」を最新バージョンに更新することで解決しました(サーバーとバックアップサーバーがMySQLバージョンに関して同期していませんでした)

于 2016-02-19T15:36:07.820 に答える
0

コマンドラインからダンプを実行できますか?それから始められないなら、そこから始めてください。可能であれば、はPHPスクリプトを実行しているため、スクリプトに、ダンプの保存先のディレクトリへの書き込み権限があることを確認してください。所有者/グループのアクセス許可と保存先のディレクトリのアクセス許可を確認してください。

于 2016-03-29T22:42:13.960 に答える