Php: event extentsion installed with error?

Created on 9 Jul 2019  路  2Comments  路  Source: docker-library/php

error info:

 PHP Startup: Unable to load dynamic library '/usr/local/lib/php/extensions/no-debug-non-zts-20160303/event.so' - Error relocating /usr/local/lib/php/extensions/no-debug-non-zts-20160303/event.so: php_sockets_le_socket: symbol not found in Unknown on line 0

it seems sockets extension was not found, but I have installed it via docker-php-ext-install pdo_mysql opcache sockets

this is my Dockerfile

FROM php:7.1.30-cli-alpine3.9

# Packages
RUN apk --update add \
    autoconf \
    build-base \
    linux-headers \
    libevent-dev \
    openldap-dev \
    imagemagick-dev && \
    docker-php-ext-install pdo_mysql opcache sockets && \
    docker-php-ext-enable sockets && \
    pecl install event-2.5.3 && \
    docker-php-ext-enable event && \
    docker-php-ext-enable opcache \
    && rm -rf /var/cache/apk/*




ENV COMPOSER_ALLOW_SUPERUSER 1
ENV COMPOSER_HOME /tmp
ENV COMPOSER_VERSION 1.5.1


RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/bin --filename=composer \
 && composer --ansi --version --no-interaction

VOLUME /var/www
WORKDIR /var/www

CMD [ "php", "./public/server.php" ]

The problem has puzzled me for a long time

Most helpful comment

So that esoteric error is because event was being loaded before sockets from the .ini's in /usr/local/etc/php/conf.d

Going into your image, the ordering of these files determines which are loaded first

/usr/local/etc/php/conf.d # ls -al
total 28
drwxr-xr-x    2 root     root          4096 Jul  9 20:39 .
drwxr-xr-x    7 root     root          4096 Jul  9 20:01 ..
-rw-r--r--    1 root     root            19 Jul  9 18:39 docker-php-ext-event.ini
-rw-r--r--    1 root     root            82 Jul  9 18:39 docker-php-ext-opcache.ini
-rw-r--r--    1 root     root            23 Jul  9 18:38 docker-php-ext-pdo_mysql.ini
-rw-r--r--    1 root     root            21 Jul  9 18:38 docker-php-ext-sockets.ini
-rw-r--r--    1 root     root            20 Jun 28 02:48 docker-php-ext-sodium.ini

docker-php-ext-enable allows for a flag to change the .ini name, so doing a docker-php-ext-enable --ini-name zz-event.ini event has it load in last

FROM php:7.1.30-cli-alpine3.9

# Packages
RUN apk add --no-cache \
    autoconf \
    build-base \
    linux-headers \
    libevent-dev \
    openldap-dev \
    imagemagick-dev

RUN docker-php-ext-install sockets pdo_mysql opcache

RUN docker-php-ext-enable opcache && \
    pecl install event-2.5.3 && \
    docker-php-ext-enable --ini-name zz-event.ini event


ENV COMPOSER_ALLOW_SUPERUSER 1
ENV COMPOSER_HOME /tmp
ENV COMPOSER_VERSION 1.5.1


RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/bin --filename=composer \
 && composer --ansi --version --no-interaction

VOLUME /var/www
WORKDIR /var/www

CMD [ "php", "./public/server.php" ]

I'd searched pretty extensively for that error php_sockets_le_socket: symbol not found in Unknown on line 0 and this blog had mentioned

Warnings like this are typically due to certain module load order dependencies

All 2 comments

So that esoteric error is because event was being loaded before sockets from the .ini's in /usr/local/etc/php/conf.d

Going into your image, the ordering of these files determines which are loaded first

/usr/local/etc/php/conf.d # ls -al
total 28
drwxr-xr-x    2 root     root          4096 Jul  9 20:39 .
drwxr-xr-x    7 root     root          4096 Jul  9 20:01 ..
-rw-r--r--    1 root     root            19 Jul  9 18:39 docker-php-ext-event.ini
-rw-r--r--    1 root     root            82 Jul  9 18:39 docker-php-ext-opcache.ini
-rw-r--r--    1 root     root            23 Jul  9 18:38 docker-php-ext-pdo_mysql.ini
-rw-r--r--    1 root     root            21 Jul  9 18:38 docker-php-ext-sockets.ini
-rw-r--r--    1 root     root            20 Jun 28 02:48 docker-php-ext-sodium.ini

docker-php-ext-enable allows for a flag to change the .ini name, so doing a docker-php-ext-enable --ini-name zz-event.ini event has it load in last

FROM php:7.1.30-cli-alpine3.9

# Packages
RUN apk add --no-cache \
    autoconf \
    build-base \
    linux-headers \
    libevent-dev \
    openldap-dev \
    imagemagick-dev

RUN docker-php-ext-install sockets pdo_mysql opcache

RUN docker-php-ext-enable opcache && \
    pecl install event-2.5.3 && \
    docker-php-ext-enable --ini-name zz-event.ini event


ENV COMPOSER_ALLOW_SUPERUSER 1
ENV COMPOSER_HOME /tmp
ENV COMPOSER_VERSION 1.5.1


RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/bin --filename=composer \
 && composer --ansi --version --no-interaction

VOLUME /var/www
WORKDIR /var/www

CMD [ "php", "./public/server.php" ]

I'd searched pretty extensively for that error php_sockets_le_socket: symbol not found in Unknown on line 0 and this blog had mentioned

Warnings like this are typically due to certain module load order dependencies

@wglambert thks, you saved my day.

Was this page helpful?
0 / 5 - 0 ratings