2004년 1월 31일 토요일

Berkeley DB

http://www.sleepycat.com/
http://www.sleepycat.com/docs/index.html
참고 서적 : Berkeley DB, sleepycat software, New Riders출판사.

tar xzvf db-4.2.52.tar.gz

ln -s /home/ilashman/local/src/db-4.2.52/docs /home/ilashman/public_html/bdb
(Html document를 link로 건다.)
http://ecoli.neowiz.com:8080/~ilashman/bdb/

cd build_unix/
../dist/configure --prefix=/home/ilashman/local/db-4.2.52 --enable-cxx
make -j 4
make install

export LIBDIR=$LIBDIR:/home/ilashman/local/db-4.2.52/lib
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/ilashman/local/db-4.2.52/lib
export LD_RUN_PATH=$LD_RUN_PATH:/home/ilashman/local/db-4.2.52/lib

------
RedHat 9.0인 경우에는 Berkeley DB가 rpm으로 깔려 있다.
$ rpm -qa|grep db
db4-devel-4.0.14-20
db4-4.0.14-20
db4-utils-4.0.14-20

예제 코드
------
$ cat test1.c
#include <sys/types.h>
#include <limits.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <db.h>

#define DATABASE "access.db"

int
main()

{
    DB *dbp;
    DBT key, data;

    int ret, t_ret;

    if ((ret = db_create(&dbp, NULL, 0)) != 0)
    {
        fprintf(stderr, "db_create: %s\n", db_strerror(ret));
        exit(1);
    }

    /* db 4.2.5의 API에는 open시에 DB_TXN을 입력해야 하는 데 db 4.0에는 없는 것 같다. */
    if ((ret = dbp->open(dbp, DATABASE, NULL, DB_BTREE, DB_CREATE, 0664)) != 0)
    {  
        dbp->err(dbp, ret, "%s", DATABASE);
        goto err;
    }

    memset(&key, 0, sizeof(key));
    memset(&data, 0, sizeof(data));
    key.data = "fruit";
    key.size = sizeof("fruit");
    printf("sizeof(\"fruit\") : %d\n", sizeof("fruit"));
    data.data = "apple";
    printf("sizeof(\"apple\") : %d\n", sizeof("apple"));
    data.size = sizeof("apple");

    if ((ret = dbp->put(dbp, NULL, &key, &data, 0)) == 0)
        printf("db : %s: key stored.\n", (char *)key.data);
    else
    {
        dbp->err(dbp, ret, "DB->put");
        goto err;
    }

    if ((ret = dbp->get(dbp, NULL, &key, &data, 0)) == 0)
        printf("db : %s: key retrieved: data was %s.\n", (char *)key.data, (char *)data.data);
    else
    {
        dbp->err(dbp, ret, "DB->get");
        goto err;
    }

    if ((ret = dbp->del(dbp, NULL, &key, 0)) == 0)
        printf("db: %s: key was deleted.\n", (char *)key.data);
    else
    {
        dbp->err(dbp, ret, "DB->del");
        goto err;
    }

err:
    if ((t_ret = dbp->close(dbp, 0)) != 0 && ret == 0)
        ret = t_ret;

    exit(ret);
}


컴파일 하기
------
gcc test1.c -g -Wall -ldb-4.0


--------------------
Berkeyley DB는 SQL을 사용하지 않는 다.
장점이라면 빠른 속도와 간편한 사용법에 있다.
key -> value 라는 단순한 형식으로 구성되어 있다.
단점은 너무 단순해서 복잡한 query와 table을 쉽게 쓸 수 없다는 것이다.

--------------------
Q) dbp->put 할 때 'Invalid Argument'라는 에러가 난다면?
A) argument가 제대로 되었는 데도 문제가 난다면 library의 link 상태를 의심해 본다.
Berkeley DB의 버젼에 따라 API가 다를 수 있다.
ldd 명령으로 shared library link 상태를 분석한다.
만약 잘못되어 있다면
library를 제대로 설치하고
LD_LIBRARY_PATH 환경 변수를 적절히 setting한다.

혹은 key, data 변수가 memset에 의해 제대로 초기화 되어 있는 지 살펴본다.

댓글 없음:

댓글 쓰기