C++Builder Programming Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
C++빌더 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
컴포넌트/라이브러리
메신저 프로젝트
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C++빌더 Q&A
C++Builder Programming Q&A
[72977] Re:Re:Re:Re:[답변]IdTCPClient (Indy, 인디) 컴포넌트 오류(10053 Socket Error) 도움부탁드립니다.
유도청년 [ktged] 5383 읽음    2015-09-09 21:24
우와우와!! 너무너무 감사합니다 덕분에 너무 잘 해결했네요!!!! 정말 머리숙여 감사드립니다!!

스머팩트 님이 쓰신 글 :
: 휴~ 이거 생각보다 힘들군요.
: 다시한번 테스트 했습니다.
:
: 좀더 극악의 상황을 만들어 봤습니다.
: TCP Connection이 이루어진 상태에서 서버쪽 랜선을 뽑아봤습니다.
: 약간 기다리니 말씀하신것과 같은 에러가 또 발생하는 군요.
:
: Indy Write명령으로 전송하면 데이터가 비동기적으로(좀 나중에) 전송되는 모양 입니다.(추측)
: 따라서 try-catch구문에서 잡히지 않는 것이라고 가정하고, Application레벨에서 Exception을 잡기로 했습니다.
: ApplicationEvents 콤포넌트를 Form에 추가하고
: OnException에 다음과 같은 코드를 추가했습니다.
:
:
: void __fastcall TForm2::ApplicationEvents1Exception(TObject *Sender, Exception *E)
: {
: 	memTest->Lines->Add("[App Exception]");
: 	idTCP_C_IPMS->Disconnect();
: }
: 

:
: 그랬더니 잘 되는군요.
:
:
:
: 유도청년 님이 쓰신 글 :
: : 혹시 한 번 더 테스트 해주실 수 있으실까요?
: : 가끔 나이스한 타이밍에 죽이면 괜찮은데..
: : 나이스 하지 못한 타이밍에 서버가 죽으면 어김없이 에러가 쌓이네요 ㅠ
: : 염치불구하고 부탁드립니다.
: :
: : 스머팩트 님이 쓰신 글 :
: : : 제가 사용중인 서버(osx)에 간단한 서버프로그램 올리고 IP, Port바꿔서 테스트 해봤습니다.
: : : 서버 프로그램을 <CTRL+C>로 죽이면 별 문제없이 처리되는데
: : : Kill로 죽여 봤더니 말씀하신 현상이 나타나는 군요.
: : :
: : : IdTCPClient OnStatus이벤트에 다음과 같이 코드를 추가하면 에러를 막을 수 있네요.
: : :
: : :
: : : void __fastcall TForm2::idTCP_C_IPMSStatus(TObject *ASender, const TIdStatus AStatus,
: : : 		  const UnicodeString AStatusText)
: : : {
: : : 	if(AStatus == hsDisconnected) idTCP_C_IPMS->Disconnect();
: : : }
: : : 

: : :
: : :
: : : ---------------------------------------------------------
: : :
: : : 유도청년 님이 쓰신 글 :
: : : :
void __fastcall TForm2::Timer1Timer(TObject *Sender)
: : : : {
: : : : 	static int iSender = 0;
: : : : 	if(!idTCP_C_IPMS->Connected())
: : : : 	{
: : : : 		idTCP_C_IPMS->ConnectTimeout = 90;
: : : : 		idTCP_C_IPMS->Host = "118.220.37.174";
: : : : 		idTCP_C_IPMS->Port = 33333;
: : : : 		try{
: : : : 			idTCP_C_IPMS->Connect();
: : : : 			if(idTCP_C_IPMS->Connected())
: : : : 			{
: : : :                 memTest->Lines->Add("IPMS Connection Success");
: : : :             }
: : : : 		}catch(...){
: : : : 			idTCP_C_IPMS->CleanupInstance();
: : : : 			memTest->Lines->Add("Please Check IPMS Connection");
: : : : 			iSender = 0;
: : : : 		}
: : : : 
: : : : 	}
: : : : 	try{
: : : : 		if(idTCP_C_IPMS->Connected())
: : : : 		{
: : : : 			idTCP_C_IPMS->Socket->Write(iSender);
: : : : 			iSender++;
: : : : 		}
: : : : 	}catch(...){
: : : : 		idTCP_C_IPMS->CleanupInstance();
: : : : 		memTest->Lines->Add("Please Check IPMS Connection");
: : : : 		iSender = 0;
: : : : 	}
: : : : }
: : : : //---------------------------------------------------------------------------

: : : :
: : : : 위 코드 처럼 작성해서 구동을 합니다. 100ms 마다 한 번 씩 호출이 되는 타이머 이구요...
: : : : Connection 간의 오류는 try catch 구문이 잘 잡아주고 있습니다.
: : : :
: : : : 그런데.. Server가 비정상 종료되는 경우 idTCP_C_IPMS->Socket->Write(iSender); 구문에서
: : : :
: : : : 10053 socket error 가 발생하여 프로그램을 강제종료해야 하는 상황이 연출이 됩니다.
: : : :
: : : : try catch, __try exception 등 여러가지 방법을 모두 사용해 봐도..
: : : :
: : : : 저 구문에서 오류가 나는 것을 감지(처리, 우회)를 하는 방법을 모르겠습니다.
: : : :
: : : : 구글링을 해봐도 뾰족한 수가 보이지 않아 염치불구하고 여러분들께 질문드립니다.
: : : :
: : : : 감사합니다.

+ -

관련 글 리스트
72965 IdTCPClient (Indy, 인디) 컴포넌트 오류(10053 Socket Error) 도움부탁드립니다. 유도청년 5284 2015/09/07
72987         Re:Re:IdTCPClient (Indy, 인디) 컴포넌트 오류(10053 Socket Error) 도움부탁드립니다. 유도청년 5512 2015/09/11
72968     Re:[답변]IdTCPClient (Indy, 인디) 컴포넌트 오류(10053 Socket Error) 도움부탁드립니다. 스머팩트 5197 2015/09/07
72971         Re:Re:[답변]IdTCPClient (Indy, 인디) 컴포넌트 오류(10053 Socket Error) 도움부탁드립니다. 유도청년 4446 2015/09/08
72972             Re:Re:Re:[답변]IdTCPClient (Indy, 인디) 컴포넌트 오류(10053 Socket Error) 도움부탁드립니다. 스머팩트 4584 2015/09/08
72977                 Re:Re:Re:Re:[답변]IdTCPClient (Indy, 인디) 컴포넌트 오류(10053 Socket Error) 도움부탁드립니다. 유도청년 5383 2015/09/09
72978                     Re:Re:Re:Re:Re:[답변]IdTCPClient (Indy, 인디) 추가확인 사항 입니다. 스머팩트 4607 2015/09/10
72986                         Re:Re:Re:Re:Re:Re:[답변]IdTCPClient (Indy, 인디) 추가확인 사항 입니다. 유도청년 5234 2015/09/11
72990                             Re:Re:Re:Re:Re:Re:Re:[답변]IdTCPClient (Indy, 인디) 마지막회 입니다. 스머팩트 6185 2015/09/11
73008                                 Re:Re:Re:Re:Re:Re:Re:Re:[답변]IdTCPClient (Indy, 인디) 마지막회 입니다. 초보대마왕 4838 2015/09/15
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.