yum安装和编译安装,孰优孰劣?

1. 背景

一个php的项目,里面涉及一些图片操作。原本在测试环境运行正常的功能,但是发布到生产环境后,却报错了:“call to undefined function imagecreatefromjpeg”。

2. 原因分析

经过排查,笔者发现两个环境在处理png格式图片时,都能成功。但是如果上传了jpeg或webp格式,生产环境就会报错。
进一步检查两个环境的phpinfo,笔者发现两边虽然都安装了GD库,但测试环境的GD库支持所有图片格式,而生产环境的GD库只支持png和gif。
除了phpinfo()函数,还可以使用php -ri gd 命令查看gd模块的细节信息。

测试环境

GD Support => enabled
GD Version => bundled (2.1.0 compatible)
FreeType Support => enabled
FreeType Linkage => with freetype
FreeType Version => 2.8.0
GIF Read Support => enabled
GIF Create Support => enabled
JPEG Support => enabled
libJPEG Version => 8
PNG Support => enabled
libPNG Version => 1.5.13
WBMP Support => enabled
XBM Support => enabled
WebP Support => enabled

Directive => Local Value => Master Value
gd.jpeg_ignore_warning => 1 => 1

生产环境

GD Support => enabled
GD Version => bundled (2.1.0 compatible)
GIF Read Support => enabled
GIF Create Support => enabled
PNG Support => enabled
libPNG Version => 1.5.13
WBMP Support => enabled
XBM Support => enabled

Directive => Local Value => Master Value
gd.jpeg_ignore_warning => 1 => 1

所以生产环境之所以会报错,是因为:生产环境的GD库,并没有支持jpeg和webp格式的能力。因此,需要针对GD库进行扩展。

那么问题来了,为什么测试环境的GD库支持的全,而生产环境的GD库却支持的少呢?

这是由于当时搭建测试环境和生产环境的人,不是同一人,他们用了截然不同的方式进行搭建。测试环境使用了yum安装,而生产环境使用了源码编译安装。

处理这个问题时,我不禁思考,yum安装和源码编译安装,孰优孰劣?

下面以扩展gd库为例,我会从使用方式、优缺点这两个方面进行探讨这个问题。

3. 区别一:一般步骤

3.1 yum安装

yum安装很简单,只需要输入几个命令就行。

  1. 如果不确定安装的名字,可以先搜索一下: yum search [关键字];
  2. 如果不确定是否已安装,可以使用whereis [关键字] 或 yum info [关键字];
  3. 安装:yum install [软件包名]。

举个栗子1:用yum方式为GD库开启webp支持

  1. 搜索名字:yum search webp
  2. 是否已安装:yum info libwebp-devel
  3. 安装:yum install libwebp-devel

3.2 源码安装

源码安装相对复杂,不过和windows安装应用的步骤相似:

  1. 访问对应的网址,然后找到对应的平台和版本的安装包并下载;
  2. 对源码包解压缩,进入压缩后的目录;
  3. 编译源码,进行安装。

举个栗子2:用源码编译为GD库开启jpeg支持

  1. 下载jpeg包:wget http://www.ijg.org/files/jpegsrc.v9c.tar.gz
  2. 解压缩:tar -zxvf jpegsrc.v9c.tar.gz
  3. 进入目录:cd jpeg-9c/
  4. 编译jpeg包并指定安装目录 ./configure --prefix=/usr/local/phpjpeglib --enable-shared --enable-static
  5. 进入php扩展的gd源码目录(注意不是php源码根目录):cd /root/php-7.4.10/ext/gd
    最好先make clean一下,我就是因为没有clean,虽然编译安装没报错,但依然无法打开支持。
  6. 执行phpize:/usr/local/php/bin/phpize
  7. 重新编译gd,指明php-config和刚刚编译安装的jpeg包和freetype的路径。
    ./configure --with-php-config=/usr/local/php/bin/php-config --with-jpeg=/usr/local/phpjpeglib --with-freetype=/usr/local/freetype
  8. 安装 make && make install
  9. 重启apache或nginx

4. 区别二:优缺点

4.1. yum安装

优点

  1. 简单:基本一个命令搞定。
  2. 自动安装依赖包:比如这次的gd库,使用yum安装的gd库就是因为自动安装了依赖包,所以能支持全部格式的图片处理。
  3. 自动安装服务,可以使用service或systemctl命令启动或关闭服务。

缺点

  1. 版本单一:基本一个源只能安装一个固定的版本,如centos默认yum源只能安装php5.4。

解决方法:更新或使用新的yum源。

  1. 安装成功后,找不到装在哪了。

解决方法:其实大部分软件的安装路径都有规律,如配置文件都在/etc/下面,日志在/var/log下面。
也可以用 whereis 命令查看应用的路径。

4.2. 源码编译安装

优点

  1. 灵活:可以根据需要选择软件的任意版本。
  2. 安装路径自定义:编译时使用prefix参数可以自定义安装路径。

缺点

  1. 复杂:相比yum,编译的步骤很多。

适合动手能力强的,不喜欢使用默认安装目录的运维同学。(毕竟目录不同了,也能增加一定程度的安全性。)

  1. 不会自动安装依赖包:本案例中,必须先安装依赖(jpegsrc, libwebp)再进行gd的二次编译才行。

虽然需要花时间下载安装依赖,但依靠网络搜索也不难。也可以减少安装用不到的软件。

  1. 不会自动安装服务。

/etc/init.d/下面依然可以毕竟方便的启动或关闭软件。

小结

yum安装和编译安装各有千秋,yum安装简单但不灵活,编译安装灵活但比较复杂。
笔者喜欢yum安装,毕竟更新一下yum源也很不难。
那么,你更喜欢哪种方式呢?

2022年7月11日更新:

  • centos7.5下安装php7.2,需要更新的yum源
# 1. 安装epel_release
yum install epel-release

# 2. 安装 remi 源(可以使用php-*安装):
yum install http://rpms.remirepo.net/enterprise/remi-release-7.rpm
# 或者安装webtatic源(可以使用php72w-*安装)
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

# 3. 安装 yum 扩展包:
yum install yum-utils

# 4. 启用 remi 仓库:
yum-config-manager --enable remi-php72
yum update

# 5. 安装 PHP7.2
yum install php

#安装 php-fpm 和一些其他模块
yum install php-fpm php-gd php-json php-mbstring php-mysqlnd php-xml php-xmlrpc php-opcache
yum install php-pecl-zip php-ldap php-odbc php-posix php-shmop php-sysvmsg php-sysvsem php-sysvshm php-xmlrpc

# 6. 输入 php -v 查看安装结果
  • php-fpm 服务
# 1.设置开机自启
$ sudo systemctl enable php-fpm.service

# 2. 常用 php-fpm 命令

# 开启服务
$ sudo systemctl start php-fpm.service

# 停止服务
$ sudo systemctl stop php-fpm.service

# 查看状态
$ sudo systemctl status php-fpm.service

# 3. 配置权限
# 通过 egrep 查询 nginx 服务器的用户和用户组:
$ egrep '^(user|group)' /etc/nginx/nginx.conf

# 结果示例:
user nginx;

# 编辑 /etc/php-fpm.d/www.conf,修改执行 php-fpm 的权限:
$ sudo vi /etc/php-fpm.d/www.conf

# 设置用户和用户组为 nginx:
user = nginx
group = nginx

# 保存并关闭文件,重启 php-fpm 服务:
$ sudo systemctl restart php-fpm.service

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容