MyException - 我的异常网
当前位置:我的异常网» 开源软件 » BigMemory系列稿件-5. Ehcache配置和统计数据

BigMemory系列稿件-5. Ehcache配置和统计数据

www.MyException.Cn  网友分享于:2015-08-24  浏览:0次
BigMemory系列文章--5. Ehcache配置和统计数据
  •  Ehcache默认启动jmx,对Ehcache的使用状态、配置和统计信息进行监控。

一、使用状态:

  1. Name: 缓存名

  2. Status: 状态 (星星)(星星)(星星)

  3. TerracottaClustered: 是否是bigmemory集群模式(bigmemory max)

二、配置信息:

(对应到ehcache.xml中的自定义配置和默认配置)

  1. DiskExpiryThreadIntervalSeconds: 每xx秒检查硬盘的数据是否有过期的

  2. DiskPersistent: 是否做硬盘持久化

  3. DiskSpoolBufferSizedMB: 硬盘缓存区尺寸(单位:MB)

  4. Eternal: 对象是否永久,如果是true的话,TimeToIdleSeconds和TimeToLiveSeconds的配置都会无效。(星星)(星星)(星星)

  5. LoggingEnabled: 是否启动日志

  6. MaxBytesLocalDisk: 硬盘最大存储量(单位是字节)

  7. MaxBytesLocalHeap: 堆内最大存储量(单位是字节)(星星)(星星)(星星)

  8. MaxMemoryOffHeapInBytes: 设置对外内存的最大尺寸(单位是字节)(星星)(星星)(星星)

  9. MaxBytesLocalOffHeap: 堆外最大存储量(单位是字节)(8和9貌似是一样的)(星星)(星星)(星星)

  10. MaxElementsInMemory:   内存最大Elements个数

  11. MaxElementsOnDisk: 硬盘最大Elements个数

  12. MaxEntriesLocalDisk: 硬盘最大Entries个数 (星星)(星星)(星星)

  13. MaxEntriesLocalHeap: 堆内最大Entries个数 (星星)(星星)(星星)

  14. TimeToIdleSeconds: 对象最大空闲时间(超过空闲时间且超过设置的Max,可能参与到对象的删除策略中)(星星)(星星)

  15. TimeToLiveSeconds: 对象的最大存活时间,也就是对象的过期时间。(星星)(星星)

  16. OverflowToDisk: OffHeap如果满了,是否flow到硬盘。(默认是false, 如果为false,所有和硬盘相关的配置都不生效)

  17. OverflowToOffHeap: Heap如果满了,是否flow到OffHeap。

  18. Name: 缓存名

  19. TerracottaClustered: 是否是bigmemory集群模式(bigmemory max)

  20. MemoryStoreEvictionPolicy: 堆内Eviction策略(默认是LRU) (星星)(星星)(星星)

MaxEntries和MaxBytes,一般来说是不共用的。
如果能预估对象个数,但是容量不确定,可以用MaxEntries
如果能预估容量,但是对象个数不确定,可以用MaxBytes
 

三、统计信息:

1. AssociatedCachedName: cache的名称,对应ehcache.xml中的<cache name="mobilServiceOffHeap".../>

2. CacheHitPercentage: 总缓存命中率 (星星)(星星)(星星)

3. CacheHits: 总缓存命中数 (星星)(星星)(星星)

4. CacheMissPercentage: 总缓存丢失率 (星星)(星星)(星星)

5. CacheMisses: 总缓存丢失数 (星星)(星星)(星星)

6. DiskStoreObjectCount: 硬盘中存储的对象个数 (配置中DiskPersistent必须为true)

7. InMemoryHitPercentage: 堆内命中率 (星星)(星星)(星星)

8. InMemoryHits: 堆内命中数 

9. InMemoryMisses: 堆内丢失数

11. MemoryStoreObjectCount: 堆内存储对象个数

11. OffHeapStoreObjectCount: 堆外存储对象个数

12. OffHeapHitPercentage: 堆外命中率 (星星)(星星)(星星)

13. OffHeapHits: 堆外命中数

14. OffHeapMisses: 堆外丢失数 

15. OnDiskHitPercentage: 堆外命中率

16. OnDiskHits: 堆外命中数

17. OnDiskMisses: 堆外丢失数

18. ObjectCount: 总对象个数 (星星)(星星)(星星)

如果当前cache是offheapCache,那么总对象数 = OffHeapStoreObjectCount + DiskStoreObjectCount (可能InMemory是Offheap的热点数据,认为是一个对象)

如果当前cache是heapCache,那么总对象数 = InMemoryStoreObjectCount + DiskStoreObjectCount

19. WriterMaxQueueSize: the maximum size of the write-behind queue (应该是写硬盘的线程,用到的队列)

20. WriteQueueLength:  the size of the write-behind queue(应该是写硬盘的线程,用到的队列)

 

四、自定义统计信息

1. 除了默认的统计信息,可以调用ehcache api获取更加全面的统计信息,实现自己来定制统计。

package com.sohu.tv.mobil.common.jmx;
import java.util.List;

public interface EhcacheExtendWatcherMBean {
    /**
     * 获取延迟结果
     * 
     * @return
     */
    List<String> getGlobalResult();
    /**
     * 获取剔除数量
     * 
     * @return
     */
    long getEvictedCount();
    /**
     * 获取超时数量
     * 
     * @return
     */
    long getExpiredCount();
    /**
     * 获取未命中统计
     * 
     * @return
     */
    List<String> getMissStatisticsMap();
}

 

package com.sohu.tv.mobil.common.jmx.impl;
import com.sohu.tv.mobil.common.jmx.EhcacheExtendWatcherMBean;
import net.sf.ehcache.Ehcache;
import net.sf.ehcache.statistics.StatisticsGateway;
import net.sf.ehcache.statistics.extended.ExtendedStatistics;
import java.util.ArrayList;
import java.util.List;

public class EhcacheExtendWatcher implements EhcacheExtendWatcherMBean {
    private Ehcache ehcache;
    @Override
    public List<String> getGlobalResult() {
        ExtendedStatistics extendedStatistics = ehcache.getStatistics().getExtended();
        ExtendedStatistics.Result getResult = extendedStatistics.allGet();
        ExtendedStatistics.Result putResult = extendedStatistics.allPut();
        ExtendedStatistics.Result missResult = extendedStatistics.allMiss();
        List<String> resultList = new ArrayList<String>();
        String getStr =
                "allGet:count=" + getResult.count().value() + ";rate=" + getResult.rate().value()
                        + ";latency:average=" + getResult.latency().average().value() + ";minimum="
                        + getResult.latency().minimum().value() + ";maximum=" + getResult.latency()
                                .maximum().value();
        String putStr =
                "allPut:count=" + putResult.count().value() + ";rate=" + putResult.rate().value()
                        + ";latency:average=" + putResult.latency().average().value() + ";minimum="
                        + putResult.latency().minimum().value() + ";maximum=" + putResult.latency()
                                .maximum().value();
        String missStr =
                "allMiss:count=" + missResult.count().value() + ";rate=" + missResult.rate().value()
                        + ";latency:average=" + missResult.latency().average().value() + ";minimum="
                        + missResult.latency().minimum().value() + ";maximum=" + missResult.latency()
                                .maximum().value();
        resultList.add(getStr);
        resultList.add(putStr);
        resultList.add(missStr);
        return resultList;
    }
    @Override
    public long getEvictedCount() {
        StatisticsGateway statisticsGateway = ehcache.getStatistics();
        return statisticsGateway.cacheEvictedCount();
    }
    @Override
    public long getExpiredCount() {
        StatisticsGateway statisticsGateway = ehcache.getStatistics();
        return statisticsGateway.cacheExpiredCount();
    }
    @Override
    public List<String> getMissStatisticsMap() {
        StatisticsGateway statisticsGateway = ehcache.getStatistics();
        ExtendedStatistics.Result missResult = statisticsGateway.cacheMissOperation();
        ExtendedStatistics.Result missExpiredResult = statisticsGateway.cacheMissExpiredOperation();
        ExtendedStatistics.Result missMissNotFoundResult =
                statisticsGateway.cacheMissNotFoundOperation();
        String missResultStr =
                "missResult:count=" + missResult.count().value() + ";rate=" + missResult.rate().value()
                        + ";latency:average=" + missResult.latency().average().value() + ";minimum="
                        + missResult.latency().minimum().value() + ";maximum=" + missResult.latency()
                                .maximum().value();
        String missExpiredResultStr =
                "missExpiredResult:count=" + missExpiredResult.count().value() + ";rate="
                        + missExpiredResult.rate().value() + ";latency:average=" + missExpiredResult
                                .latency().average().value() + ";minimum=" + missExpiredResult.latency().minimum()
                                .value() + ";maximum=" + missExpiredResult.latency().maximum().value();
        String missMissNotFoundResultStr =
                "missMissNotFoundResult:count=" + missMissNotFoundResult.count().value() + ";rate="
                        + missMissNotFoundResult.rate().value() + ";latency:average="
                        + missMissNotFoundResult.latency().average().value() + ";minimum="
                        + missMissNotFoundResult.latency().minimum().value() + ";maximum="
                        + missMissNotFoundResult.latency().maximum().value();
        List<String> resultList = new ArrayList<String>();
        resultList.add(missResultStr);
        resultList.add(missExpiredResultStr);
        resultList.add(missMissNotFoundResultStr);
        return resultList;
    }
    public void setEhcache(Ehcache ehcache) {
        this.ehcache = ehcache;
    }
}

 

2. 实现效果:

3. 重要统计说明:

EvictedCount: 剔除个数(内存满之后) (星星)(星星)(星星)(星星)(星星)

ExpiredCount: 过期个数 (如果设置了单个KEY的过期时间或者全局的TimeToLive就会出现) (星星)(星星)(星星)(星星)

GlobalResult: 包含各个命令的调用次数,各种响应时间,QPS(rate) (星星)(星星)(星星)(星星)

文章评论

程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
2013年美国开发者薪资调查报告
2013年美国开发者薪资调查报告
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
老程序员的下场
老程序员的下场
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
代码女神横空出世
代码女神横空出世
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
鲜为人知的编程真相
鲜为人知的编程真相
Google伦敦新总部 犹如星级庄园
Google伦敦新总部 犹如星级庄园
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
 程序员的样子
程序员的样子
我的丈夫是个程序员
我的丈夫是个程序员
Java程序员必看电影
Java程序员必看电影
程序员都该阅读的书
程序员都该阅读的书
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
那些争议最大的编程观点
那些争议最大的编程观点
程序员应该关注的一些事儿
程序员应该关注的一些事儿
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
编程语言是女人
编程语言是女人
为什么程序员都是夜猫子
为什么程序员都是夜猫子
漫画:程序员的工作
漫画:程序员的工作
一个程序员的时间管理
一个程序员的时间管理
旅行,写作,编程
旅行,写作,编程
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
每天工作4小时的程序员
每天工作4小时的程序员
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
如何成为一名黑客
如何成为一名黑客
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
程序员的鄙视链
程序员的鄙视链
中美印日四国程序员比较
中美印日四国程序员比较
10个调试和排错的小建议
10个调试和排错的小建议
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有