10

我们刚刚将服务器从 升级RHEL v7.3v7.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.8.0.141但这似乎与 的版本无关,因为带有( )openjdk的问题是相同的。使用相同版本的on a和server,程序在 RH 7.3 中运行,在 RH 7.4 中失败,方式与使用相同IBM JDKWebSphere v9.0v1.8.0 SR4 FP6IBM JDKRHEL v7.3RHEL v7.4openjdk

知道发生了什么吗?

4

4 回答 4

20

我们终于找到了!
RHEL v7.4(从 v7.3 升级或全新安装)附带 package stix-fonts
安装此包时,默认字体从 更改UtopiaSTIX 所以,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]
似乎该错误已在 JDK 1.8.192 中修复:https ://bugs.java.com/view_bug.do?bug_id=JDK-8188030

[EDITED 2019-06-28]
现在有一个修复程序可以解决 IBM JDK v8.05.37 http://www-01.ibm.com/support/docview.wss?uid=swg1IJ16655中包含的问题

于 2017-08-09T21:01:59.503 回答
7

环境 RHEL 7.4

使用 OpenJDK 或 IBM JDK 升级后,我们无法使用无衬线字体。

在 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 可以解决问题。

百胜安装dejavu-serif-fonts

于 2017-11-02T13:47:51.173 回答
4

如果您只安装任何其他字体,如“dejavu-serif-fonts”,问题将得到解决。或者您使用“local.conf”文件解决问题。RedHat 已将该问题列为 7.4 中的错误,并正在寻找真正的解决方案和依赖项:看看这里:https ://bugzilla.redhat.com/show_bug.cgi?id=1479563

于 2017-09-07T06:11:28.953 回答
0

如果有人在干净的 Linux 服务器实例上运行应用程序时遇到问题,请运行命令 fc-list 并验证它是否有多种字体并来自不同的文件夹,在我的例子中,我在路径 /usr/share/ 中有一些额外的字体X11/fonts/Type1/,我把文件夹里的东西都删了,问题就解决了。

于 2019-06-05T00:52:20.250 回答