Berkeley DB 5.2 Android平台编译过程介绍

在Berkeley DB 5.2版本中,Android Drop-in编译方式正式纳入官方发布文档。5.2的Android编译过程和先前我基于DBSQL 5.0写的博文稍有不同。以下介绍Oracle Berkeley DB 5.2官方文档中Android安装文档。欢迎交流。

Android默认提供的数据库功能是SQLite。Berkeley DBSQL完全兼容SQLite API,可以直接替换SQLite库而无需改动现有的应用程序或服务。依本方法编译得到的Berkeley DBSQL库将完全替换Android的SQLite库(drop-in模式)。在这种模式下,Android平台上所有的应用程序(包括我们自己编译的应用程序)都将链接到Berkeley DBSQL库以获取更高的存储和并发性能。

完整原文:http://download.oracle.com/docs/cd/E17076_02/html/installation/build_android_intro.html

中文介绍:

Android编译过程

本节提供了Berkeley DB Drop-in方式的Android编译指令。

首先要下载并且编译Android源代码树。
第一次编译过程需要花费较长一段时间,不过后面再编译就快多了。可以从这里下载Android的源代码并且按照Android文档完成编译过程。

把Berkeley DB代码目录拷到Android的代码目录里面:

  1. $ cd ${root}/external/sqlite/dist  
  2. $ tar zxvf db-xx.tar.gz  

这里的${root}指的是Android源代码树的根路径。

通过以下命令将源代码树中默认的Android.mk文件替换成Berkeley DB的版本:

  1. $ cd ${root}/external/sqlite/dist  
  2. $ mv Android.mk Android.mk.sqlite  
  3. $ cp db-xx/build_android/Android.mk ./  

提示:编译之前,可通过这里查看Android平台上的几种调优参数。

重新编译数据库部分,这样Berkeley DB就替换到最终生成的系统镜像了:

  1. $ cd ${root}  
  2. $ . build/envsetup.sh  
  3. $ make clean-libsqlite  
  4. $ mmm -B external/sqlite/dist  
  5. $ make snod  

以上指令完成后,新的基于Berkeley DB SQL的Android系统镜像即编译完毕。系统会打印出新的镜像所在目录,一般来说这个目录是:${root}/out/target/product/generic。

从SQLite迁移到Berkeley DB

如果你需要使DBSQL能够自动打开并转换现有的SQLite数据库文件,请参照本节的步骤。

首先,我们需要通过以下脚本来为Android平台编译一个静态的SQLite shell, 这个shell对自动转换功能而言是必需的。

view plain copy to clipboard print ?
  1. #!/bin/bash  
  2. # This script shows how to use built-in toolchain to build  
  3. # sqlite3 shell, which is required by Berkeley DB SQL  
  4. # on-the-fly migration feature.  
  5.   
  6. # Note: these variables should be set per active Android source tree  
  7. # We assume $PWD=$ROOT/external/sqlite/dist  
  8. ROOT=${PWD}/../../..  
  9. TOOLCHAIN=${ROOT}/prebuilt/linux-x86/toolchain/arm-eabi-4.4.0  
  10. CC=${TOOLCHAIN}/bin/arm-eabi-gcc  
  11. LIB="${ROOT}/out/target/product/generic/obj/lib"  
  12. INCLUDE="${ROOT}/ndk/build/platforms/android-8/arch-arm/usr/include"  
  13.   
  14. # CFLAGS should be set per Android.mk.sqlite (the original  
  15. # version of SQLite's Android.mk)  
  16. CFLAGS="-DHAVE_USLEEP=1 -DSQLITE_THREADSAFE=1 -DNDEBUG=1 \ 
  17.  -DSQLITE_DEFAULT_JOURNAL_SIZE_LIMIT=1048576 \ 
  18.  -DSQLITE_ENABLE_MEMORY_MANAGEMENT=1 \ 
  19.  -DSQLITE_DEFAULT_AUTOVACUUM=1 \ 
  20.  -DSQLITE_TEMP_STORE=3 -DSQLITE_ENABLE_FTS3 \ 
  21.  -DSQLITE_ENABLE_FTS3_BACKWARDS -DTHREADSAFE=1"  
  22. CFLAGS="${CFLAGS} -I${INCLUDE}"  
  23.   
  24. LDFLAGS="-ldl -nostdlib -Wl,--gc-sections -lc -llog -lgcc \ 
  25.  -Wl,--no-undefined,-z,nocopyreloc ${LIB}/crtend_android.o \ 
  26.  ${LIB}/crtbegin_dynamic.o -L${LIB} -Wl,-rpath,${LIB}"  
  27.   
  28. ${CC} -DANDROID -DOS_ANDROID --sysroot="${SYSROOT}" -mandroid \  
  29.       -fvisibility=hidden -ffunction-sections -fdata-sections \  
  30.       -fPIC ${LDFLAGS} ${CFLAGS} \  
  31.       sqlite3.c shell.c -o sqlite3orig  

提示:你可能需要根据当前环境来修改以上环境变量。

运行以上脚本,成功的话我们就得到了一个静态的sqlite3 shell工具 – sqlite3orig

接下来我们需要修改系统image文件。首先用xyaffs2工具解压镜像文件

  1. $ xyaffs2 ./system.img system  

把编译好的sqlite3工具拷进去。

  1. $ cp ${root}/external/sqlite/dist/sqlite3orig system/xbin/sqlite3orig  

使用mkyaffs2image工具来重新生成system.img.

  1. $ mkyaffs2image -f $PWD/system system.img  

这样,修改好的系统镜像即可自动转换并打开现成的SQLite3数据库文件。需要注意的是:在adb shell模式下,打开sqlite3数据库的命令是sqlite3orig;而打开Berkeley DBSQL数据库的命令是sqlite3。

转自:http://www.bdbchina.com/2011/07/berkeley-db-5-2-android%E5%B9%B3%E5%8F%B0%E7%BC%96%E8%AF%91%E8%BF%87%E7%A8%8B%E4%BB%8B%E7%BB%8D/android%E5%B9%B3%E5%8F%B0%E7%BC%96%E8%AF%91%E8%BF%87%E7%A8%8B%E4%BB%8B%E7%BB%8D/

你可能感兴趣的:(Berkeley DB 5.2 Android平台编译过程介绍)