Environments封装了一个或多个的数据库。个人觉得可以理解为是JE的总的配置的环境。我们一般用它来打开database,或者是取得transaction。
下面演示打开和关闭Enviroment。
Environment myDbEnvironment = null;
try {
EnvironmentConfig envConfig = new EnvironmentConfig();
envConfig.setAllowCreate(true);
myDbEnvironment = new Environment(new File("/export/dbEnv"),
envConfig);
...do something
} catch (DatabaseException dbe) {
// Exception handling goes here
} finally{
if (myDbEnvironment != null) {
myDbEnvironment.close();
}
}
注意,可能出现一种情况是,在你关闭Environment的时候,后台线程(cleaner thread)还未完成它的工作,这将会导致你的日志文件不准确,为了保证这种情况不会发生,你可以在调用Environment.close()方法之前,调用Environment.cleanLog()方法。就像这样:
if (myDbEnvironment != null) {
myDbEnvironment.cleanLog(); // Clean the log before closing
myDbEnvironment.close();
}
接下来,我们讨论几个Environment的常用设置。Environment可以在开始创建的时候通过EnvironmentConfig来进行属性设置。
- EnvironmentConfig.setAllowCreate()
设置若不存在该Environment,则新建一个。注意的是文件可以不存在,但是文件夹必须要存在。
- EnvironmentConfig.setReadOnly()
设置是否由此Environment打开的database都是只读的。
- EnvironmentConfig.setTransactional()
设置这个Environment是否支持事务。
除了使用EnvironmentConfig在创建Environment的时候进行属性设置,你还可以用EnvironmentMutableConfig来设置一个已存在的Environment实例。注意的是EnvironmentConfig类是继承自EnvironmentMutableConfig类,所以在EnvironmentMutableConfig设置的属性,都可以通过EnvironmentConfig进行设置。
- setCachePercent()
设置JE缓存可以使用多少百分比的JVM缓存
- setCacheSize()
设置JE缓存可以使用多少大,单位是
- setTxnNoSync()
设置是否在事务提交的时候马上把改变写入到日志文件。
- setTxnWriteNoSync()
设置当事务提交的时候日志文件是否被刷新。
下面演示下Environment属性的设置:
EnvironmentConfig envConfig = new EnvironmentConfig();
envConfig.setAllowCreate(true);
myEnvConfig.setReadOnly(false);
Environment myEnv = new Environment(new File("/export/dbEnv"), null);
EnvironmentMutableConfig envMutableConfig = new EnvironmentMutableConfig();
envMutableConfig.setTxnNoSync(true);
myEnv.setMutableConfig(envMutableConfig);
Environment的属性还能在JE的属性文件中设置,属性文件的位置是<environmentHome>/je.properties ,他们的优先顺序是:
1.在<environmentHome>/je.properties设置的属性
2.通过EnvironmentConfig设置的属性
3.默认的属性
分享到:
相关推荐
Oracle BerkeleyDB-JE je-6.0.11
BerkeleyDB-Core-C-GSG.pdf bdb c开发手册 英文版
Berkeley DB JE-7.0.6 jar包
Java-Edition-BerkeleyDB-3.1.0,国外的开源数据库,供大家参考
(二) Berkeley DB -- Access Method Configuration_iyangjian2005997_新浪博客.mht
Berkeley DB -- 入门知识和一个小例子_iyangjian2005997_新浪博客.mht
BerkeleyDB和Sqlite是当前最流行的嵌入式开源数据库。
Life After BerkeleyDB- OpenLDAP's Memory-Mapped Database
db-6.1.26.tar.gz berkeley db
关于berkeley db 4.6.2的介绍性文章,是了解berkeley db的技术文档。
嵌入式数据库,功能强大,可用于如QQ本地的聊天记录数据库等,使用方便,效率高
berkeley db je-6.4.9.gz
Berkeley DB是一个开源的文件数据库,介于关系数据库与内存数据库之间,使用方式与内存数据库类似,它提供的是一系列直接访问数据库的函数,而不是像关系数据库那样需要网络通讯、SQL解析等步骤,本文件是早期版本
官方版本,亲测可用
1. Introduction to Berkeley DB ......... 1 About This Manual .......... 2 Berkeley DB Concepts ........... 2 Access Methods ......... 4 Selecting Access Methods ......... 4 Choosing between BTree and ...
Berkeley DB 4.4.20 .tar.gz 来自https://www.oracle.com/database/technologies/related/berkeleydb-release-history.html
来自于oracle的BerkeleyDB帮助文件,里面有代码的。
文件类型的DB,存取速度快,操作方便,是以map方式key-value方式存取数据.兄弟大家共享!
BerkeleyDB:BerkeleyDB-对Berkeley DB 2.x或更高版本的Perl5访问
building-ha-scalable-applications-with-berkeley-db-whitepaper