Microsoft MVP성태의 닷넷 이야기
글쓴 사람
조정용
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)

안녕하세요.
고민 고민하다 처음으로 질문 글을 올리게 되었습니다.

다름이 아니라 이번에 WCF 프로그램을 개발 하는 중에 생각치도 못한 심각한 문제가 발생되었습니다.

시나리오는 다음과 같습니다.

1. WCF 호스트는 주 호스트와 보조 호스트(N개)로 나누어집니다.
2. 클라이언트에서 주 호스트에 요청이 전달되면 처리 도중 조건에 의해 보조 호스트에 동일한 내용을 전파합니다. (복제)
3. 보조 호스트에 대한 요청 처리를 기다릴 필요는 없습니다. (성공을 기반으로 하나 실패하여도 무관, 방화벽 및 네트워크 장애 등등)


문제는 클라이언트에서 다량의 요청을 전달하면 2.번 항목의 복제 작업 때문에 응답에 대한 병목이 발생한다는 것입니다. (클라이언트가 받는 처리 시간이 들쑥날쑥합니다)
2.번 항목의 복제는 Task 클래스를 이용하여 waiting 없는 코드로 수행 하였기에 기대 결과는 호출자에 대한 영향이 없다고 생각했는데(실제로 스톱워치를 찍어봐도 그렇게 나오고)
정작 클라이언트 입장에서는 때때로 느리게 처리되었다...는 결과를 받게 되네요.

테스트 코드가 다량의 요청이라 백그라운드 처리 지연에 의한 리소스 고갈인가 의심도 되긴하는데....

해당 코드는 파일 (visual studio 2013으로 작성)로 첨부해두었습니다. (문제가 되는 부분만 떼어 다시 급하게 작성한거라 엉성하여도 이해부탁드립니다)


도움 부탁드리겠습니다.


[연관 글]






[최초 등록일: ]
[최종 수정일: 8/17/2014]


비밀번호

댓글 작성자
 



2014-08-18 04시56분
보내주신 WCF 서비스를 Visual Studio에서 F5 디버거로 시작하면, Output 창에 예외가 많이 발생하는 것을 볼 수 있습니다. 그것들을 아래의 글에 설명한대로,

First-Chance Exception
; http://www.sysnet.pe.kr/2/0/510

Exceptions 창에서 "Thrown"으로 설정해 두면 예외가 발생한 라인에서 디버거가 멈출 것입니다. 해당 에러들을 모두 수정하신 다음에 다시 소스 코드를 올려주세요. (아마 제 생각에는 그 예외들을 고치다 보면 현상이 해결될 것입니다.)
정성태
2014-08-19 02시32분
[조정용] 답변 감사드립니다.
말씀하신 Exception은 사실 발생할 수밖에 없는 구조입니다.
원격 호스트가 없거나 방화벽등의 장애로 연결 할 수 없을 경우 WCF Channel Open 과정에서 각종 Exception을 발생시키는데 이를 수정하기 위한 조건은 결국 원격 호스트가 정상적으로 열어 있어야만 합니다.
하지만 시나리오 상으로 호스트가 없거나 연결할 수 없는 경우도 있기 때문에 Excepiton을 수정할 수는 없습니다.
예외를 front caller에 throw하지 않고 아무런 처리를 하지 않도록 하여도 클라이언트에 대한 응답 병목현상은 해결이 안되네요 ㅜㅜ;
[guest]
2014-08-19 01시46분
@조정용 그렇다면 ^^ 상황이 달라지는군요. 일단, Task.Run은 스레드 풀을 기반으로 하는데, 이게 무조건 스레드를 늘리는 방식이 아닙니다. 이 때문에 지연 현상이 발생하는 것입니다. 관련해서는 다음의 글을 참고하세요.

ThreadPool.QueueUserWorkItem 의 실행 지연
; http://www.sysnet.pe.kr/2/0/1455

Task의 내부 구현은 살펴봐야겠지만 어쨌든 전체적인 맥락은 위의 글에 따를 것이므로 지연 현상이 발생합니다. 따라서 ReplicaProvider.Transfer 내부의 Task.Run( ... )을 new Thread( () => ... ).Start();로 바꿔주시면 되는데요. 이렇게 해도 문제가 됩니다.

왜냐하면 TestModuleClient.Use 메서드가 잘못 작성되었습니다.

public void Use(...)
{
    try { ... } catch (...) { Use(...); }
}

위와 같이 되어 있는데, 예외가 발생하면 그 내부에서 다시 Use를 호출하기 때문에 서버와 연결이 되지 않으면 무한 재귀 호출 현상에 빠집니다. 따라서, Thread 수가 급격하게 늘어나기 시작하고 예외 처리가 무겁기 때문에 CPU 100% 현상이 발생합니다.

그렇다고 catch 절의 Use를 제거했다고 해서 문제가 해결되는 것은 아닙니다. Socket.Connect TCP 연결 메서드는 내부적으로 연결 시도를 하기 때문에 Connect에서 예외가 발생하기까지 시간이 걸립니다. 따라서, 마찬가지로 급격하게 스레드가 늘어나고 역시 마찬가지로 CPU 100% 현상이 발생합니다.

따라서, 이를 해결하려면 Replica를 호출하는 전용 스레드를 하나만 두고 Queue를 만들어 처리하는 방식으로 바꿔야 합니다. 서버가 연결되지 않는 경우, 마찬가지로 Queue에는 급격하게 요청이 쌓일 것이므로 Queue의 최대 수를 적절하게 조절해서 처리하는 것이 좋습니다.
정성태
2014-08-23 10시39분
[조정용] 자세한 설명과 참고자료 정말 감사드립니다.
스레드의 지연 현상은 정말 의외네요 ^^;
조언 주신데로 장기 사용할 전용 스레드로 수행하도록 해야겠습니다.

다시 한번 감사드립니다.
[guest]

... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4932정환나라12/13/20179007vs2013에서 빌드한 com 컨트롤 객체를 닷넷 2.0에서 사용하려 합니다 [4]
4931Arvid12/12/201710015Visual Studio 2012 c# using문 참조 에러 [5]파일 다운로드1
4929김성대12/8/20178520app.config에 관한질문입니다. [1]
4928김성대12/7/20179164SQL Server 설치에러에 대한 질문입니다. [1]파일 다운로드1
4926heyh...12/6/20178425[삭제] ContextSwitchDeadlock????
4925ho12/5/20178957[삭제] WebBrowser로 드롭박스 로그인 페이지 탐색 시 발생한 문제에 대해 질문 올립니다.파일 다운로드2
4924몽중언12/3/20179410C# 디버깅 모드에서만 DB Insert가 되는 현상 질의 [6]
4923고요한11/23/20179543파일 확장자에 연결된 프로그램을 등록하는 방법에 대한 질문입니다. [2]
4922박성훈11/23/201710498시작하세요! C# 7.1 학습 방법 [3]
4921초보개발자11/20/20177727[삭제] 폼 사이즈 질문드립니다.
4920Ques...11/19/20178835IEnumerable 의 "지연된 평가" 에 관하여 질문드립니다. [2]파일 다운로드1
4919mskim11/16/20179120Split()을 이용하여 문자 구분 시 구분문자도 같이 저장하는 방법이 있나요? [2]
4917ho11/16/20179764WPF XAML 트리거 관련해 문의 드립니다. [3]
4918ho11/16/201710054    답변글 [답변]: 예제 프로젝트 첨부합니다. [4]파일 다운로드2
4916필승11/11/20179721기본 웹 브라우저 체크는 어떻게 해야 하나요? [2]
4915필승11/10/20178788WebBrowser 컨트롤 소리 출력 문의 드립니다. [2]
4914Ques...11/10/20179468c# 버튼 이벤트에 관하여 질문드립니다. [2]
4913Arvid11/8/201711870Log4Net 라이브러리를 이용하여 특정 기간이 지났을 때 자동 로그 삭제 기능 구현 질문 드립니다! [2]
4912조범희11/8/201711542C# FTP 다운로드중 에러 발생.. [2]파일 다운로드1
4911필승11/6/201710008WebBrowser 컨트롤 사용법에 대해 궁금합니다. [2]
4910진우11/6/20179577람다 초보 질문 드립니다. [2]
4909필승11/5/201710495TextBox에 관해 질문 드립니다. [5]
4908필승11/1/201713807특정 시각에 프로그램 종료 또는 재시작시 오류 발생 [8]
4907심너울10/29/20179412선생님이 쓰신 "시작하세요! C# 7.1~"으로 공부하고 있는데요~ [2]
4906guest10/25/20178992.net core, .net standard 관련해서 궁금합니다 [2]
490510/25/20178269watermark 관련문의 [1]
... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...