久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

利用Apache Common將java對(duì)象池化的問(wèn)題

瀏覽:138日期:2023-03-07 14:40:29

什么是對(duì)象池化?

對(duì)象被創(chuàng)建后,使用完畢不是立即銷毀回收對(duì)象,而是將對(duì)象放到一個(gè)容器保存起來(lái),下次使用的時(shí)候不用創(chuàng)建對(duì)象,而是從容器中直接獲取。

什么樣的對(duì)象需要池化?

一般需要池化的對(duì)象往往都是比"重量級(jí)"較的對(duì)象,創(chuàng)建和銷毀都比較耗時(shí),比如我們的"線程","數(shù)據(jù)庫(kù)鏈接對(duì)象","tcp鏈接對(duì)象", "FTP鏈接對(duì)象" 等等。

對(duì)象池化的好處?

這些對(duì)象池化后,之后使用的時(shí)候不用創(chuàng)建,直接使用即可,可以大大縮短程序的運(yùn)行時(shí)間,以及創(chuàng)建對(duì)象時(shí)對(duì)CPU資源的消耗,以及對(duì)系統(tǒng)資源的控制(池化的對(duì)象數(shù)量有限,不會(huì)一直創(chuàng)建對(duì)象,導(dǎo)致系統(tǒng)資源耗盡,或者造成程序OOM的情況)進(jìn)而提高系統(tǒng)的穩(wěn)定性。

對(duì)象池化后需要注意什么?

這些被池化的對(duì)象都有一個(gè)特點(diǎn),都是"活的",比如數(shù)據(jù)庫(kù)鏈接對(duì)象內(nèi)部一般保存了一個(gè)TCP鏈接,所以,這個(gè)對(duì)象"能用"的前提是這個(gè)TCP鏈接是有效的,線程對(duì)象"能用"的前提是線程的狀態(tài)不是"凋亡"狀態(tài),所以我們有必要定期對(duì)對(duì)象的"健康狀態(tài)"進(jìn)行檢查,剔除掉"不能用"的對(duì)象,并填充新的對(duì)象給"對(duì)象池"。

使用apache-common-pool池化對(duì)象

  • 引入依賴
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-pool2</artifactId>
    <version>2.9.0</version>
</dependency>
  • 需要池化的對(duì)象示例
public class Foo {
    private final String username;
    public Foo(String username) {
this.username = username;
    }
    public String getUsername() {
return username;
    }
}
  • 構(gòu)建對(duì)象創(chuàng)建工廠

可以直接實(shí)現(xiàn)org.apache.commons.pool2.PooledObjectFactory<T>接口實(shí)現(xiàn)創(chuàng)建、銷毀、鈍化、取消等接口,也可以使用他的抽象類,實(shí)現(xiàn)創(chuàng)建和包裝方法即可。

public class FooPoolObjectFactory extends BasePooledObjectFactory<Foo> {
    @Override
    public Foo create() throws Exception {
return new Foo(String.valueOf(RandomUtils.randomInt(0, 10)));
    }
    @Override
    public PooledObject<Foo> wrap(Foo obj) {
return new DefaultPooledObject<>(obj);
    }
}
  • 實(shí)現(xiàn)驅(qū)逐策略

一般數(shù)據(jù)庫(kù)鏈接對(duì)象,要定期進(jìn)行心跳,確保鏈接可用,如果鏈接斷開(kāi),需要銷毀對(duì)象,并重新創(chuàng)建新的對(duì)象。common-pool中,我們可以實(shí)現(xiàn)驅(qū)逐策略,對(duì)對(duì)象進(jìn)行定期檢查

public class FooEvictionPolicy implements EvictionPolicy<Foo> {
    @Override
    public boolean evict(EvictionConfig config, PooledObject<Foo> underTest, int idleCount) {
// todo  定期檢查對(duì)象某些功能是否可用
return true;
    }
}
  • 構(gòu)建&配置對(duì)象池
    public GenericObjectPool<Foo> fooGenericObjectPool() {
GenericObjectPoolConfig<Foo> poolConfig = new GenericObjectPoolConfig<>();
poolConfig.setEvictionPolicy(new FooEvictionPolicy());
poolConfig.setBlockWhenExhausted(true);
poolConfig.setJmxEnabled(false);
poolConfig.setMaxWaitMillis(1000 * 10);
poolConfig.setTimeBetweenEvictionRunsMillis(60 * 1000);
poolConfig.setMinEvictableIdleTimeMillis(20 * 1000);
poolConfig.setTestWhileIdle(true);
poolConfig.setTestOnReturn(true);
poolConfig.setTestOnBorrow(true);
poolConfig.setMaxTotal(3);
// 設(shè)置拋棄策略
AbandonedConfig abandonedConfig = new AbandonedConfig();
abandonedConfig.setRemoveAbandonedOnMaintenance(true);
abandonedConfig.setRemoveAbandonedOnBorrow(true);
return new GenericObjectPool<>(new FooPoolObjectFactory(), poolConfig, abandonedConfig);
    }

如果我們使用的是spring容器,一般我們需要將該對(duì)象交由spring管理。

  • 獲取&歸還對(duì)象
    private final GenericObjectPool<Foo> fooGenericObjectPool = fooGenericObjectPool();
    public Foo borrowFoo () throws Exception {
return fooGenericObjectPool.borrowObject();
    }
    public void returnObject(Foo foo){
fooGenericObjectPool.returnObject(foo);
    }

到此這篇關(guān)于利用Apache Common將java對(duì)象“池化”的文章就介紹到這了,更多相關(guān)Apache Common java對(duì)象池化內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: Linux Apache
主站蜘蛛池模板: 欧美在线观看网站 | 国产一区二区自拍 | 69久久久| 亚洲国产欧美在线 | 精品国产精品三级精品av网址 | 久草福利在线视频 | 久久国产精品久久久久久 | 国产成人久久精品一区二区三区 | 在线观看亚洲视频 | 日日操天天射 | 久久黄色片 | 国产在线小视频 | 国内自拍偷拍视频 | 国产中文字幕在线观看 | 91麻豆精品国产91久久久久久久久 | 日韩av一区二区在线观看 | 国产精品久久久久久吹潮 | 91在线区 | 午夜视频一区二区 | 久久se精品一区精品二区 | 毛片一级片| 成人在线精品视频 | 一区二区中文字幕在线观看 | 黄色a视频 | 日日日日干干干干 | 午夜影视 | 密室大逃脱第六季大神版在线观看 | 成年人看的羞羞网站 | 国产精品久久国产精品 | 色婷婷久久一区二区三区麻豆 | 亚洲 欧美 日韩在线 | 免费黄色小视频 | 国产免费黄色大片 | 高清国产午夜精品久久久久久 | 男女视频一区二区 | 在线免费中文字幕 | 欧美日韩激情在线一区二区三区 | 亚洲国产一区二区三区, | 91在线成人| 国产精品日韩在线观看 | 国变精品美女久久久久av爽 |