青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 6  文章 - 11  trackbacks - 0
<2011年2月>
303112345
6789101112
13141516171819
20212223242526
272812345
6789101112

常用鏈接

留言簿(1)

隨筆檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

  平臺服務和腳本服務接口對后端PostgreSQL數(shù)據(jù)庫的使用目前采用短暫連接方式,造成多次調用服務時頻繁連接和斷開數(shù)據(jù)庫,效率很低。

  如果共享數(shù)據(jù)庫連接,則會造成多線程訪問數(shù)據(jù)庫時的事務沖突,故必須采用連接池來管理對數(shù)據(jù)庫的并發(fā)訪問,某一線程連接到數(shù)據(jù)庫使用完畢后,不斷開數(shù)據(jù)庫連接,而是把連接歸還給連接池。

  另一線程訪問數(shù)據(jù)庫時會首先向連接池申請已經(jīng)存在的連接,如果連接池中沒有空閑連接,或者申請到得連接已經(jīng)超時失效,再建立新的連接,使用完畢后同樣歸還到連接池。

  這樣連接池中的連接數(shù)會隨著線程壓力的增加逐漸增長,直到所有的線程同時工作,達到最多連接數(shù)。

  由于一個線程可能同時申請多個連接,故連接數(shù)可能會大于線程數(shù)。連接池在程序結束時銷毀全部連接,或者線程在申請到的某一連接失效時銷毀該連接。


 1 
 2 class dbConnection
 3 {
 4     friend class dbConnectionPool;
 5     bool is_using;
 6 
 7 public:
 8     pqxx::connection pqxx_conn;
 9 
10 public:
11     dbConnection(string opt)
12         : pqxx_conn(opt),is_using(false)
13     {}
14 };
15 
16 typedef boost::shared_ptr<dbConnection> dbConnection_ptr;
17 
18 class dbConnectionPool
19 {
20     string                        m_opt;
21     size_t                        m_max_num;
22     std::vector<dbConnection_ptr> m_pool;
23     cppx::thread_mutex            m_mutex;
24 
25 public:
26     dbConnectionPool(string opt,size_t max_num)
27         : m_opt(opt),m_max_num(max_num)
28     {}
29 
30     dbConnection_ptr GetConnection(void){
31         ACE_DEBUG((LM_DEBUG,"(%t) LINE %d : %C\n", __LINE__ ,__FUNCTION__));
32 
33         cppx::scoped_lock lock(m_mutex);
34         foreach(dbConnection_ptr ptr,m_pool){
35             if( ptr->is_using == false ){
36                 ptr->is_using = true;
37 
38                 if( ptr->pqxx_conn.is_open() ){
39                     ACE_DEBUG((LM_DEBUG,"(%t) 找到連接池空閑連接。\n"));
40                     return ptr;
41                 }
42             }
43         }
44 
45         ACE_DEBUG((LM_DEBUG,"(%t) 沒有空閑連接,創(chuàng)建新連接。[%d]\n",m_pool.size()));
46 
47         // 沒有空閑連接,創(chuàng)建新連接
48         dbConnection_ptr ptr(new dbConnection(m_opt));
49         ptr->is_using = true;
50 
51         // 找到一個失效的連接,用新連接覆蓋
52         bool cover = false;
53         for(size_t idx = 0; idx < m_pool.size(); idx++){
54             dbConnection_ptr ptr2 = m_pool[idx];
55             if( ptr2->is_using == false && ptr2->pqxx_conn.is_open() == false ){
56                 m_pool[idx] = ptr;
57                 cover = true;
58                 ACE_DEBUG((LM_DEBUG,"(%t) 覆蓋失效的連接[%d]。\n",idx));
59                 break;
60             }
61         }
62         if!cover ){
63             m_pool.push_back(ptr);
64         }
65         
66         return ptr;
67     }
68 
69     void ReleaseConnection(dbConnection_ptr ptr_){
70         ACE_DEBUG((LM_DEBUG,"(%t) LINE %d : %C\n", __LINE__ ,__FUNCTION__));
71         ACE_DEBUG((LM_DEBUG,"(%t) 連接使用完畢,歸還到連接池。[%d]\n",m_pool.size()));
72 
73         cppx::scoped_lock lock(m_mutex);
74         ptr_->is_using = false;
75     }
76 };
77 
78 class dbConnectionUser
79 {
80     dbConnectionPool & pool;
81 
82 public:
83     dbConnection_ptr   conn;
84 
85 public:
86     dbConnectionUser(dbConnectionPool & pool_) : pool(pool_) {
87         conn = pool.GetConnection();
88     }
89     ~dbConnectionUser(void){
90         pool.ReleaseConnection(conn);
91     }
92 };
93 

  使用連接池的方法,只要在建立數(shù)據(jù)庫連接的類中增加連接池成員即可:
 1 
 2 struct ALEE_PlatformService_iPqxx::pimpl_t
 3 {
 4 #if defined(USE_POOL_DBLINK) && (USE_POOL_DBLINK == 1)
 5 
 6 public:
 7     dbConnectionPool m_pool;
 8 
 9 #else
10 

  為了方便,定義如下的宏:
1 #define DB_CONNECTION() \
2     dbConnectionUser user(pimpl_->m_pool);                              \
3     if!user.conn || !user.conn->pqxx_conn.is_open() ) return false;   \
4     pqxx::work X(user.conn->pqxx_conn);
5 

  需要調用數(shù)據(jù)庫查詢時,只需要把上面的宏插入try塊中:
 1 
 2     try{
 3         DB_CONNECTION();
 4 
 5         fuStringCommand cmd;
 6         cmd = pimpl_->m_sqls["apx_get_moi_attr_enum"];
 7         cmd << X.quote(moi_hash)
 8             << X.quote(attr_code);
 9 
10         result = new defs::xml_row;
11         return pimpl_->QueryRecord(X, cmd, *result);
12     }
13     catch_pqxx_error();
14 

  一個簡單的數(shù)據(jù)庫連接池就完成了,由于多線程并發(fā)時動態(tài)申請數(shù)據(jù)庫連接,既可以充分發(fā)揮數(shù)據(jù)庫并發(fā)的好處有避免了共享數(shù)據(jù)庫連接造成事務沖突。完全滿足簡單的數(shù)據(jù)庫查詢需要。

  等燈。等燈。 Cppx Inside
posted on 2011-02-28 13:57 風雷九州 閱讀(5781) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产亚洲成精品久久| 麻豆91精品| 国产精品久久久久久久久久直播| 欧美一区国产二区| 中文亚洲视频在线| 日韩视频第一页| 欧美成va人片在线观看| 欧美国产日本高清在线| 久久综合狠狠| 亚洲国产精品va| 亚洲另类自拍| 亚洲国产一区二区视频| 国产精品人成在线观看免费 | 国产精品高潮粉嫩av| 欧美日韩综合另类| 国产精品二区在线| 欧美成人中文字幕| 国产精品美女久久久| 欧美日韩国产专区| 欧美超级免费视 在线| 亚洲国产精品t66y| 欧美日韩成人精品| 久久av二区| 9色精品在线| 国产精品欧美日韩一区| 久久深夜福利免费观看| 欧美日韩国产色综合一二三四| 亚洲人成网站在线观看播放| 亚洲精品免费电影| 亚洲国产经典视频| 亚洲视频中文字幕| 一本久久知道综合久久| 亚洲精品久久久久久久久久久久久 | 久久精品国产一区二区三| 蜜臀久久99精品久久久画质超高清| 欧美电影在线免费观看网站| 欧美视频一区二区三区四区| 日韩视频一区二区| 一区二区三区精品视频| 国产精品高清在线| 亚洲午夜黄色| 午夜视频在线观看一区二区| 亚洲另类自拍| 亚洲欧洲精品一区二区精品久久久| 日韩香蕉视频| 亚洲欧美日韩精品久久久| 午夜精品国产更新| 亚洲大片av| 亚洲欧美中文在线视频| 久久久777| 欧美ab在线视频| 亚洲美女毛片| 亚洲欧美日韩在线观看a三区| 久久成年人视频| 国产精品久久二区| 亚洲欧洲在线视频| 亚洲网站视频| 美女精品视频一区| aⅴ色国产欧美| 亚洲影院色在线观看免费| 久久久蜜桃精品| 欧美视频一区二区在线观看 | 久久精品二区亚洲w码| 国外精品视频| 久久一区国产| 亚洲精品久久久蜜桃| 久久激情中文| 国产精品女人久久久久久| 亚洲人成网在线播放| 午夜精彩视频在线观看不卡| 欧美激情四色| 猛男gaygay欧美视频| 国产美女精品免费电影| 欧美伊人久久久久久午夜久久久久 | 亚洲欧洲av一区二区| 欧美高清视频免费观看| 欧美黄色免费| 国产亚洲成年网址在线观看| 亚洲一区观看| 久久漫画官网| 亚洲线精品一区二区三区八戒| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产日韩欧美黄色| 久久久久国产一区二区| 亚洲一区二区av电影| 欧美午夜视频在线| 亚洲国产精品成人综合| 欧美成人精品福利| 久久婷婷国产综合国色天香| 国内外成人在线| 蜜桃av一区二区三区| 久久久久亚洲综合| 欧美+日本+国产+在线a∨观看| 日韩天堂av| 99精品国产一区二区青青牛奶| 欧美日韩一区二区在线视频| 性欧美videos另类喷潮| 欧美在线一级视频| 精品成人在线| 亚洲美女中出| 国产精品久久亚洲7777| 久久一区二区视频| 亚洲一区二区成人| 伊甸园精品99久久久久久| 欧美一区二区在线视频| 亚洲第一视频| 亚洲伊人伊色伊影伊综合网| 久久久久久久999精品视频| 国产精品久久久久一区二区| 久久精品亚洲| 国产精自产拍久久久久久| 国产精品入口麻豆原神| 亚洲午夜精品久久久久久app| 香蕉久久一区二区不卡无毒影院 | 欧美在线播放一区| 国产精品久久久久91| 老司机免费视频一区二区| 欧美二区在线| 亚洲精品三级| 亚洲激情午夜| 亚洲肉体裸体xxxx137| 中国成人在线视频| 欧美一区二区性| 亚洲视频一二三| 亚洲欧美国产毛片在线| 国产精品激情| 亚洲精品在线观看免费| 国产伦理精品不卡| 欧美激情bt| 国产女主播一区| 欧美激情按摩| 亚洲福利国产| 久久精品国产99| 久久成人资源| 国产精品美女主播| 一本色道久久88亚洲综合88| 亚洲日本成人在线观看| 久久久久久9| 久久天堂av综合合色| 国产精品一区=区| 一区二区三区欧美在线| 在线视频一区二区| 欧美日本中文字幕| 一区二区激情视频| 午夜国产欧美理论在线播放| 国产精品捆绑调教| 亚洲女同性videos| 久久国产精品久久w女人spa| 国产欧美视频一区二区三区| 最新国产成人在线观看| 亚洲人成艺术| 免费高清在线视频一区·| 欧美亚洲午夜视频在线观看| 亚洲男人第一av网站| 亚洲欧美国产日韩天堂区| 亚洲无毛电影| 久久久7777| 欧美日韩卡一卡二| 国产精品一区二区久久久| 久久精品官网| 午夜久久tv| 在线观看成人小视频| 欧美在线一区二区三区| 久久综合亚洲社区| 亚洲第一毛片| 欧美激情综合五月色丁香| 日韩午夜电影在线观看| 午夜激情综合网| 在线观看亚洲a| 欧美激情一区二区久久久| 亚洲少妇在线| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲第一区在线观看| 欧美日韩大片| 欧美在线视频二区| 亚洲激情在线视频| 欧美一区二区三区的| 一区二区视频免费完整版观看| 久久国产精品高清| 亚洲精品一区二区三| 国产精品成人aaaaa网站| 久久精品综合一区| 日韩视频免费观看| 久久精品盗摄| 日韩网站免费观看| 国一区二区在线观看| 欧美午夜不卡在线观看免费 | 亚洲影院一区| 在线欧美日韩| 国产亚洲精品久| 欧美精品在欧美一区二区少妇| 欧美一区二区视频观看视频| 亚洲日本无吗高清不卡| 久久久xxx| 亚洲专区一二三| 亚洲乱码国产乱码精品精| 亚洲福利视频在线| 国产自产2019最新不卡| 国产精品成人免费视频| 欧美精品123区|