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

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

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

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

Visual Studio

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

Docker

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

Q&A

解決済

1回答

625閲覧

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

MASUFISH

総合スコア21

C#

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

Visual Studio

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

Docker

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

0グッド

0クリップ

投稿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

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

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

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

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

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

退会済みユーザー

退会済みユーザー

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
退会済みユーザー

退会済みユーザー

2022/09/30 13:54 編集

質問者さん、前に https://teratail.com/questions/v071melkydsv9h でハマってた人ですよね。聞いたことにはちゃんと答えませんか? また話が噛み合わなくなりますので。
MASUFISH

2022/09/30 14:02

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

退会済みユーザー

2022/09/30 14:07 編集

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

退会済みユーザー

2022/09/30 21:56

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

2022/09/30 22:42

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

退会済みユーザー

2022/10/01 00:44 編集

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

退会済みユーザー

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様の回答をベストアンサーにさせていただきます。ありがとうございます。
guest

回答1

0

ベストアンサー

現在、VisualStudioで作成したWebアプリをDockerコンテナ上に配置し、webアプリの動作を検証しております。

質問のコメントに返事がないのでいろいろ不明ですが、「Webアプリ」というのが ASP.NET Web アプリで、「Dockerコンテナ上に配置」というのが運用環境の IIS にデプロイしたということであろうと理解して・・・

開発環境で Visual Studio から実行して IIS Express 上で動かすと期待通り動くが、運用環境で IIS にデプロイすると動かないという原因のほとんどは:

(1) ワーカープロセスのアクセス権の違い。

(2) 開発環境ではユーザー対話モードでアプリが実行されるが運用環境ではそうではない。

・・・です。

上で言う「開発環境」の時は Visual Studio を PC にログインしたアカウントで起動したと思いますが、そうすると、上の (1) はそのユーザーアカウントの権限、(2) はユーザー対話モードになっているはずです。

運用環境の時は、デフォルトでは (1) はほとんど権限のないアカウント、(2) は非ユーザー対話モード(グラフィカルユーザーインターフェイスは表示できない)になります。

アクセス権については、ワーカープロセスに必要なアクセス権を与えるとか、IIS Manager を操作してワーカープロセスを必要なアクセス権を持つアカウントに変更することで対処可能です。

しかし、(2) の問題があるとすると何ともなりません。

投稿2022/09/30 13:48

編集2022/09/30 14:48
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問