🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
NFS

NFS (Network File System) とは、ネットワークを介して外部ストレージにアクセスするための分散ファイルシステムです。

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

2回答

5795閲覧

PHPコマンド:renameで成功と失敗が混在する?

hanamichi

総合スコア13

NFS

NFS (Network File System) とは、ネットワークを介して外部ストレージにアクセスするための分散ファイルシステムです。

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2019/09/17 06:23

sansanと申します。

●環境
OS:CentOS6.3 (64bit)
PHP:5.3.18

データ格納サーバ:
192.168.1.100
格納ディレクトリ:
/data/
→この場所は、192.168.2.50上の/share 部分をNFSマウントしている
格納ファイル等 :
A001.TXT、B001.TXT

バックアップ  :
上記の92.168.1.100上のローカルディレクトリ → /home/ZZZZ/backup/

上記の環境で、PHPコマンドで次のrename関数を用いて流すのですが、例えば格納ファイルのA001.TXTは成功するんですが、B001.TXTは以下のエラー表示が出ます。しかし、バックアップ先にはちゃんとバックアップされています。
但し、エラー吐いているので格納ディレクトリには、ファイル(B001.TXT)が残ったままになります。まっ、当然ですが。

rename成功と失敗が何故に発生するのは不思議です。
ここ数日、悩んでおります。どなたかご教示ください。

 ※A001.TXTとB001.TXTの違いは何もありません。サイズも同じ。

★以下のエラー Invalid argument in の回避は、以下のソース抜粋で強制的に配列化(array)にしています。
foreach((array)glob($dir."/R*.".$tenpo_code) as $file) {
$send_file[] = substr($file,31,43);
$file_name[] = substr($file,31,3);
}

●エラー表示
Warning: rename(/data/B001.TXT,/home/ZZZZ/backup/20190917144108_B001.TXT): Invalid argument in /data/

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

otn

2019/09/17 10:57 編集

ソースコードを載せてください。
hanamichi

2019/09/18 01:27

了解です。業務に追われているので、少しお時間を頂戴します。
hanamichi

2019/09/18 04:01

以下が主要部分のソースになります。 前半部分のDB処理等は割愛します。 よろしくお願い致します。 // 変数の初期化 $send_file = ""; $file_name = ""; $file = ""; forは省略 // 先にマッチングパターン用意 $pattern = "{".$dir."/A*.TXT,".$dir."/B*.TXT,".$dir."/C*.TXT}"; $files = glob( $pattern , GLOB_BRACE ); switch ( $xxxxxx ) { case "ZZZZ": foreach((array)glob($dir."/A*.TXT") as $file) { $send_file[] = substr($file, -31); $file_name[] = substr($file,41,8); } foreach((array)glob($dir."/B*.TXT") as $file) { $send_file[] = substr($file, -31); $file_name[] = substr($file,41,8); } foreach((array)glob($dir."/C*.TXT") as $file) { $send_file[] = substr($file, -31); $file_name[] = substr($file,41,8); } break; default: } -----途中省略------ forは省略 $userFileInfo = UserFileConfig_GGGGGGGG::getMainteFtpData( $file_name[$j] ); $userFileInfo["FILE"] = $send_file[$j]; $userFileInfo["PATH_WORK"] = $userFileInfo["PATH_WORK"]; $userFileInfo["PATH_BACKUP"] = $userFileInfo["PATH_BACKUP"]; // ファイルをバックアップ if ( $result_file == SYORI_OK ) { if ( rename( $userFileInfo["PATH"].$userFileInfo["FILE"],$userFileInfo["PATH_BACKUP"].$this->GVAL["time_stamp"]."_".$userFileInfo["FILE"] ) ) { $this->log->rep(PNAME,"ファイル[".$userFileInfo["FILE"]."]は、".$userFileInfo["PATH_BACKUP"]."にバックアップされました。"); } else { $this->log->rep(PNAME,"ファイル[".$userFileInfo["FILE"]."]は、バックアップに失敗しました。"); $result_file = SYORI_NG; } }
guest

回答2

0

rename成功と失敗が何故に発生するのは不思議です。

異なるディスクへのrenameは、実際にはコピーと削除なので、コピーが成功して削除が失敗しただけで、特に不思議ではないです。
NFSサーバー側のログに何か出ているのでは?

投稿2019/09/17 11:04

otn

総合スコア85888

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hanamichi

2019/09/18 05:15

NFSサーバー側のログには異常な記録は無いようでした。
otn

2019/09/18 05:56

実行ユーザーから、/data/と、/data/B001 の両方の書き込み権限はありますか?
hanamichi

2019/09/19 04:53

はい、あります。 今のパーミッション=777にしてありますので、OKです。
otn

2019/09/19 05:17

そうですか。 PHPのメッセージしかないので、究明が難しいですね。 再現性がなければ、諦めるか。 調べるとすると、NFS越しのファイル削除の失敗なので、その方面で情報を探すか。
hanamichi

2019/09/19 07:18

開発系との相違は、NFSなし(ローカル環境のみ)で、一切、このようなエラーは無いですね。 本番系では、実は他の開発者も似たような事=rename[NFS越し]処理をして おり、エラーは無いとの事です。 違うのは私は「glob関数」を使用している事ですが、Warning=Invalid argument in が出ています。無効な引数・・・・?? 色々と試行しますが、このInvalid argument inが消えません。 何故なんだろう・・・・・
otn

2019/09/19 07:30

再現性があるんですか?
hanamichi

2019/09/19 07:49

はい、必ず再現します。
guest

0

しかし、バックアップ先にはちゃんとバックアップされています。

バックアップされたのではなく同名のファイルが元からあって
パーミッションエラーかなにかで上書きできなかったのでは?

投稿2019/09/17 07:04

yambejp

総合スコア116688

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hanamichi

2019/09/17 07:19

ありがとうございます。 いえ、バックアップ先にファイルが何もない状態です。 もし、同名ファイルが存在しても rename関数 は 上書きの仕様と理解しております。
yambejp

2019/09/17 07:22

> rename関数 は上書きの仕様 それはパーミッションが許せばという前提があります
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問