FTPサーバーにアップロードされたファイルを抽出できません

FTPサーバーにアップロードされたファイルを抽出できません

ソースシステム:

  • セント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

関連情報