背景
某 Web 应用部署到欧拉操作系统后,应用中导出的 PDF 文件中文全部显示乱码,原因是字体缺失,但是目标系统上并没有联网,必须找到字体的离线安装包。
CSDN 上还有40个积分,下载了两个相关的资源后,目标系统上安装的时候,报错了 Fontconfig warning: "/etc/fonts/fonts.conf", line 86: unknown element “blank"
,安装出错了,积分也没了,咋搞哦?
本文记录这个问题的解决过程,顺便吐槽一下高的离谱的下载积分。
依赖包
下载积分还有点,下载了一个可用的包,主要有 6 个文件:
- fontconfig-2.10.95-11.amzn2.0.2.x86_64.rpm
- fontpackages-filesystem-1.44-8.amzn2.noarch.rpm
- libXfont-1.5.4-1.el7.x86_64.rpm
- libfontenc-1.1.3-3.amzn2.0.2.x86_64.rpm
- stix-fonts-1.1.0-5.amzn2.noarch.rpm
- xorg-x11-font-utils-7.5-20.amzn2.0.2.x86_64.rpm
找一个没有字体的 CentOS 系统测试没问题,但是到目标欧拉系统执行安装命令后,执行 fc-list :lang=zh
,报错 Fontconfig warning: "/etc/fonts/fonts.conf", line 86: unknown element “blank"
。
这个错误怎么产生的呢?正常系统中这个 etc/fonts/fonts.conf
到 86 行确实就是 blank
元素的。搜到一篇文章,感觉有点用,就截了一下屏幕:
分析第一个命令是更新包,后面重新安装这几个包,Xvfb 这个跟字体没关系,感觉要解决这个问题,思路应该是找最新的包,重新安装。
下载最新包
网上找最新的字体包估计是不好找了,还是从在线安装入手,测试机器都是可以联网的,重新执行这 6 个包的安装命令,并用 downloadonly
工具下载到某目录下。
downloadonly
这个命令在已经安装的情况下不会有任何动作的,所以要下载 6 个包的最新版本,需要逐个执行下面的步骤:
- yum install yum-plugin-downloadonly
- yum list |grep xxx 逐个删除这些依赖包
- yum install --downloadonly --downloaddir=/root/rpm libXfont
- yum install --downloadonly --downloaddir=/root/rpm mkfontscale
- yum install --downloadonly --downloaddir=/root/rpm fontconfig
- yum install --downloadonly --downloaddir=/root/rpm libfontenc
- yum install --downloadonly --downloaddir=/root/rpm stix-fonts.noarch
- yum install --downloadonly --downloaddir=/root/rpm fontpackages-filesystem
得到最新的字体安装包,然后准备好一个包含字体文件的文件夹 fonts,放到当前目录下。编写安装脚本:
#!/sh
basePath=$(cd `dirname $0`; pwd)
cd $basePath
mv fonts /usr/share
echo "start install font basePath $basePath"
rpm -ivh ./*.rpm --nodeps --force
cd /usr/share/fonts
mkfontscale
fc-list :lang=zh
重新安装
进入目标目录下,执行 sh install.sh
完成字体的安装操作,最新版本在欧拉系统下也能正确安装。CSDN 的下载积分高的越来越离谱了!