将RHEL从7.3升级到7.4:sun.font.CompositeStrike.getStrikeForSlot

时间:2017-08-08 13:13:26

标签: java awt redhat openjdk ibm-jdk

我们刚刚将服务器从RHEL v7.3升级到v7.4

这个简单的程序适用于RHEL v7.3,在v7.4中失败

public class TestJava {
  public static void main(String[] args) {
    Font font = new Font("SansSerif", Font.PLAIN, 12);
    FontRenderContext frc = new FontRenderContext(null, false, false);
    TextLayout layout = new TextLayout("\ude00", font, frc);
    layout.getCaretShapes(0);
    System.out.println(layout);
  }
}

RHEL 7.4中的例外是:

Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0
    at sun.font.CompositeStrike.getStrikeForSlot(CompositeStrike.java:75)
    at sun.font.CompositeStrike.getFontMetrics(CompositeStrike.java:93)
    at sun.font.Font2D.getFontMetrics(Font2D.java:415)
    at java.awt.Font.defaultLineMetrics(Font.java:2176)
    at java.awt.Font.getLineMetrics(Font.java:2283)
    at java.awt.font.TextLayout.fastInit(TextLayout.java:598)
    at java.awt.font.TextLayout.<init>(TextLayout.java:393)

RHEL v7.3的结果是:

sun.font.StandardTextSource@7ba4f24f[start:0, len:1, cstart:0, clen:1, chars:"de00", level:0, flags:0, font:java.awt.Font[family=SansSerif,name=SansSerif,style=plain,size=12], frc:java.awt.font.FontRenderContext@c14b833b, cm:sun.font.CoreMetrics@412ae196]

RHEL v7.4的更新包括从openjdk1.8.0.131的{​​{1}}更新,但这似乎与1.8.0.141的版本无关,问题与openjdk IBM JDKWebSphere v9.0)的问题相同。在v1.8.0 SR4 FP6IBM JDK服务器上使用相同版本的RHEL v7.3,该程序在RH 7.3中工作,在RH 7.4中失败的方式与RHEL v7.4

知道发生了什么事吗?

4 个答案:

答案 0 :(得分:17)

我们终于找到了它! RHEL v7.4(从v7.3升级或全新安装)附带包stix-fonts 安装此软件包后,默认字体从Utopia更改为STIX 因此,java现在默认字体映射到STIX,包括sans-serif字体系列
无论出于何种原因,STIX字体似乎不能很好地与java(openjdk + IBM JDK)一起使用,并且在使用java.awt时导致异常和错误的计算人工制品定位,这是JasperReports的情况 我们用这个来结束创建一个文件名/etc/fonts/local.conf,以强制将Utopia作为java使用的默认字体。

<?xml version='1.0'?>
<!DOCTYPE fontconfig SYSTEM 'fonts.dtd'>
<fontconfig>
  <alias>
    <family>serif</family>
    <prefer><family>Utopia</family></prefer>
  </alias>
  <alias>
    <family>sans-serif</family>
    <prefer><family>Utopia</family></prefer>
  </alias>
  <alias>
    <family>monospace</family>
    <prefer><family>Utopia</family></prefer>
  </alias>
  <alias>
    <family>dialog</family>
    <prefer><family>Utopia</family></prefer>
  </alias>
  <alias>
    <family>dialoginput</family>
    <prefer><family>Utopia</family></prefer>
  </alias>
</fontconfig>

[编辑2018-10-22]
看来这个bug在JDK 1.8.192中得到修复:https://bugs.java.com/view_bug.do?bug_id=JDK-8188030

答案 1 :(得分:6)

环境RHEL 7.4

使用OpenJDK或IBM JDK升级后,我们无法使用font sans serif。

在openjdk 1.8.0.141-2中使用字体库的新例外。 解析度 该问题已在java-1.8.0-openjdk-1.8.0.151-1.b12.el7_4.x86_64中修复。 RHSA-2017:2998-安全咨询 解决方法

据观察,在某些情况下安装dejavu-serif-fonts可以解决问题。

yum install dejavu-serif-fonts

答案 2 :(得分:4)

如果您只安装任何其他字体,例如&#34; dejavu-serif-fonts&#34;问题将得到解决。或者你使用&#34; local.conf&#34;进行解决。文件。 RedHat已经将问题视为7.4中的一个错误,并且正在寻找真正的解决方案和依赖关系:看看这里:https://bugzilla.redhat.com/show_bug.cgi?id=1479563

答案 3 :(得分:0)

如果有人在干净的Linux服务器实例上运行应用程序时遇到问题,请运行命令fc-list并验证它是否具有多个字体并且来自不同的文件夹,在我的情况下,我在/ usr路径中有一些额外的字体/ share / X11 / fonts / Type1 /,我删除了文件夹中的所有内容,问题已解决。