Я использую простое PHP-приложение на основе Docker (https://github.com/fuhrysteve/php-docker-apache-example.git) для демонстрации профилирования Blackfirekfire:
1.Установите расширение Chrome для BlackFire (на Chrome)
2.определить эти переменные среды:
$export BLACKFIRE_CLIENT_ID=921b5dfa-a9e0-4979-8bd1-a7a7a2acf031
$export BLACKFIRE_CLIENT_TOKEN=af050bfc9cf3761082828e3f5e4f31ada89649f0635c0cb445c86f26f72a8e18
$export BLACKFIRE_SERVER_ID=3534d1d9-7c0b-4c5b-9aad-eda497b27494
$export BLACKFIRE_SERVER_TOKEN=79082e6b82122630d6be03bb8f3f8c9544fadada78156ef4606d86f639644eb0
3.Установить агент
docker run --name="blackfire" -d -e BLACKFIRE_SERVER_ID -e BLACKFIRE_SERVER_TOKEN blackfire/blackfire
4.Включение PHP Probe
$cat Dockerfile
FROM php:7.0-apache
RUN version=$(php -r "echo PHP_MAJOR_VERSION.PHP_MINOR_VERSION;") \
&& curl -A "Docker" -o /tmp/blackfire-probe.tar.gz -D - -L -s https://blackfire.io/api/v1/releases/probe/php/linux/amd64/$version \
&& mkdir -p /tmp/blackfire \
&& tar zxpf /tmp/blackfire-probe.tar.gz -C /tmp/blackfire \
&& mv /tmp/blackfire/blackfire-*.so $(php -r "echo ini_get('extension_dir');")/blackfire.so \
&& printf "extension=blackfire.so\nblackfire.agent_socket=tcp://myapp:8707\n" > $PHP_INI_DIR/conf.d/blackfire.ini \
&& rm -rf /tmp/blackfire /tmp/blackfire-probe.tar.gz
RUN apt-get update && \
#apt-get install -y php5-mysql && \
apt-get clean
COPY myapp /var/www/html/
5.Сборка myapp контейнера
$docker build -t php-docker-apache-example
.
6.Docker run
$docker network create myphp
$docker run -d -p 8080:80 --net=myphp-app -v `pwd`:/var/www/html php-blackfire
РЕЗУЛЬТАТ:
Unable to find image 'php-blackfire:latest' locally
docker: Error response from daemon: pull access denied for php-blackfire, repository does not exist or may require 'docker login'.
See 'docker run --help'.
$ docker login
Аутентификация с использованием существующих учетных данных ... Вход выполнен успешно
$ docker run -d -p 8080:80 --net=myphp-app -v \
pwd`: / var / www / html php- blackfire`
Unable to find image 'php-blackfire:latest' locally
docker: Error response from daemon: pull access denied for php-blackfire, repository does not exist or may require 'docker login'.
See 'docker run --help'.
Затем я попытался найти Blackfire локальное изображение :
$docker images | grep black
blackfire/blackfire latest fe5c5468b23d 7 days ago 25.7MB
$ docker run -d -p 8080:80 --net=myphp -v pwd:/var/www/html blackfire/blackfire
26005945907dd55d55d174444dcf53ef176e5b45d0086309496122d0b02e3918
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
7768e1266e81 blackfire/blackfire "blackfire-agent" 38 minutes ago Up 38 minutes 8707/tcp blackfire
7.Запустите приложение php в контейнере
$docker run -d -p 8080:80 php-docker-apache-example
$docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
6dd287bfbb44 php-docker-apache-example "docker-php-entrypoi…" About a minute ago Up About a minute 0.0.0.0:8080->80/tcp determined_snyder
7768e1266e81 blackfire/blackfire "blackfire-agent" 44 minutes ago Up 44 minutes 8707/tcp blackfire
8.Просмотр http://localhost:8080/
Отображение: Привет.Сегодня понедельник, 10-е.
9.Запустите профилировщик в Chrome
Ошибка:
Вы авторизованы для профилирования этой страницы?Зонд не найден, неверная подпись (HTTP 200).Устранение неполадок? В журналах Docker
не отображаются связанные ошибки:
$docker logs 6dd287bfbb44 -f
AH00558: apache2: Could not reliably determine the server's fully qualified domain name, using 172.17.0.3. Set the 'ServerName' directive globally to suppress this message
AH00558: apache2: Could not reliably determine the server's fully qualified domain name, using 172.17.0.3. Set the 'ServerName' directive globally to suppress this message
[Mon Dec 10 22:24:13.490536 2018] [mpm_prefork:notice] [pid 1] AH00163: Apache/2.4.25 (Debian) PHP/7.0.32 configured -- resuming normal operations
[Mon Dec 10 22:24:13.490688 2018] [core:notice] [pid 1] AH00094: Command line: 'apache2 -D FOREGROUND'
172.17.0.1 - - [10/Dec/2018:22:25:50 +0000] "GET / HTTP/1.1" 200 407 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.110 Safari/537.36"