ソースシステム:
- セントOS7
- バッシュシェル
- ジップ
宛先システム:
- FTPサーバー
- 6.4 の
- バッシュシェル
- 解凍
シェルスクリプトを使用してファイルをアーカイブし、FTPサーバーに送信するスクリプトを作成しました。
#!/bin/bash
# Declare no. of days
days=15
# Declare Source path of sql files and Destination path of backup directory
dumps=/home/applications/backup
bkpdir=/home/applications/backup/olddumps
# Find sql dumps of ets
files=($(find $dumps/*.sql -mtime +"$days"))
for file in ${files[*]}
do
# Move each file into backup dir which is 15 days old
echo "file is: $file\n";
mv $file $bkpdir
# Find the sql files and compress them
cd $bkpdir
filename=$(basename $file)
zip $bkpdir/$filename.zip $filename
# FTP Login
HOST=a.b.c.d
USER=xxxx
PASS=yyyyy
REM_DIR=/olddumps/sqlfiles
echo "Uploading file via FTP:"
ftp -in $HOST <<EOF
quote USER $USER
quote PASS $PASS
cd $REM_DIR
put $filename.zip
bye
EOF
# Remove sql files if any
rm $bkpdir/$filename
done
# Remove compressed files which are 6 months old
find $bkpdir/*.zip -type f -mtime +180 -exec rm {} \;
ここで問題となるのは、宛先システム内の圧縮ファイルがコマンドを使用して抽出されずunzip
、次のエラーが表示されることです。
アーカイブ: emt_bus-08-09-16-03-29.sql.zip
caution: zipfile comment truncated
error [emt_bus-08-09-16-03-29.sql.zip]: missing 49666528 bytes in zipfile
(attempting to process anyway)
error [emt_bus-08-09-16-03-29.sql.zip]: start of central directory not found;
zipfile corrupt.
(please check that you have transferred or created the zipfile in the
appropriate BINARY mode and that you have compiled UnZip properly)
以前はアーカイブしていましたtar
が、うまくいきませんでした。宛先システムでファイルを抽出できず、次のエラーが表示されます。
gzip: stdin: invalid compressed data--format violated
emt_bus-08-09-16-03-29.sql
tar: Unexpected EOF in archive
tar: Unexpected EOF in archive
tar: Error is not recoverable: exiting now
問題を解決するにはどうすればよいですか?
答え1
おそらく、そのスクリプトを実行したときに表示されないエラー メッセージが既に存在している可能性があります。
script.sh > log.txt 2>&1を実行して、すべての出力をログに記録します。
最後の部分はstderrをstdout(この場合はlog.txt)にリダイレクトします。
おそらく、タイムアウトが発生していること (送信しているファイルの数、接続の安定性)、または次のコマンドを待機するはずのコマンドが実際にはスクリプト内で待機していないことが分かるでしょう。
答え2
スクリプトはbinary
(quote
コマンドの後に) を設定する必要があります。そうでない場合、このスクリプトではテキスト モードが使用されます。
対話型の場合、先ほどテストした FTP クライアントはバイナリ モードを想定します。ただし、非対話型の場合にはそうではありません。
私がテストして修正したものは次のとおりです:
#!/bin/sh
ftp -in invisible-island.net <<EOF
quote USER anonymous
quote PASS anonymous
binary
cd cproto
get cproto.tar.gz
bye
EOF