통신 중 소켓어러 ..
도와주세요.
아래소스중 타임아웃이 걸려 적색부분의 루틴을 타는것 같이 보입니다.
이런 경우는 어떨 때 발생되나요?
회사에서 테스트하면 잘 되는데..
집에서 테스트 하면 적색부분루틴을 탑니다.
에러메시지
Server Socket read error rc=-1,errno=131
/**************************************************************
FUNC_NAME : RecvTcpMessage
DESCRIPTION : 메세지 수신 함수
ARGUMENT :
data.h.timeout = 0 : 수신이 성공할 때까지 기다린다.
/Server Socket
/* 기 설정된 Timout signal 함수를 취소한다 */
Signal( SIGALRM, SIG_IGN );
alarm ( 0 );if ( TimeSet > 0 )
{
Signal( SIGALRM, TimeOut );
alarm ( TimeSet );
}rc = Read( sockfd, data, sizeof(FILE_DATA) );
if ( rc <= 0 )
{
/* Timeout에 의한 signal처리인 경우 */
if ( errno == EINTR )
{
Signal( SIGALRM, SIG_IGN );
alarm ( 0 );errno = 0;
return MSG_TIMEOUT;
}
else
{
Signal( SIGALRM, SIG_IGN );
alarm ( 0 );close( sockfd );
sockfd = -1;printf("[Server Socket read error rc=%d,errno=%d]", rc, errno);
return MSG_ERROR;
}
}Signal( SIGALRM, SIG_IGN );
alarm ( 0 );return MSG_OK;
}
회사와 집이라면, 컴이 다를거고 거기다 커널도 버젼이 다를것 같은데,
회사와 집이라면,
컴이 다를거고 거기다 커널도 버젼이 다를것 같은데,
혹, 커널만이라도 동일한 조건에서 해보시는건 어떠신지요,,
혹시...
회사에서는 서버, 클라이언트를 같은 머신에서 돌리고 집에서는 서버, 클라이언트를 서로 다른 머신에서 실행시키시지 않습니까?
나를 죽이지 않는 모든 것은 나를 강하게 할 뿐이다.
중요한 정보를 빠뜨렸네요.
-참고 :
unix server(c):회사
client(vc++) :회사에서 잘됨, 집에서 같은 프로그램으로 하더라도 위의 에러가 납니다. --
errno 값이?
errno 값이 이상하네요.
read 함수에서 에러 값들은 다음과 같습니다.
EINTR (4)
EAGAIN (11)
EIO (5)
EISDIR (21)
EBADF (77)
EINVAL (22)
EFAULT (14)
errno 값을 다시 한번 확인해보시는게 좋을 것 같네요.
음.. VC++ 이라면, WSAGetLastError 를 통해서 에
음.. VC++ 이라면, WSAGetLastError 를 통해서
에러값을 얻는게 맞지 않나요..
리눅스가 아니라서 잘모르겠네요.. 쩝 -_-;;
Re: errno 값이?
read 함수와 errno를 출력하는 printf 사이에 close 함수가 호출되네요.
출력한 errno는 close 함수의 errno가 아닐까요?
댓글 달기