Microsoft MVP성태의 닷넷 이야기
웹가든에서 메모리 동적 업데이트 방법 [링크 복사], [링크+제목 복사],
조회: 11592
글쓴 사람
icookie (icookie at naver.com)
홈페이지
첨부 파일
 

IIS에서 웹가든을 2(최대 작업자 프로세스 수를 2로 설정)로 설정 해서 사용 중 입니다.
web.config를 사용 해서 환경설정을 사용 하다가 web.config가 변경 되면 w3wp.exe가 recycling이 발생 하는 문제 때문에
환경설정을 DB로 변경 하였습니다.

어플리케이션이 시작 할 때 db에서 읽어서 메모리에 올려 두고 사용 합니다.
설정 정보가 db에서 변경이 되면 관리 웹 페이지에서 web service를 통해 메모리 업데이트를 요청 합니다.
해당 web service는 db에서 다시 설정 정보를 조회해서 메모리를 업데이트 합니다.

하지만 웹가든을 사용 하면서 문제가 발생 하였습니다.
잘 아시는 것 처럼 웹가든을 사용 하기 때문에 w3wp.exe가 2개로 분리 되었고 관리 웹페이지에서 web service를 호출 하면 2개 w3wp.exe중 1개의 프로세스에서 응답을 받을 것이고
당연히 응답받은 w3wp.exe에 있는 메모리만 업데이트 됩니다.

질문 드립니다.
1. 2개의 w3wp.exe를 각각 호출 할 수 있는 방법이 있을 까요?
2. 각각의 웹서비스를 호출 할 수 없다면 다른 방법이 있을까요?
  (FileSystemWatcher를 사용 해 보았지만 실패 하였습니다. w3wp.exe가 특정 파일을 모니터링 하고 있고 그 파일이 변경 되면 알림을 받게 구현 함, 이벤트가 1번만 발생 합니다.)












[최초 등록일: ]
[최종 수정일: 4/4/2022]


비밀번호

댓글 작성자
 



2022-04-04 05시24분
제가 알기로는, 특정 worker process를 고르는 방법은 없습니다.

따라서 해결책도 간단합니다. w3wp.exe 간에 inter-process 통신을 해서 알리는 수밖에 없습니다. 소켓을 대기하든, 이벤트를 대기하든 선택해야 합니다. 그나저나 FileSystemWatcher를 대기했는데, 왜 실패했다는 것인지 이해가 잘 안 되는군요. FileSystemWatcher 이벤트를 발생시키는 OS 측에서 특정 프로세스 하나에 대해서만 signal하는 기능은 없습니다.

FileSystemWatcher를 수신하는 2개의 프로세스를 띄워놓고, 파일 변경을 해보시면 결과가 나올 것입니다. (아마도 분명히, 테스트상의 오류가 있었을 것입니다.)

--------------------------------

그렇긴 한데, 단순히 재생 문제 때문에 굳이 db로 옮기셨을 필요는 없을 것 같은데요. IIS의 관리자에서 AppPool 설정을 보면 "Recycling(재생)"에서 "Disable Recycling for Configuration Changes(구성 변경에 대한 재생 사용 안함)"이라는 옵션을 설정하면 web.config이 변경돼도 recycling이 발생하지 않습니다.
정성태

... 91  92  93  94  [95]  96  97 
NoWriterDateCnt.TitleFile(s)
87정성태2/22/200512270    답변글 [답변]: Smart Client에 관한 문의 드립니다.
82천호민2/1/200511138데이터 그리드의 템플릿필드에 버튼 컨트롤을 넣구요.. 포스트백시 이전 위치에 포커스를 주고 싶은데요..
83정성태2/2/200511949    답변글 [답변]: 데이터 그리드의 템플릿필드에 버튼 컨트롤을 넣구요.. 포스트백시 이전 위치에 포커스를 주고 싶은데요..
79정형균1/26/200511920드디어 정성태님을 찾았네요..^^; 스마트 클라이언트 구현하는데 배포시 문제때문에 죽겠습니다...
80정성태1/26/200510537    답변글 [답변]: 드디어 정성태님을 찾았네요..^^; 스마트 클라이언트 구현하는데 배포시 문제때문에 죽겠습니다...
76임은선1/25/200511479질문이 있는데요....
77정성태1/25/200511819    답변글 [답변]: 질문이 있는데요....
78임은선1/26/200512386        답변글 [답변]: [답변]: 질문이 있는데요....
72최정희1/19/200511820또 접니다.
73정성태1/19/200511622    답변글 [답변]: 또 접니다. [2]
74최정희1/19/200510994        답변글 [답변]: [답변]: 당연히 도움이 되지요.
75정성태1/19/200511557            답변글 [답변]: [답변]: [답변]: 당연히 도움이 되지요.
69최정희10/13/200410928저 기억하실런지? 그때 두리로IE툴바 만들어 주셨죠.
62엄길웅10/1/200412136매번 물어보기만 하는군요..
63정성태10/2/200411975    답변글 [답변]: 매번 물어보기만 하는군요..
64keal...10/5/200413562        답변글 [답변]: [답변]: 매번 물어보기만 하는군요..
65정성태10/6/200413479            답변글 [답변]: [답변]: [답변]: 매번 물어보기만 하는군요..
68keal...10/11/200411169                답변글 [답변]: [답변]: [답변]: [답변]: 매번 물어보기만 하는군요..
71정성태10/31/200411225                    답변글 [답변]: [답변]: [답변]: [답변]: [답변]: 매번 물어보기만 하는군요..
58엄길웅9/30/200411360안녕하세요.. 추석은 잘 보내셨는지요?
59정성태9/30/200411501    답변글 [답변]: 안녕하세요.. 추석은 잘 보내셨는지요?
60엄길웅10/1/200411280        답변글 [답변]: [답변]: 안녕하세요.. 추석은 잘 보내셨는지요?
56엄길웅9/23/200411635ATL을 이용해서 함수를 하나 만들었습니다.
57정성태9/23/200412652    답변글 [답변]: ATL을 이용해서 함수를 하나 만들었습니다.
61엄길웅10/1/200411293        답변글 [답변]: [답변]: ATL을 이용해서 함수를 하나 만들었습니다.
54차광석8/26/200411497잘 지내시죠?
... 91  92  93  94  [95]  96  97