고객사에서, 지난 3월 24일 있었던 ISV 세미나에 다녀와서는 곧바로 스마트 클라이언트 적용을 검토하던 중이었습니다.
아주 간단한 exe 파일을 올려놓고 테스트 했는데, 업데이트 된 exe 파일을 올려도 적용이 안되는 것입니다. 즉, 스마트 클라이언트의 가장 강점이라고 할 수 있는 "자동 업데이트" 가 안되는 현상을 보였습니다. ^^; 나름대로 당황을 했지요. 그렇긴 해도, 언젠가 부터 쌓인 습관 - Microsoft 측의 버그라고 우선 단정하지 않는 - 으로 문제를 하나 하나 파악해 나갔습니다.
일단, 제 컴퓨터의 웹 서버에 올려놓았을 때 다른 사람들은 업데이트가 안되었지만, 제 컴퓨터에서 접속을 했을 때는 업데이트가 되는 것을 확인했습니다. 순간... ^^ 불현듯 이곳이 Proxy 로 구성된 네트워크라는 것이 떠올랐습니다. 아하... 문제는 바로 Proxy 측에서의 캐쉬였습니다.
다른 컴퓨터에서 제 웹 서버의 스마트 클라이언트 exe 파일을 요청하면 중간의 Proxy 서버가 그 파일을 캐쉬하고 있다가 이후의 요청에서는 Proxy 서버가 모든 처리를 해버려서 자동업데이트가 이루어지지 않은 것입니다.
exe 파일을 바로 요청하는 것이기 때문에 프로그램 적으로 캐쉬설정을 할 수 없는데, 다행히 IIS 설정창에서 "HTTP Headers" 탭의 "Enable content expiration" 에서 "Expire immediately" 를 선택해서 수정할 수 있었습니다.
어쨌든, 이번에도 느낀 것이지만, 언젠가 부터... Microsoft 의 기술에 신뢰가 가더군요. 만약, 반대로 불신을 가지고 있었다면, 이런 경우 난리를 치며 MS 의 스마트 클라이언트 기술에 중대 버그가 있다고 떠들지 않았을까요. ^^
No | Writer | Date | Cnt. | Title | File(s) |
11895 | 정성태 | 5/12/2019 | 22563 | .NET Framework: 832. ML.NET Model Builder - 회귀(Regression), 다중 분류(Multi-class classification) 예제 | 1 |
11894 | 정성태 | 5/10/2019 | 24519 | VS.NET IDE: 135. Visual Studio - ML.NET Model Builder 소개 [5] | |
11893 | 정성태 | 5/10/2019 | 20586 | 오류 유형: 535. C# 6.0 이상의 문법을 컴파일 시 오류가 발생한다면? | |
11892 | 정성태 | 5/10/2019 | 20495 | 웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231) | |
11891 | 정성태 | 5/9/2019 | 23623 | .NET Framework: 831. (번역글) .NET Internals Cookbook Part 12 - Memory structure, attributes, handles | |
11890 | 정성태 | 5/8/2019 | 19284 | 개발 환경 구성: 439. "Visual Studio Enterprise is required to execute the test." 메시지와 관련된 코드 기록 | |
11889 | 정성태 | 5/8/2019 | 19328 | 개발 환경 구성: 438. mstest, QTAgent의 로그 파일 설정 방법 | |
11888 | 정성태 | 5/8/2019 | 37236 | .NET Framework: 830. C# - 비동기 호출을 취소하는 CancellationToken의 간단한 예제 코드 [1] | 1 |
11887 | 정성태 | 5/8/2019 | 23075 | .NET Framework: 829. C# - yield 문을 사용할 수 있는 메서드의 조건 | |
11886 | 정성태 | 5/7/2019 | 20128 | 오류 유형: 534. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 [2] | |
11885 | 정성태 | 5/7/2019 | 17601 | 오류 유형: 533. mstest.exe 실행 시 "File extension specified '.loadtest' is not a valid test extension." 오류 발생 | |
11884 | 정성태 | 5/5/2019 | 22513 | .NET Framework: 828. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 두 번째 이야기 | |
11883 | 정성태 | 5/3/2019 | 27519 | .NET Framework: 827. C# - 인터넷 시간 서버로부터 받은 시간을 윈도우에 적용하는 방법 | 1 |
11882 | 정성태 | 5/2/2019 | 23987 | .NET Framework: 826. (번역글) .NET Internals Cookbook Part 11 - Various C# riddles | 1 |
11881 | 정성태 | 4/28/2019 | 24086 | 오류 유형: 532. .NET Core 프로젝트로 마이그레이션 시 "CS0579 Duplicate 'System.Reflection.AssemblyCompanyAttribute' attribute" 오류 발생 | |
11880 | 정성태 | 4/25/2019 | 19840 | 오류 유형: 531. 이벤트 로그 오류 - Task Scheduling Error: m->NextScheduledSPRetry 1547, m->NextScheduledEvent 1547 | |
11879 | 정성태 | 4/24/2019 | 28752 | .NET Framework: 825. (번역글) .NET Internals Cookbook Part 10 - Threads, Tasks, asynchronous code and others | 2 |
11878 | 정성태 | 4/22/2019 | 24014 | .NET Framework: 824. (번역글) .NET Internals Cookbook Part 9 - Finalizers, queues, card tables and other GC stuff | 1 |
11877 | 정성태 | 4/22/2019 | 24228 | .NET Framework: 823. (번역글) .NET Internals Cookbook Part 8 - C# gotchas | 1 |
11876 | 정성태 | 4/21/2019 | 22502 | .NET Framework: 822. (번역글) .NET Internals Cookbook Part 7 - Word tearing, locking and others | 1 |
11875 | 정성태 | 4/21/2019 | 24319 | 오류 유형: 530. Visual Studo에서 .NET Core 프로젝트를 열 때 "One or more errors occurred." 오류 발생 | |
11874 | 정성태 | 4/20/2019 | 24344 | .NET Framework: 821. (번역글) .NET Internals Cookbook Part 6 - Object internals | 1 |
11873 | 정성태 | 4/19/2019 | 23024 | .NET Framework: 820. (번역글) .NET Internals Cookbook Part 5 - Methods, parameters, modifiers | 1 |
11872 | 정성태 | 4/17/2019 | 23906 | .NET Framework: 819. (번역글) .NET Internals Cookbook Part 4 - Type members | 1 |
11871 | 정성태 | 4/16/2019 | 21795 | .NET Framework: 818. (번역글) .NET Internals Cookbook Part 3 - Initialization tricks [3] | 1 |
11870 | 정성태 | 4/16/2019 | 20682 | .NET Framework: 817. Process.Start로 실행한 콘솔 프로그램의 출력 결과를 얻는 방법 | 1 |