多线程环境下OTL的使用《转载》

 

1, OTL是什么

OTL是一个数据库访问模板库,支持绝大部分数据库访问。OTL是C++写的,based on templates, 只有一个头文件,大小只有800K+。使用方便,性能也很不错

可以使用OTL访问基本上所有的数据库,在你更换数据库时不用修改任何业务代码

强烈推荐在C++开发中使用

 

2,OTL下载

http://www.veda.dk/~clr/doc/otl/otlv4_h.zip

 

3,OTL使用

参见OTL Samples: http://www.veda.dk/~clr/doc/otl/otl3_examples.htm

 

4,多线程下使用OTL时几个注意的地方

1) static int otl_connect::otl_initialize(const int threaded_mode=0);

如果在多线程环境下使用,threaded_mode设置为1

注意:即使设置为1并不代表就是线程安全(thread-safe)

实际上OTL并不是线程安全的,一个otl_connect只能同时被一个线程使用,如果在多线程环境下使用OTL,需要自己保证otl_connect对象的线程安全

 

2)otl_stream_pool

OTL支持stream pool,就是一个池,在一个otl_stream close时,把它放到池中,下次访问时可以从池中获取,实现fast reopen,提高程序性能

注意:otl_stream_pool是otl_connect的一个成员,所以要在otl_connect锁unlock之前执行otl_stream.close,否则会出现那个啥:)

即使不使用otl_stream_pool,也要在otl_connect锁unlock之前执行otl_stream.close

 

经验证,OTL在多线程环境可以稳定运行

使用otl_stream_pool可以获得一定的性能提升

posted @ 2011-11-10 10:15  kanego  阅读(1808)  评论(0编辑  收藏  举报