4

我有这个问题正在降低生产。在 AWS/Ubuntu/Tomcat 堆栈中,CPU 运行的 Tomcat 正在跳跃到 100%,当我得到一个线程转储时,这段代码总是在完全相同的地方阻塞。(所有其他人都被锁定并等待。)

"TP-Processor6" daemon prio=10 tid=0x0000000041ec2800 nid=0x41c4 runnable [0x00007f70194b5000]
  java.lang.Thread.State: RUNNABLE
    at sun.util.calendar.ZoneInfo.getTransitionIndex(ZoneInfo.java:322)
    at sun.util.calendar.ZoneInfo.getOffsets(ZoneInfo.java:248)
    at sun.util.calendar.ZoneInfo.getOffsets(ZoneInfo.java:225)
    at java.util.GregorianCalendar.computeFields(GregorianCalendar.java:2024)
    at java.util.GregorianCalendar.computeFields(GregorianCalendar.java:1996)
    at java.util.Calendar.setTimeInMillis(Calendar.java:1109)
    at java.util.GregorianCalendar.<init>(GregorianCalendar.java:576)
    at java.util.Calendar.createCalendar(Calendar.java:1011)
    at java.util.Calendar.getInstance(Calendar.java:948)
    at com.xxx.core.util.DateUtil.modifyDate(DateUtil.java:385)
    at com.xxx.core.util.DateUtil.getDayDate(DateUtil.java:563)
    at com.xxx.core.util.DateUtil.getDayDate(DateUtil.java:573)
    at com.xxx.core.util.DateUtil.getDayDate(DateUtil.java:569)
    at com.xxx.core.util.DateUtil.splitByDays(DateUtil.java:496)
    at com.xxx.core.util.DateUtil.splitDateIntervalByIntervals(DateUtil.java:474)
    at com.xxx.core.util.DateUtil.splitDateIntervalByIntervals(DateUtil.java:436)
4

1 回答 1

1

围绕事物进行一些更好的日志记录,以弄清楚这里发生了什么。

确保您的实例指定了正确的编码和区域设置——系统、tomcat 容器、应用程序。以格林威治标准时间为标准并尝试:

Calendar.getInstance ("GMT-0", Locale.US); // verify inputs

如果您正在获取日历的实例,为什么要明确地重新设置日期?为什么不直接创建一个新日历?然后,您将实例化一个新日历:

Calendar cal = new Calendar (TimeZone zone, Locale aLocale); // new 
cal.setTimeZone("GMT-0"); 
cal.setTimeInMillis(System.currentTimeMillis ()); 

Calendar 和 Date 对象在 Java 中相对具有可塑性,因此您可以更改它们的功能。我猜想环境变量或容器中可能有一些设置不正确,例如本地或编码与日历实例尝试的内容冲突。尝试明确指定所有内容。

这是我最好的直觉。

于 2012-09-01T10:32:50.473 回答