質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
86.12%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

解決済

VisualStudioで作成したWebアプリをDockerコンテナ上で動作させたところ、ファイルへの書き込み等が出来なくなった。

MASUFISH
masu

総合スコア19

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

1回答

0リアクション

0クリップ

315閲覧

投稿2022/09/30 08:46

編集2022/10/01 01:01

前提

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

以下のような質問にはリアクションをつけましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

2022/09/30 13:21依頼された後にこの質問は修正されています

こちらの質問が他のユーザーから「やってほしいことだけを記載した丸投げの質問」という指摘を受けました。

SurferOnWww

2022/09/30 09:32

> VisualStudioで作成したWebアプリをDockerコンテナ上に配置し、 「Webアプリ」って何ですか? 「Dockerコンテナ上に配置」ってどういうことですか?
CHERRY

2022/09/30 09:34 編集

環境構築した方に相談することはできないのでしょうか? 書き込みしている部分のソースコードと エラーメッセージをそのまま 質問に記載していただくことは可能ですか?
t-n

2022/09/30 10:52

Webアプリの実行ユーザに対して出力先ディレクトリへの書き込み権限はありますか? ls -la
MASUFISH

2022/09/30 14:02

SurferOnWww様 「Webアプリ」って何ですか? 「Dockerコンテナ上に配置」ってどういうことですか? ⇒理解が浅く表現が分かりづらくすみません。Dockerコンテナ上でのテストと表現すれば、伝わりますでしょうか。 CHERRY様 環境構築した方に相談することはできないのでしょうか? ⇒難しい状況です。 書き込みしている部分のソースコードと エラーメッセージをそのまま 質問に記載していただくことは可能ですか? ⇒ログ出力の設定を追記させていただきましたが、他は難しいです。エラーメッセージはログにとるようにしていたのですがログにすら出力されないので、こちらも現状難しいです。すみません。 t-n様 Webアプリの実行ユーザに対して出力先ディレクトリへの書き込み権限はありますか? ⇒なんとなく、今回の問題の原因のように思えるのですが、このようなケースの場合にwebアプリの実行ユーザに対して、書き込み権限を与える設定が必要になってくるのでしょうか。でないとログ出力等も機能しなくなってしまうのでしょうか。
SurferOnWww

2022/09/30 14:07 編集

聞いたことにはちゃんと答えませんか? 「Webアプリ」って何ですか?  > Dockerコンテナ上でのテストと表現すれば、伝わりますでしょうか。 分かりません。運用環境で IIS で動かすのとどのように違うのですか?
SurferOnWww

2022/09/30 21:56

質問者さん、無言ですが、回答したのでそれに対するフィードバックを返してください。役に立った/立たなかったぐらいはすぐに返せるのでは? 役に立たなかったならどこがダメかを書くとより期待に近い回答が出てくるかも。とにかく無言は NG です。
dodox86

2022/09/30 22:42

Dockerコンテナ上のOSの情報がまったく示されてないのもあって分かりませんが、 > fileName="./App_Data/log/error/errorlog.log" では実行時のカレントディレクトリ下指定で、これも怪しそうですね。いずれにせよ情報不足の感は否めません。
SurferOnWww

2022/10/01 00:44 編集

質問者さん、その後無言ですが、聞いたことにはちゃんと答えませんか? 「Webアプリ」って何ですか? 「Dockerコンテナ上に配置」ってどういうことですか? 前のスレッドと同じ web アプリなら .NET Framework の ASP.NET MVC5 なので、web サーバーは Windows OS の IIS でないと動きません (開発環境は IIS Express。Docker なんちゃらでステージング環境を作ったなら IIS)。そうじゃないんですか? それすら答えられないほど何も分からないのですか?
SurferOnWww

2022/10/01 00:43

dodox86 さん> App_Data というフォルダは、Visual Studio のテンプレートを使って .NET Framework の(Core でない)ASP.NET アプリを作ると、名前のとおり Data の格納場所としてアプリのルート直下に自動的に作成されます。 それをログの保存場所にしたと想像。ログの保存場所として App_Data が適当かどうかはちょっと置いといて、少なくとも間違ってはいません。 ただし、回答に書いた通り、IIS にデプロイした場合ワーカープロセスに書き込み権限はないので、「WebアプリをDockerコンテナ上で動作させたところ、ファイルへの書き込み等が出来なくなった」という問題が出たのでしょう。自信度 99% ぐらいはあります。
MASUFISH

2022/10/01 01:14

SurferOnWww様 前のスレッドと同じ web アプリなら .NET Framework の ASP.NET MVC5 なので、web サーバーは Windows OS の IIS でないと動きません (開発環境は IIS Express。Docker なんちゃらでステージング環境を作ったなら IIS)。そうじゃないんですか? それすら答えられないほど何も分からないのですか? ⇒回答が漏れてしまい申し訳ありません。環境につきましては、仰る通りです。   IIS にデプロイした場合ワーカープロセスに書き込み権限はないので、「WebアプリをDockerコンテナ上で動作させたところ、ファイルへの書き込み等が出来なくなった」という問題が出たのでしょう。自信度 99% ぐらいはあります。 ⇒上記に関しましても、理解できておらず、回答いただきました点について、しっかり調べ確認してみます。原因としても、回答いただいたことに起因するのかとおもいますので、SurferOnWww様の回答をベストアンサーにさせていただきます。ありがとうございます。

まだ回答がついていません

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

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

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

同じタグがついた質問を見る

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです