프로그램 구조(로직?) 에 대해 어떤것이 나을까요..?
글쓴이: wnldirqhrdyd / 작성시간: 금, 2010/03/12 - 2:03오후
안녕하세요
서버를 개발중인데요..
클라이언트에게 데이터를 전송하는데
db에서 받아와서 전송하게 됩니다.
여기서 고민이 되는데요..
1)
db에 접속을 계속 해둔상태에서
데이터를 필요시에 쿼리문을 날리는게 낳을까요
2)
아님 데이터를 필요로할때마다 db에 접속을 하고 쿼리문을 날려서 데이터를 받아오고 db접속을 끊고..
다시 데이터를 보내게 될때 다시 db에 접속을 하고 쿼리문 날리고,, 데이터 받고 db 접속을 끊고..
둘중 어떤 구조가 올바른 프로그래밍일까요..
참고로 클라이언트에게는 3초 단위로 데이터를 전송합니다..
Forums:
3초에 한번이라면 한번 접속하는 것이 좋습니다.
이미 해결 방법을 찾으셨을 것 같지만 일반적인 내용 적어 올립니다.
DB에 3초에 한번씩 특정 쿼리를 전송할 경우
만약 3초에 한번씩 접속하고 끊고를 반복하게 되면 해당 포트로의 접속 상태가 TIME_WAIT나 CLOSE_WAIT 등이
불필요하게 늘어날 수 있으며, 접속 자체의 오버헤드가 발생하므로 한번 접속하고 쿼리를 전송하는 것이 좋을 듯 싶습니다.(해당 DB에 접속을 유지해야 할 클라이언트가 많은 경우는 다른 고민을 해야 합니다.)
단 DB서버가 재시작하거나 순간적인 통신 오류로 인하여 접속이 끊어질 것을 대비하여
에러 체크하여 에러 발생후 재접속하는 코드를 삽입시켜 주시면 문안하게 동작할 것으로 보입니다.
하지만 긴 시간(1분이상)에 한번 정도 데이터를 전송하는 구조라면 데이터 전송할 경우에만
접속하는 것이 좋습니다.
댓글 달기