カテゴリー
Linux

Docker php:7.3-fpm で zip モジュールを使えるようにしようとして発生したエラーと解決方法

解決方法まとめ

  • コンテナにインストールするパッケージを zlib1g-dev から libzip-dev へ変更した。
  • イメージのビルド時に PHP の設定として、 docker-php-ext-configure zip --with-libzip を追加した。

エラーメッセージ

ちなみに、 php:7.2-fpm までは問題は発生していませんでした。

$ docker-compose build php_fpm
Building php_fpm

... 略 ...

Configuring for:
PHP Api Version:         20180731
Zend Module Api No:      20180731
Zend Extension Api No:   320180731
checking for grep that handles long lines and -e... /bin/grep
checking for egrep... /bin/grep -E
checking for a sed that does not truncate output... /bin/sed
checking for cc... cc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.out
checking for suffix of executables... 
checking whether we are cross compiling... no
checking for suffix of object files... o
checking whether we are using the GNU C compiler... yes
checking whether cc accepts -g... yes
checking for cc option to accept ISO C89... none needed
checking how to run the C preprocessor... cc -E
checking for icc... no
checking for suncc... no
checking whether cc understands -c and -o together... yes
checking for system library directory... lib
checking if compiler supports -R... no
checking if compiler supports -Wl,-rpath,... yes
checking build system type... x86_64-pc-linux-gnu
checking host system type... x86_64-pc-linux-gnu
checking target system type... x86_64-pc-linux-gnu
checking for PHP prefix... /usr/local
checking for PHP includes... -I/usr/local/include/php -I/usr/local/include/php/main -I/usr/local/include/php/TSRM -I/usr/local/include/php/Zend -I/usr/local/include/php/ext -I/usr/local/include/php/ext/date/lib
checking for PHP extension directory... /usr/local/lib/php/extensions/no-debug-non-zts-20180731
checking for PHP installed headers prefix... /usr/local/include/php
checking if debug is enabled... no
checking if zts is enabled... no
checking for re2c... re2c
checking for re2c version... 0.16 (ok)
checking for gawk... no
checking for nawk... nawk
checking if nawk is broken... no
checking for zip archive read/writesupport... yes, shared
checking for the location of libz... no
checking pcre install prefix... no
checking libzip... yes
checking for the location of zlib... /usr
checking for pkg-config... /usr/bin/pkg-config
checking for libzip... not found
configure: error: Please reinstall the libzip distribution
ERROR: Service 'php_fpm' failed to build: The command '/bin/sh -c apt-get update && apt-get install -y     zlib1g-dev     && docker-php-ext-install     pdo_mysql     zip     && apt-get clean     && rm -rf /var/lib/apt/lists/*' returned a non-zero code: 1
$ 

Dockerfile の差分

php イメージです。タグは、 php:7.3-fpm, php:7.2-fpm, php:7.1-fpm, php:7.0-fpm, php:5.6-fpm で確認しました。

確認内容は、 docker container run --rm docker_lemp_laravel_php_fpm php -v; php -m で、 PHP バージョンと、モジュールとして zip があることを確かめました。

$ git diff
diff --git a/php_fpm/Dockerfile b/php_fpm/Dockerfile
index 6fca638..80aab0d 100644
--- a/php_fpm/Dockerfile
+++ b/php_fpm/Dockerfile
@@ -6,7 +6,7 @@ ENV TZ ${TZ}
 RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
 
 RUN apt-get update && apt-get install -y \
-    zlib1g-dev \
+    libzip-dev \
     && docker-php-ext-install \
     pdo_mysql \
     zip \
bash: __git_ps1: command not found
$ 

おわりに

Docker の php:apache に、Composer を使えるようにする Dockerfile を作る – oki2a24 にて、 Docker コンテナに zlib1g-dev をインストールしました。

今回は、これではダメで、 libzip-dev へ変更したらエラーが収まった、そして、他の PHP バージョンでも問題なさそう、という結果でした。

はじめは、

の内容をやってみて解決したと喜んでいたのですけれども、検証を重ねるうちに、 docker-php-ext-configure zip --with-libzip がなくとも問題ないことがわかりました。

このページにたどり着くまでに参考になったページです。

最後の参考ページを見ると、 PHP に現在のところ libzip がバンドルされていることがわかります。それなのに PHP の zip モジュールを使うためには libzip-dev が必要で、けれども docker-php-ext-configure zip --with-libzip がなくとも問題ない、というのがなんだか不思議な気持ちです。

きっと、 PHP で zip モジュールを使えるようにするためには、 libzip はバンドルされているが、ビルドを完遂するために libzip-dev の ZLIB が必要、、、みたいな状況なのではないかと妄想しておりました。

以上です。

「Docker php:7.3-fpm で zip モジュールを使えるようにしようとして発生したエラーと解決方法」への1件の返信

コメントを残す