client port binding 문제
글쓴이: plrmsu / 작성시간: 금, 2013/10/04 - 2:46오후
안녕하세요
리눅스에서 server/client socket 프로그래밍을 하고 있는데요
client port 할당 때문에 문제가 되고 있습니다.
server가 50000번으로 port를 열어 두고 기다리고 있으면
제가 만든 client에서 50000번으로 접속하여 문제없이 진행이됩니다.
그런데,
server가 죽어 있는 경우, client에서 connection retry를 계속하다보면
아래와 같이 client 프로그램에서 50000 port를 계속 잡고 있어 문제가 발생합니다.
이런 현상이 server가 죽자마자 발생하지는 않고, 테스트를 해보니 대략 10시간 정도
지나서 확인이 되었습니다.
혹시 이런 경험 해보신분 있으신가여?
netstat -anp|grep tcp
tcp 0 0 127.0.0.1:50000 127.0.0.1:50000 ESTABLISHED 7041/client
Forums:
굉장히 어려운 말이네요.
저희 어머니께서 아프신데. 어디가 아픈지 도통 모르겠습니다. 라고 물어보는거 같습니다.
1. 서버가 죽지 않도록 만들어야 하고
2. 죽는 원인을 찾아야 하고
3. 각 함수에서 에러코드를 디버깅해봐야 하고
4. 변수 크기를 넘는지. 삭제는 잘했는지. 확인해보고
5. 예외 처리가 잘 되었는지 확인하고
6. 소켓 핸들. GDI. 메모리 증가. 스레드 증가. 메모리 동시 접속. 등에 다양한 처리 방식을 해봐야 합니다.
멀티 스레드의 경우는 접속과 해지. 데이터 접근 처리에서 비슷한 현상이 일어날 수 있습니다.
ㅡ_ㅡ;; 저도 잘은 모르겠네요. 그저 함수나 디버깅해서 볼 수 있을 뿐 이져.
좀 더 좋은 해결 방법으로는
- 전문가를 모시고 해결하거나
- 잘 되는 소스를 구해서 구현하거나
- 책 보면서 직접 코딩하는거죠. ㅇ_ㅇ;;
----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com
답변 감사합니다. 이것 저것 좀더 찾아 보니까
답변 감사합니다.
이것 저것 좀더 찾아 보니까 tcp simultaneous open 관련된 내용인것 같네여
댓글 달기