大佬:小伙子我看你我看你骨骼精奇,跟我学搭建本地字体库吧。
我 :什么样的啊
大佬:超简单的那种啊
我 :我信你个鬼,你个糟老头子坏得很
1.为什么使用.pbf
protocol buffer是google的一个开源项目,它是用于结构化数据串行化的灵活、高效、自动的方法。类似于XML,但是它更快,更小,更简单。
相较于我们之前使用的字体库,例如宋体的ttf文件大小为17.3M,每次请求都要加载17.3M的数据并且还要去解析。对于客户端以及服务端的压力都非常大。而PBF进行了分批请求,大大减小了请求压力。
2.常规字体库转换为PBF
转换的方法非常"简单",用到的是genfontgl工具。下面介绍详细的部署流程:
首先准备64位的linux系统,因为genfontgl的后台是使用的fontnik这个库,而fontnik暂时没有支持windows的计划(https://github.com/mapbox/node-fontnik/issues/137)至于为什么不用OS X
安装Node 6.X
#使用wget命令下载Node或者直接从官网下载linux的包后使用winscp等工具上传至linux
wget https://nodejs.org/dist/v6.9.0/node-v6.9.0-linux-x64.tar.xz
#使用tar命令解压
tar xvf node-v6.9.0-linux-x64.tar.xz
#将npm以及node建立为全局命令
ln -s /root/node-v6.9.0-linux-x64/bin/node /usr/local/bin/node
ln -s /root/node-v6.9.0-linux-x64/bin/npm /usr/local/bin/npm
#将/root/node-v6.9.0-linux-x64/bin配置到用户环境变量中
cd ~
vi .bash_profile
#在PATH中追加/root/node-v6.9.0-linux-x64/bin
#立即执行修改
source .bash_profile
测试安装Node成功
#使用node -v 命令,看到输出V6.9.0
#使用npm -v 命令,看到输出3.10.8
检查linux的当前gcc版本
使用:strings /usr/lib64/libstdc++.so.6 | grep GLIBC 命令
可以看到在系统中没有GLIBCXX_3.4.20,所以我们升级gcc来解决该问题
安装所需工具
yum groupinstall "Development Tools"
yum install glibc-static libstdc++-static
升级gcc
#使用wget或者直接下载压缩包并上传至linux并解压
wget http://ftp.tsukuba.wide.ad.jp/software/gcc/releases/gcc-5.4.0/gcc-5.4.0.tar.gz
tar -xvf gcc-5.4.0.tar.bz2
#下载gcc以来的文件以及库
cd gcc-5.4.0
./contrib/download_prerequisits
#创建一个输出目录并执行configure配置安装
mkdir build
cd build
../configure --enable-checking=release --enable-languages=c,c++ --disable-multilib
make && make install
#安装完成后重启一下机器
#使用命令查找安装的最新库
find / -name "libstdc++.so*"
#将上面的最新动态库libstdc++.so.6.0.21复制到/usr/lib64目录下
cp /usr/local/lib64/libstdc++.so.6.0.21 /lib64
#删除之前的软连接并指向最新的动态库
cd /lib64
rm -rf libstdc++.so.6
ln -s libstdc++.so.6.0.21 libstdc++.so.6
再次执行strings /lib64/libstdc++.so.6 | grep GLIBC即可看到安装好的GLIBCXX_3.4.20以及GLIBCXX_3.4.21
安装genfontgl
npm install -g genfontgl
使用winscp等工具上传任意ttf格式字体至linux机器,使用genfontgl 进行转换测试:成功了!!!!我**********!!!!
作为一个90后,既然早早地抱起了保温杯,泡上了枸杞水,那就认真地过好每一天吧。