Microsoft MVP성태의 닷넷 이야기
웹가든에서 메모리 동적 업데이트 방법 [링크 복사], [링크+제목 복사],
조회: 12535
글쓴 사람
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)
119김용국3/22/20059818                    답변글 [답변]: 정상태님 아주 잘 해결 되었습니다.... 감사합니다!
108guest3/17/200510000닷넷 프레임워크 배포
111정성태3/19/200510435    답변글 [답변]: 닷넷 프레임워크 배포
107안연준3/17/20059615[-_-]스마트 클라이언트에 관련 된 질문[-_-]
110정성태3/19/200510511    답변글 [답변]: [-_-]스마트 클라이언트에 관련 된 질문[-_-]
116안연준3/21/200510003        답변글 [답변]: 친절한 답변 고맙습니다.
98김용국3/18/200511741정성태님... 연결이 준비됬습니다
99정성태3/2/200512596    답변글 [답변]: 정성태님... 연결이 준비됬습니다
100김용국3/18/20059717        답변글 [답변]: 죄송합니다! 급히올리느라 file path의 변경을 하지않고 그냥올렸네요....!
101정성태3/2/20059956            답변글 [답변]: [답변]: 죄송합니다! 급히올리느라 file path의 변경을 하지않고 그냥올렸네요....!
102김용국3/18/200510008                답변글 [답변]: 거듭죄송하네요..... 후~~~주소를 변경하고 빌드를 다시 했습니다....
103정성태3/2/20059915                    답변글 [답변]: [답변]: 거듭죄송하네요..... 후~~~주소를 변경하고 빌드를 다시 했습니다....
104김용국3/2/200510017                        답변글 [답변]: 네... 빨리 검토해 봐 주셔서 감사합니다~~
105정성태3/2/20059209                            답변글 [답변]: [답변]: 네... 빨리 검토해 봐 주셔서 감사합니다~~
106김용국3/2/20059688                                답변글 [답변]: 답변감사합니다!
91김용국2/28/200511347IE에 WindowsFormControl을 올려 실행하면 이런에러가 나네요???파일 다운로드1
92정성태2/28/200512649    답변글 [답변]: IE에 WindowsFormControl을 올려 실행하면 이런에러가 나네요???
93김용국2/28/200511617        답변글 [답변]: 답변감사합니다... 재질문을 드립니다
94정성태2/28/200512223            답변글 [답변]: [답변]: 답변감사합니다... 재질문을 드립니다
95김용국2/28/200512258                답변글 [답변]: IE주소창에서 해당주소로 실행을 해보니....디버깅 PopUp화면이...^
96정성태2/28/200511292                    답변글 [답변]: [답변]: IE주소창에서 해당주소로 실행을 해보니....디버깅 PopUp화면이...^
97김용국3/1/200511864                        답변글 [답변]: 준비되는데로 말씀드리겠습니다 ^^
88안지환2/22/200513353^^ 사이트 잘 들러보았습니다.
89정성태2/22/200513349    답변글 [답변]: ^^ 사이트 잘 들러보았습니다.
85한기열2/22/200511988정성태님 홈같은 부드러운 페이지 넘김?은 어떻게 구현하나요?
86정성태2/22/200512688    답변글 [답변]: 정성태님 홈같은 부드러운 페이지 넘김?은 어떻게 구현하나요? [2]
... 91  92  93  [94]  95  96  97