리눅스용 통신라이브러리를 솔라리스에 포팅시 문제가 있습니까?
글쓴이: soft20 / 작성시간: 수, 2003/11/12 - 9:57오전
안녕하십니까?
좀 이상한 문제에 봉착해 있어서 이렇게 도움을 요청합니다.
현재 똑같은 라이브러리 및 소스코드를 이용하여 리눅스에서는 g++ 3.2.2를 솔라리스에서는 g++ 3.1을 사용하여 라이브러리를 각각 컴파일하고, 소스는 동일하므로 컴파일을 했습니다.
프로그램은 소켓 통신으로 서버로 메시지를 전달하도록 되어 있습니다.
제가 소켓으로 send하기전 fwrite를 이용하여 메시지를 바이트단위로 출력했을때 두기종간의 메시지가 동일합니다. 하지만 리눅스에서 전송한 데이터는 서버에서 정상 처리를 하는 반면, 솔라리스에서 전송한 데이터는 서버에서 거부하고 있는 것으로 보입니다.
서버에서 이를 확인해 주면 쉽게 될것으로 생각되지만 이또한 쉽지 않은 일이라 혹시 이런 경험을 가지신 분이 있으시면 조언 부탁드립니다.
바이트오더는 리눅스에서 htonl로 변경하고 있으니 솔라리스에서는 신경을 쓰지 않아도 되리라 생각이 됩니다. 아참 서버는 AIX입니다. :cry:
Forums:
AIX서버쪽으로 나가는 패킷을 스위치 미러링등을 통하여 중간에서
AIX서버쪽으로 나가는 패킷을 스위치 미러링등을 통하여
중간에서 잡아채서 덤프한걸 비교해보면 금방 해결될것 같네요.
좀 시간이 걸리더라도 가장 확실한...
^^*
혹시요.
바이트 오더 문제는 아닐까요.? AIX쪽에서 x86 기준으로 변환하게끔 해놓아서 정작 쏠라리스에서 들어오는것을 이상하게 받는것은 아닐까요.? 그냥 혹시나 해서요.
위의 문제 해결은 했습니다만 좀 이상하긴 하네요.
역시 이런 문제는 네트워크 상에서 페킷을 보는 것이 가장 빠른 길이 었던거같습니다. 혹시 이런 이상한 문제를 당하시는 분이 있으실까봐 제 경험을 써봅니다.
우선 TCP dump를 이용하여 리눅스와 솔라리스의 패킷을 받아본 결과. 솔라리스에서 IP 패킷 해더 부분의 TTL 값이 1로 셋팅되어 나가고 있었고, 리눅스는 기본 64로 나가고 있었습니다. 이 또한 정말 이상한 현상으로 setsockopt함수를 이용하여 소켓 옵션을 SO_DONROUTE 셋팅을 해놓았는데 리눅스에서는 이 옵션이 소용이 없는거 같더군요. 하지만 솔라리스에서는 정상적으로 셋팅이 되더군요.
역시 삽질이 가장 빠른 방법이었습니다. TT
답변 주신 고수님들 감사드립니다.
댓글 달기