Skip to main content

Posts

Showing posts from February 13, 2011

Sqlite database is locked

sqlite는 embedded system에서 널리 사용되는 무료 dbms?(dbms라고 말하긴 좀 그렇지만, dbms라 불러주자 ㅎ) 이다. 특히 memory db 기능이 아주 유용하다. 그 밖의 dbms에서도 이 기능이 있으나, 이 기능이 지원되는 버전은 대부분 고가이다. 따라서, 무료인 sqlite를 많이들 애용하는 것 같다. 멀티쓰레드를 sqlite DB를 구현하고 롱런테스트를 하다보면, pthread_mutex_lock으로 쓰레드 간의 교착상태를 막아줘도, sqlite lock 에러가 간헐적으로 발생할 것이다. 이에 대해 본인은 다음과 같은 에러 처리 구문을 준비하여 사용하고 있다. sqlite Error가 발생하면, sqlite3_exception함수를 호출한다. 이 함수에서 sqlite error code를 구분하여, 만약, busy 또는 locked이면 최대 2초간 sleep 상태로 만드는 sqlite3_busy_timeout, busy handler를 호출한다. 그 다음, goto 구문으로 재차 sqlite3_exec를 실행한다. 단, sqlite3_exec는 transaction의 begin과 commit 또는 rollback 구문 사이에서 실행한다. 대부분 lock 에러가 발생하더라도 1~2번 실패 후에, 처리된다는 것이 본인의 테스트 결과이다. 단, journal를 WAL로 변경하였음. 기존 journal은 멀티쓰레드 지향적이지 않다는 점을 잊지마시길.... Error Code SQLITE_LOCKED (6): Database Is Locked This error code occurs when you try to do two incompatible things with a database at the same time from the same database connection. For example, if you are in the middle of a SELECT statement and you t

토머스 제퍼슨의 10가지 습관

1. 오늘 할 수 있는 일을 내일로 미루지 않는다.   제퍼슨은 매일 동트기 전에 자리에서 일어나   그 날 할 일에 대한 목록을 작성했다.   2. 당신 스스로 해결할 수 있는 일로 다른 사람을 괴롭히지 않는다.   제퍼슨은 정치적 독립뿐 아니라 개인의 독립 역시 중요하게 생각했다.   그는 개인의 독립은 자신의 문제를 스스로 해결하는 능력에서 비롯된다고   생각했다.   3. 번 만큼만 쓴다.   제퍼슨은 이것을 어렵게 배웠다.   즉 이 충고를 수차례 무시하여 그에 따른 혹독한 대가를 치르면서,    벌기 전에 돈을 써서는 안된다는 사실을 깨달았다.   4. 값이 싸다는 이유로 원하지도 않는 물건을 구입하지 않는다.   당신에게 의미가 있는 물건만을 구입한다.   제퍼슨은 물질을 단순한 물질이 아니라 경험을 얻는 수단으로 생각했다.   5. 자만은 허기, 갈증, 추위보다도 많은 대가를 요구한다.   오랫동안 권력의 중심에 있으면서 제퍼슨은   자만이 초래한 참담한 결과를 수없이 목격했다.   6. 소식(小食)을 후회하는 이는 없다.   제퍼슨이 유달리 건강한 생활을 할 수 있었던 것은   건강에 유익한 음식 섭취와 소식 습관 때문이었다.   7. 낙관적인 태도를 갖는다.   선천적으로 낙관적이었던 제퍼슨은 항상 가장 좋아보이는 것을 선택할 수   있었다. 그것은 그가 '당신이 선택한 것을 손에 넣고 싶다면 당신이 갖고 있는 것을 선택하면 된다'는 식의 사고방식을 갖고 있었기 때문이다.   8. 기우(杞憂)는 마음을 병들게 한다.   제퍼슨은 걱정은 무의미한 일임을 일깨워주고 있다. 그는 낙관적인 사고방식으로 미래에 대한 모든 근심걱정에서 벗어날 수 있었다.   9. 무리 없이 일을 처리한다.   제퍼슨은 저항을 최소화하면서 일처리를 하는 온유한 사람이었다.   10. 화가 치밀 때는 열까지 센 다음 말한다.   폭발할 것 같을 때는 백까지 세고 말한다. 계몽주의자로서 제