前提
VisualStudioで作成した業務管理系のWebアプリケーションを作成し、それをDockerコンテナ上にて動作の検証を行っております。
動作検証にて
Webアプリの機能としてログインやDBのデータを表示するといったものは正常に動作するのですが、ログ出力やファイルのアップロードとといった、ディレクトリ操作、ファイルへの書き込み系の処理(ローカルでは正常に動作していた)でエラーとなってしまいます。
エラーをログに出力するようにしていましたが、ログにも書き込まれない状況なので、困っています。ログ出力には、ロギングツールとしてNlogを使用しています。
ログ出力の設定は以下のとおりです。
<target xsi:type="File" name="errorlog" fileName="./App_Data/log/error/errorlog.log" encoding="UTF-8" layout="${longdate} ${level:uppercase=true} ${identity} ${message} ${exception:format=tostring}" archiveDateFormat = "yyyyMMdd" archiveNumbering="Date" archiveEvery="Monday" archiveFileName="./App_Data/log/error/bk/{#}.errorlog.zip" enableArchiveFileCompression ="true" />
理解が浅いうえ、環境構築は他者が担当したため、自身も不明点が多く大変申し訳ないのですが、なにか考えられる原因はないでしょうか。上記解決に必要な情報ありましたら、追記いたします。
よろしくお願いいたします。
補足情報(FW/ツールのバージョンなど)
ローカルの環境
ASP.NET MVC5
IIS Express
Dockerの環境
ウェブサーバー:IIS
> VisualStudioで作成したWebアプリをDockerコンテナ上に配置し、
「Webアプリ」って何ですか? 「Dockerコンテナ上に配置」ってどういうことですか?
環境構築した方に相談することはできないのでしょうか?
書き込みしている部分のソースコードと エラーメッセージをそのまま 質問に記載していただくことは可能ですか?
Webアプリの実行ユーザに対して出力先ディレクトリへの書き込み権限はありますか?
ls -la
質問者さん、前に https://teratail.com/questions/v071melkydsv9h でハマってた人ですよね。聞いたことにはちゃんと答えませんか? また話が噛み合わなくなりますので。
SurferOnWww様
「Webアプリ」って何ですか? 「Dockerコンテナ上に配置」ってどういうことですか?
⇒理解が浅く表現が分かりづらくすみません。Dockerコンテナ上でのテストと表現すれば、伝わりますでしょうか。
CHERRY様
環境構築した方に相談することはできないのでしょうか?
⇒難しい状況です。
書き込みしている部分のソースコードと エラーメッセージをそのまま 質問に記載していただくことは可能ですか?
⇒ログ出力の設定を追記させていただきましたが、他は難しいです。エラーメッセージはログにとるようにしていたのですがログにすら出力されないので、こちらも現状難しいです。すみません。
t-n様
Webアプリの実行ユーザに対して出力先ディレクトリへの書き込み権限はありますか?
⇒なんとなく、今回の問題の原因のように思えるのですが、このようなケースの場合にwebアプリの実行ユーザに対して、書き込み権限を与える設定が必要になってくるのでしょうか。でないとログ出力等も機能しなくなってしまうのでしょうか。
聞いたことにはちゃんと答えませんか? 「Webアプリ」って何ですか?
> Dockerコンテナ上でのテストと表現すれば、伝わりますでしょうか。
分かりません。運用環境で IIS で動かすのとどのように違うのですか?
質問者さん、無言ですが、回答したのでそれに対するフィードバックを返してください。役に立った/立たなかったぐらいはすぐに返せるのでは? 役に立たなかったならどこがダメかを書くとより期待に近い回答が出てくるかも。とにかく無言は NG です。
Dockerコンテナ上のOSの情報がまったく示されてないのもあって分かりませんが、
> fileName="./App_Data/log/error/errorlog.log"
では実行時のカレントディレクトリ下指定で、これも怪しそうですね。いずれにせよ情報不足の感は否めません。
質問者さん、その後無言ですが、聞いたことにはちゃんと答えませんか? 「Webアプリ」って何ですか? 「Dockerコンテナ上に配置」ってどういうことですか?
前のスレッドと同じ web アプリなら .NET Framework の ASP.NET MVC5 なので、web サーバーは Windows OS の IIS でないと動きません (開発環境は IIS Express。Docker なんちゃらでステージング環境を作ったなら IIS)。そうじゃないんですか? それすら答えられないほど何も分からないのですか?
dodox86 さん>
App_Data というフォルダは、Visual Studio のテンプレートを使って .NET Framework の(Core でない)ASP.NET アプリを作ると、名前のとおり Data の格納場所としてアプリのルート直下に自動的に作成されます。
それをログの保存場所にしたと想像。ログの保存場所として App_Data が適当かどうかはちょっと置いといて、少なくとも間違ってはいません。
ただし、回答に書いた通り、IIS にデプロイした場合ワーカープロセスに書き込み権限はないので、「WebアプリをDockerコンテナ上で動作させたところ、ファイルへの書き込み等が出来なくなった」という問題が出たのでしょう。自信度 99% ぐらいはあります。
SurferOnWww様
前のスレッドと同じ web アプリなら .NET Framework の ASP.NET MVC5 なので、web サーバーは Windows OS の IIS でないと動きません (開発環境は IIS Express。Docker なんちゃらでステージング環境を作ったなら IIS)。そうじゃないんですか? それすら答えられないほど何も分からないのですか?
⇒回答が漏れてしまい申し訳ありません。環境につきましては、仰る通りです。
IIS にデプロイした場合ワーカープロセスに書き込み権限はないので、「WebアプリをDockerコンテナ上で動作させたところ、ファイルへの書き込み等が出来なくなった」という問題が出たのでしょう。自信度 99% ぐらいはあります。
⇒上記に関しましても、理解できておらず、回答いただきました点について、しっかり調べ確認してみます。原因としても、回答いただいたことに起因するのかとおもいますので、SurferOnWww様の回答をベストアンサーにさせていただきます。ありがとうございます。
回答1件
あなたの回答
tips
プレビュー