Microsoft MVP성태의 닷넷 이야기
웹가든에서 메모리 동적 업데이트 방법 [링크 복사], [링크+제목 복사],
조회: 11588
글쓴 사람
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)
183정성태5/9/20059447    답변글 [답변]: // 꼭쫌 답변해 주세요~~~클라이언트 서버 ... 내용, 이점 들...
180최성우5/7/20059907[Q] POST 형식의 데이터 훅킹?
182정성태5/9/200510537    답변글 [답변]: [Q] POST 형식의 데이터 훅킹?
190최성우5/10/20059569        답변글 [답변]: [답변]: [Q] POST 형식의 데이터 훅킹?
177최정희5/4/200510103네트워크 케이블의 연결상태
178정성태5/4/200510220    답변글 [답변]: 네트워크 케이블의 연결상태 [1]
188최정희5/10/20059680        답변글 [답변]: [답변]: 네트워크 케이블의 연결상태
189정성태5/10/20059884            답변글 [답변]: [답변]: [답변]: 네트워크 케이블의 연결상태 [2]
191최정희5/11/20059522                답변글 [답변]: [답변]: [답변]: [답변]: 네트워크 케이블의 연결상태 [1]
175안연준5/3/20059915IE 제어에 대한 궁금 증 ㅡ,.ㅡ;;
179정성태5/4/200510577    답변글 [답변]: IE 제어에 대한 궁금 증 ㅡ,.ㅡ;;
168안연준5/2/20059959[Database] Connection Error파일 다운로드1
169정성태5/2/200510103    답변글 [답변]: [Database] Connection Error
170안연준5/2/20059659        답변글 [답변]: [답변]: 계속 에러가 똑같애요
171정성태5/2/200510385            답변글 [답변]: [답변]: [답변]: 계속 에러가 똑같애요
172안연준5/2/200510155                답변글 [답변]: [답변]: [답변]: [답변]: 계속 에러가 똑같애요파일 다운로드1
173정성태5/2/20059909                    답변글 [답변]: [답변]: [답변]: [답변]: [답변]: 계속 에러가 똑같애요
174안연준5/3/20059871                        답변글 [답변]: [답변]: [답변]: [답변]: [답변]: [답변]: 계속 에러가 똑같애요
165장희석4/22/200510490[질문]ASP에서 ATL 서버 컴퍼넌트로 바이너리 데이타 전달하기
167정성태4/29/200510316    답변글 [답변]: [질문]ASP에서 ATL 서버 컴퍼넌트로 바이너리 데이타 전달하기
160카심4/21/20059898Internet Explorer 에서의 닷넷 Smart Client 개발
163정성태4/22/20059829    답변글 [답변]: Internet Explorer 에서의 닷넷 Smart Client 개발
159신대철4/21/20059626자동 로긴 프로그램
162정성태4/22/20059628    답변글 [답변]: 자동 로긴 프로그램
166신대철4/22/20059312        답변글 [답변]: [답변]: 자동 로긴 프로그램파일 다운로드1
157이용휘4/20/20059316w3ip를 통해서 윈도우 미디어 화을을 올려놓을 서버..
... [91]  92  93  94  95  96  97