Microsoft MVP성태의 닷넷 이야기
.NET Framework: 33. Proxy 환경에서의 Smart Client 업데이트 문제 [링크 복사], [링크+제목 복사],
조회: 18578
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

고객사에서, 지난 3월 24일 있었던 ISV 세미나에 다녀와서는 곧바로 스마트 클라이언트 적용을 검토하던 중이었습니다.

아주 간단한 exe 파일을 올려놓고 테스트 했는데, 업데이트 된 exe 파일을 올려도 적용이 안되는 것입니다. 즉, 스마트 클라이언트의 가장 강점이라고 할 수 있는 "자동 업데이트" 가 안되는 현상을 보였습니다. ^^; 나름대로 당황을 했지요. 그렇긴 해도, 언젠가 부터 쌓인 습관 - Microsoft 측의 버그라고 우선 단정하지 않는 - 으로 문제를 하나 하나 파악해 나갔습니다.

일단, 제 컴퓨터의 웹 서버에 올려놓았을 때 다른 사람들은 업데이트가 안되었지만, 제 컴퓨터에서 접속을 했을 때는 업데이트가 되는 것을 확인했습니다. 순간... ^^ 불현듯 이곳이 Proxy 로 구성된 네트워크라는 것이 떠올랐습니다. 아하... 문제는 바로 Proxy 측에서의 캐쉬였습니다.

다른 컴퓨터에서 제 웹 서버의 스마트 클라이언트 exe 파일을 요청하면 중간의 Proxy 서버가 그 파일을 캐쉬하고 있다가 이후의 요청에서는 Proxy 서버가 모든 처리를 해버려서 자동업데이트가 이루어지지 않은 것입니다.

exe 파일을 바로 요청하는 것이기 때문에 프로그램 적으로 캐쉬설정을 할 수 없는데, 다행히 IIS 설정창에서 "HTTP Headers" 탭의 "Enable content expiration" 에서 "Expire immediately" 를 선택해서 수정할 수 있었습니다.

어쨌든, 이번에도 느낀 것이지만, 언젠가 부터... Microsoft 의 기술에 신뢰가 가더군요. 만약, 반대로 불신을 가지고 있었다면, 이런 경우 난리를 치며 MS 의 스마트 클라이언트 기술에 중대 버그가 있다고 떠들지 않았을까요. ^^








[최초 등록일: ]
[최종 수정일: 3/27/2005]

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

비밀번호

댓글 작성자
 



2005-03-30 11시03분
[Brandon] 음...경험아니면 얻을수 없는 귀중한 정보이군요..
잘보고 갑니다.^^
[guest]

... 46  47  48  49  50  51  52  53  54  55  56  57  [58]  59  60  ...
NoWriterDateCnt.TitleFile(s)
12550정성태3/5/202116688오류 유형: 701. Live Share 1.0.3713.0 버전을 1.0.3884.0으로 업데이트 이후 ContactServiceModelPackage 오류 발생하는 문제
12549정성태3/4/202118482오류 유형: 700. VsixPublisher를 이용한 등록 시 다양한 오류 유형 해결책
12548정성태3/4/202119607개발 환경 구성: 546. github workflow/actions에서 nuget 패키지 등록하는 방법
12547정성태3/3/202120103오류 유형: 699. 비주얼 스튜디오 - The 'CascadePackage' package did not load correctly.
12546정성태3/3/202120313개발 환경 구성: 545. github workflow/actions에서 빌드시 snk 파일 다루는 방법 - Encrypted secrets
12545정성태3/2/202122806.NET Framework: 1026. 닷넷 5에 추가된 POH (Pinned Object Heap) [10]
12544정성태2/26/202123219.NET Framework: 1025. C# - Control의 Invalidate, Update, Refresh 차이점 [2]
12543정성태2/26/202120692VS.NET IDE: 158. C# - 디자인 타임(design-time)과 런타임(runtime)의 코드 실행 구분
12542정성태2/20/202122229개발 환경 구성: 544. github repo의 Release 활성화 및 Actions를 이용한 자동화 방법 [1]
12541정성태2/18/202119919개발 환경 구성: 543. 애저듣보잡 - Github Workflow/Actions 소개
12540정성태2/17/202121574.NET Framework: 1024. C# - Win32 API에 대한 P/Invoke를 대신하는 Microsoft.Windows.CsWin32 패키지
12539정성태2/16/202121387Windows: 189. WM_TIMER의 동작 방식 개요파일 다운로드1
12538정성태2/15/202122015.NET Framework: 1023. C# - GC 힙이 아닌 Native 힙에 인스턴스 생성 - 0SuperComicLib.LowLevel 라이브러리 소개 [2]
12537정성태2/11/202121096.NET Framework: 1022. UI 요소의 접근은 반드시 그 UI를 만든 스레드에서! - 두 번째 이야기 [2]
12536정성태2/9/202120399개발 환경 구성: 542. BDP(Bandwidth-delay product)와 TCP Receive Window
12535정성태2/9/202119547개발 환경 구성: 541. Wireshark로 확인하는 LSO(Large Send Offload), RSC(Receive Segment Coalescing) 옵션
12534정성태2/8/202120453개발 환경 구성: 540. Wireshark + C/C++로 확인하는 TCP 연결에서의 closesocket 동작 [1]파일 다운로드1
12533정성태2/8/202118646개발 환경 구성: 539. Wireshark + C/C++로 확인하는 TCP 연결에서의 shutdown 동작파일 다운로드1
12532정성태2/6/202120713개발 환경 구성: 538. Wireshark + C#으로 확인하는 ReceiveBufferSize(SO_RCVBUF), SendBufferSize(SO_SNDBUF) [3]
12531정성태2/5/202119128개발 환경 구성: 537. Wireshark + C#으로 확인하는 PSH flag와 Nagle 알고리듬파일 다운로드1
12530정성태2/4/202122231개발 환경 구성: 536. Wireshark + C#으로 확인하는 TCP 통신의 Receive Window
12529정성태2/4/202121245개발 환경 구성: 535. Wireshark + C#으로 확인하는 TCP 통신의 MIN RTO [1]
12528정성태2/1/202121553개발 환경 구성: 534. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 윈도우 환경
12527정성태2/1/202121462개발 환경 구성: 533. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 리눅스 환경파일 다운로드1
12526정성태2/1/202117952개발 환경 구성: 532. Azure Devops의 파이프라인 빌드 시 snk 파일 다루는 방법 - Secure file
12525정성태2/1/202116492개발 환경 구성: 531. Azure Devops - 파이프라인 실행 시 빌드 이벤트를 생략하는 방법
... 46  47  48  49  50  51  52  53  54  55  56  57  [58]  59  60  ...