버클리 DB close시 이유없는 down 발생
글쓴이: kkjin32 / 작성시간: 수, 2005/02/23 - 3:12오후
안녕하세요.
버클리 DB를 이용하여 어플리케이션을 개발하고 있습니다.
DB의 종료시
DB *tdbp; if (tdbp != NULL) { ret = tdbp->close(tdbp, 0); if (ret != 0) { rtn = RESULT_ERROR; } }
와 같이 하고 있습니다.
그런데 간혹 close시 어플리케이션이 에러코드도 내지 않고 down되곤 합니다.
혹시 이유를 아시거나 close시 체크해야 되는 사항 있으면 알려주시면 감사하겠습니다.
고맙습니다.
Forums:
gdb를 애용해 보세요. :roll:
gdb를 애용해 보세요. :roll:
gdb를 애용해 보세요. :roll:
gdb를 애용해 보세요. :roll:
gdb DB 사이즈가 너무 커요.
수백만건을 저장하려고 하면 DB사이즈가 어마어마하게 커져요.
버클리 DB에 비해 6배 가량 커집니다.
추가로 질문하나 더 올립니다.
아까 드린 질문과 같은 맥락입니다.
DB close시 시간이 put이나 get에 비해 오래 걸립니다.
close하기전에 DB에 update를 합니다.
DB 크기는 1M가 안되는 크기 입니다.
혹시 DB sync 문제 인가 싶기도 한데...
해결책이나 윗 질문에 대한 답변 부탁드립니다.
답글입니다.
프로그램상의 버그가 존재하지 않으면 dbp->close() 함수 사용시 오류가 발생할 이유가 없습니다.
다만 버클리 api와 관련 되지 않은 다른 코드에서 메모리 관련 잠재적인
버그가 존재 할경우 버클리 api에서 오류를 내거나 에러도 발생시키지
않고 프로세스가 죽는 경우를 경험한적이 있습니다.
다른쪽 코드를 확인 하셔야 될것 같습니다.
그리고 dbp->close()시 오랜 시간이 걸린다고 하셨는데..
음.. 캐쉬에 20M 정도 있는경우 디스크에 기록하는데 1~2초도 안걸립니다.
디스크 기록시간이 얼마나 오래걸리는지 궁금하네요..
답변 감사드립니다.
답변 감사드립니다.
DB->close에서 down되는건 시간이 오래 걸리는 중에 signal을 받아서 발생하는걸로 추정 됩니다.
DB->close 시간은 말씀하신데로 1~2초 대 인데 1~2초는 이 어플리케이션에서는 상당히 긴 시간입니다.
다른 api는 10~ 20ms 정도의 시간이 소요되는데 close만 그렇게 걸립니다.
혹 시간을 빨리할수 있는 방법이 없을까요?
댓글 달기