Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

(시리즈 글이 4개 있습니다.)
개발 환경 구성: 220. supportedRuntime 설정을 위한 app.config Transformation
; https://www.sysnet.pe.kr/2/0/1662

.NET Framework: 1193. (appsettings.json처럼) web.config의 Debug/Release에 따른 설정 적용
; https://www.sysnet.pe.kr/2/0/13028

VS.NET IDE: 200. C# - app.config 파일의 출력을 Configuration(Debug/Release)에 따라 제어하는 방법
; https://www.sysnet.pe.kr/2/0/13918

오류 유형: 980. C# - appsettings.json 파일의 설정값이 적용 안 된다면?
; https://www.sysnet.pe.kr/2/0/14002




C# - appsettings.json 파일의 설정값이 적용 안 된다면?

이상하군요, 분명히 웹 애플리케이션의 배포 경로에는 appsettings.json 파일이 있고, 그 안에 설정값까지 넣어두었습니다.

$ cat appsettings.json
{
    "Logging": {
        "LogLevel": {
            "Default": "Information",
            "Microsoft": "Warning",
            "Microsoft.Hosting.Lifetime": "Information"
        }
    },

    "AllowedHosts": "*",

    "ConnectionStrings": {
        "DBLocal": "...[생략]..."
    }
}

그런데 Microsoft.Extensions.Configuration.IConfiguration.GetConnectionString 메서드에서는 null을 반환합니다. 반면, 비주얼 스튜디오에서 디버깅을 해보면 ^^; 값이 잘 반환됩니다.

검색해 보니까,

Published .Net Core 2 application does not read appsettings.json file
; https://stackoverflow.com/questions/50578013/published-net-core-2-application-does-not-read-appsettings-json-file

Current Directory를 기준으로 찾기 때문이라고 합니다. 그러니까, 아래와 같은 식으로 실행하면 안 되는 것입니다.

// 아래와 같은 경우라면, "/appsettings.json" 경로의 파일을 찾게 되므로 의도한 대로 실행이 안 됨.

$ pwd
/

$ dotnet /app/core3web/Core3Web.dll

대신 이렇게 실행해야 합니다.

// 아래의 경우라면, "/app/core3web/appsettings.json" 경로의 파일을 찾게 되므로 의도한 대로 실행.

$ cd /app/core3web
$ dotnet Core3Web.dll

쉬운 내용이다 보니 너무 쉽게 간과할 수 있던 부분입니다. ^^ 따라서 만약 다른 경로에서 "dotnet /app/core3web/Core3Web.dll"과 같은 식으로 실행하는 것도 허용하고 싶다면 Current Directory를 변경해야 합니다. "Published .Net Core 2 application does not read appsettings.json file" 글의 답변에는 이에 대한 해결책으로 AppContext.BaseDirectory를 이용했다고 하는데 좋은 우회책인 것 같습니다. ^^

namespace Core3Web;

public class Program
{
    public static void Main(string[] args)
    {
        Environment.CurrentDirectory = AppContext.BaseDirectory;
        CreateHostBuilder(args).Build().Run();
    }

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
            .ConfigureWebHostDefaults(webBuilder =>
            {
                webBuilder.UseStartup();
                webBuilder.ConfigureKestrel(serverOptions =>
                {
                    serverOptions.ListenAnyIP(6001);
                });
            });
}




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 8/20/2025]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...
NoWriterDateCnt.TitleFile(s)
13721정성태8/30/20249201C/C++: 168. Visual C++ CRT(C Runtime DLL: msvcr...dll)에 대한 의존성 제거 - 두 번째 이야기
13720정성태8/29/202410067VS.NET IDE: 193. C# - Visual Studio의 자식 프로세스 디버깅
13719정성태8/28/20249604Linux: 79. C++ - pthread_mutexattr_destroy가 없다면 메모리 누수가 발생할까요?
13718정성태8/27/202412355오류 유형: 921. Visual C++ - error C1083: Cannot open include file: 'float.h': No such file or directory [2]
13717정성태8/26/202412215VS.NET IDE: 192. Visual Studio 2022 - Windows XP / 2003용 C/C++ 프로젝트 빌드
13716정성태8/21/202410380C/C++: 167. Visual C++ - 윈도우 환경에서 _execv 동작 [1]
13715정성태8/19/202412756Linux: 78. 리눅스 C/C++ - 특정 버전의 glibc 빌드 (docker-glibc-builder)
13714정성태8/19/202410325닷넷: 2295. C# 12 - 기본 생성자(Primary constructors) (책 오타 수정) [3]
13713정성태8/16/202412927개발 환경 구성: 721. WSL 2에서의 Hyper-V Socket 연동
13712정성태8/14/202411387개발 환경 구성: 720. Synology NAS - docker 원격 제어를 위한 TCP 바인딩 추가
13711정성태8/13/202412079Linux: 77. C# / Linux - zombie process (defunct process) [1]파일 다운로드1
13710정성태8/8/202413273닷넷: 2294. C# 13 - (6) iterator 또는 비동기 메서드에서 ref와 unsafe 사용을 부분적으로 허용파일 다운로드1
13709정성태8/7/202411524닷넷: 2293. C# - safe/unsafe 문맥에 대한 C# 13의 (하위 호환을 깨는) 변화파일 다운로드1
13708정성태8/7/202412375개발 환경 구성: 719. ffmpeg / YoutubeExplode - mp4 동영상 파일로부터 Audio 파일 추출
13707정성태8/6/202411895닷넷: 2292. C# - 자식 프로세스의 출력이 4,096보다 많은 경우 Process.WaitForExit 호출 시 hang 현상파일 다운로드1
13706정성태8/5/202411211개발 환경 구성: 718. Hyper-V - 리눅스 VM에 새로운 디스크 추가
13705정성태8/4/202411556닷넷: 2291. C# 13 - (5) params 인자 타입으로 컬렉션 허용 [2]파일 다운로드1
13704정성태8/2/202413249닷넷: 2290. C# - 간이 dotnet-dump 프로그램 만들기파일 다운로드1
13703정성태8/1/202411272닷넷: 2289. "dotnet-dump ps" 명령어가 닷넷 프로세스를 찾는 방법
13702정성태7/31/202412641닷넷: 2288. Collection 식을 지원하는 사용자 정의 타입을 CollectionBuilder 특성으로 성능 보완파일 다운로드1
13701정성태7/30/202413605닷넷: 2287. C# 13 - (4) Indexer를 이용한 개체 초기화 구문에서 System.Index 연산자 허용파일 다운로드1
13700정성태7/29/202413267디버깅 기술: 200. DLL Export/Import의 Hint 의미
13699정성태7/27/202413785닷넷: 2286. C# 13 - (3) Monitor를 대체할 Lock 타입파일 다운로드1
13698정성태7/27/202412682닷넷: 2285. C# - async 메서드에서의 System.Threading.Lock 잠금 처리파일 다운로드1
13697정성태7/26/202411253닷넷: 2284. C# - async 메서드에서의 lock/Monitor.Enter/Exit 잠금 처리파일 다운로드1
13696정성태7/26/202411823오류 유형: 920. dotnet publish - error NETSDK1047: Assets file '...\obj\project.assets.json' doesn't have a target for '...'
1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...