[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]坑爹,TimeZone.getTimeZone是同步的方法!!!

上一篇:[备忘]Metadata GC引起的BLOCK,tomcat卡
下一篇:[备忘]nginx大量报upstream timed out (110: Connection timed out)

添加日期:2019-6-18 19:20:51 快速返回   返回列表 阅读110次
系统负载很高,查看线程发现同时出现大量BLOCK进程,

jstack线程后,发现BLOCK在TimeZone.getTimeZone方法上,

莫名其妙,搜索后,说它是synchronized方法。

点进源代码一看,我去,果然是。
----------------------
解决办法就是缓存一下吧,随便写写。
反正时区就那么几个,又不会变化。
升级后问题解决。


/**
     * 缓存时区.
     */
    public static final ConcurrentHashMap<String,TimeZone> timeZoneMap = new ConcurrentHashMap<String,TimeZone>();
    

/**
     * 获取时区.
     * 
     * @param timezone
     *            如UTC+7
     * @return
     */
    public static TimeZone getTimeZone(String timezone) {

        timezone = timezone.replace("UTC", "GMT").replace("utc", "GMT");

        // getTimeZone是同步方法,所以这里缓存一下
        if (timeZoneMap.containsKey(timezone)) {
            return timeZoneMap.get(timezone);
        }

        TimeZone zone = TimeZone.getTimeZone(timezone);
        timeZoneMap.put(timezone, zone);
        return zone;
    }

如getTimeZone("UTC+7")

 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved