Verification: a143cc29221c9be0

Php 7 xdebug как настроить

Php 7 xdebug как настроить

Возможности Xdebug

Xdebug — это расширение для PHP, которое позволяет использовать удаленный отладчик в IDE через брейк-пойнты. С его помощью вы можете отслеживать значения переменных. Как итог — ошибки в коде обнаруживаются быстрее, чем при использовании error_log, print_r и var_dump. 

Еще одна полезная функция — трассировка стека. Она выводит подробный путь, который привел приложение к ошибке. Он содержит параметры, переданные в функцию. Xdebug также можно использовать как профайлер для поиска узких мест кода. Если добавить внешние инструменты, то получится визуализировать графики производительности. Например, можно использовать WebGrind — набор PHP-скриптов для удобного вывода статистики прямо в браузере.

Кроме того, с помощью Xdebug вы можете проследить, какая часть кода выполняется в процессе запроса. Это дает информацию о том, как хорошо код покрыт тестами.

Подключение Xdebug

Для работы Xdebug PHP должен быть в режиме CGI. Посмотрим на примере хостинга Timeweb, как его включить.

Подключаемся к серверу через SSH. Можно использовать консоль в панели управления Timeweb.

Переходим в папку cd-bin сайта:

// Вместо wordpress — директория вашего сайта

cd wordpress/public_html/cgi-bin/

Создаем символическую ссылку командой:

// Укажите нужную вам версию обработчика вместо php5.3

ln -s /opt/php5.3/bin/php-cgi php5.3.cgi

Остаемся в директории cgi-bin и копируем файл php.ini:

cp /etc/php53/cgi/php.ini ./

Добавляем в файл .htaccess сайта две строки:

Action php5.3-script /cgi-bin/php5.3.cgi

AddType php5.3-script .php

Теперь мы можем управлять параметрами PHP директивами в файле php.ini. Он находится в папке cgi-bin. Открываем его и вставляем в конце следующие строки:

zend_extension = xdebug.so

xdebug.remote_enable=1

xdebug.remote_host=127.0.0.1

xdebug.remote_port=3083

xdebug.idekey=VSCODE

xdebug.remote_autostart=1

Если указанный порт занят, укажите другой. Можно использовать стандартный для Xdebug — 9000. В качестве idekey я указал VSCODE. Если будете настраивать конфигурацию для PHPStorm, впишите его.

Настройка PHP для Xdebug

Чтобы проверить, работает ли Xdebug, создадим в корне сайта файл Myfile.php со следующим содержимым:

Открываем файл в браузере и проверяем, что все параметры указаны верно.

Организация удаленного подключения

Чтобы выполнять PHP Debug на локальной машине, нужно настроить связь IDE и сервера через SSH-туннель.

На Linux все выполняется парой команд.

// Генерируем пару ключей и сохраняем их в папке .ssh на локальной машине

ssh-keygen -t rsa

Приватный ключ сохраняется на локальной машине, а публичный добавляется на сервер. Подробнее об этом, а также о настройке SSH на Windows, вы можете узнать из этой статьи.

На Linux туннель создается командой:

ssh -R 3083:localhost:3083 адрес_сервера -p1024

На Windows туннель настраивается через утилиту PuTTY.

  1. На вкладке Session указываем имя сервера и номер порта 1024. Проверяем, чтобы был отмечен протокол SSH.Создание новой сессии PuTTy
  2. Переходим в раздел Connection — Data. Указываем логин.Добавление логина
  3. Переходим в раздел Connection — SSH — Tunnels. Указываем параметры так, как указано на скриншоте. Номер порта пишем тот, который используется в конфигурации PHP на сервере.Добавление нового туннеля
  4. Возвращаемся в раздел Session и нажимаем на кнопку Open. Подтверждаем корректность ключей (только первый раз). 

Сессия сохранится под тем именем, которое мы указали в разделе Session. В дальнейшем нужно будет просто запускать ее заново.

Настройка VSCode

Чтобы работать с Xdebug в VSCode, установим два расширения: Sync-Rsync и PHP Debug. Первое нужно для работы с удаленным сервером, второе — для отладки скриптов.

  1. Открываем в VSCode раздел Extensions (можно использовать сочетание клавиш Ctrl+Shift+X).
  2. Находим и устанавливаем расширение Sync-Rsync.
  3. Находим и устанавливаем расширение PHP Debug.

После установки расширений создаем на локальной машине пустую папку и открываем ее через VSCode: «Файл» — «Открыть папку».

Добавляем подпапку .vscode, создаем внутри нее файл settings.json и прописываем в нем настройки для Sync-Rsync.

{

  "folders": [

    {

      "path": "/home/локальная папка"

    }

  ],

  "sync-rsync.onSaveIndividual": true,

  "sync-rsync.executableShell": "/bin/bash",

  "sync-rsync.shell": "ssh -p 1024 -i /home/user/.ssh/id_rsa",

  "sync-rsync.delete": true,

  "sync-rsync.sites": [

    {

      "localPath": "/home/локальная папка",

      "remotePath": "xxxxx@mysqlxx.tImeweb.ru:/home/xxxxx/domain.ru/htdocs/www/"

    }

  ]

}

Путь /home/user/.ssh/id_rsa — это место, где лежит файл с закрытой частью SSH-ключа.

После сохранения файла settings.json нажимаем в VSCode F1, выполняем команду Sync Remote to Local. В локальную папку, указанную в настройках, скопируются все файлы с сервера.

Синхронизация с сервером

Затем нажимаем на иконку отладки и на шестеренку. В папке .vscode появится файл launch.json. В него тоже нужно внести изменения:

{

  "version": "0.2.0",

  "configurations": [

    {

      "name": "Listen for XDebug",

      "type": "php",

      "request": "launch",

      "port": 3083,

      "pathMappings": {

        "/home/xxxxx/domain.ru/htdocs/www": "${workspaceRoot}/"

      }

    },

    {

      "name": "Launch currently open script",

      "type": "php",

      "request": "launch",

      "program": "${file}",

      "cwd": "${fileDirname}",

      "port": 3083

    }

  ]

}

На этом настройка IDE завершена. Можно приступать к тестированию кода.

Debug кода

Мы настроили среду, теперь разберемся, как пользоваться Xdebug.

  1. Изменим содержимое файла Myfile.php, который мы создали при подключении отладчика. Добавим в него функцию, которую хотим проверить. 
  2. Чтобы загрузить измененный файл на сервер, нажимаем на клавишу F1 и выполняем команду Sync-Rsync: Sync Local to Remote.
  3. Открываем файл в браузере и проверяем, что синхронизация работает.  
  4. Расставляем в VSCode брейк-пойнты, которые нужны для отладки. 

Переходим в режим «Отладка» и проверяем, что выделен пункт Listen for XDebug. Нажимаем на зеленый треугольник или на клавишу F5.

После перезагрузки сайта в браузере возвращаемся в VSCode. В отладчике должны отобразиться глобальные переменные и их значения на момент обработки кода в брейк-пойнте. Вы можете перемещаться по коду, отслеживая изменение переменных на каждом шаге.

Отладчик Xdebug

Профилирование с визуализацией результатов

Чтобы использовать Xdebug profiler на полную мощность, установим WebGrind. Это набор скриптов, который выводит статистику в браузере. С его помощью можно посмотреть список вызванных функций, количество вызовов, общее затраченное время на вызов и выполнение.

  1. Скачиваем WebGrind с GitHub.
  2. Загружаем архив на сервер и распаковываем файлы в корне сайта.
  3. Создаем папку, в которой будут храниться логи.
  4. Добавляем в файл php.ini две директивы:
xdebug.profiler_output_dir - /home/xxxxx/domain/папка с логами

xdebug.profiler_output_name - cachegrind.out.%p

Затем нужно открыть файл config.php, который находится в распакованной папке webgrind-master. В нем отредактируем две строки:

static $storageDir = '/home/xxxxx/domain/папка с логами/';

static $profilerDir = '/home/xxxxx/domain/папка с логами';

После такой настройки можно выполнять на Xdebug профилирование. Открываем наш тестовый скрипт в браузере. Затем переходим по ссылке www.domain/webgrind-master. В выпадающем списке выбираем только что запущенный скрипт и нажимаем на кнопку Update.

Функции можно скрывать или раскрывать, чтобы посмотреть развернутую статистику. Инструмент также умеет отображать графы вызова функций — для этого используется режим Show Call Graph.

Source

Xdebug is hosted in GIT. The source code can be browsed through github and can be checked out with:

git clone https://github.com/xdebug/xdebug.git

Latest Release

Xdebug 3.0.4

Release date: 2021-04-08

Command Line Debug Client

Please refer to the documentation to learn about how to use the debug client.

DBGp Proxy

Please refer to the documentation to learn about how to use the DBGp proxy tool.

Компиляция и настройка расширения PHP Xdebug

Для успешного использования расширения Xdebug сайт должен работать в режиме CGI.

Ниже будет рассмотрена компиляция Xdebug для PHP 5.6. При желании можно скомпилировать для любой другой имеющейся у нас версии PHP: 4.4, 5.2, 5.3, 5.4, 5.5, 5.6, 7.0, 7.1, 7.2, в зависимости от того, на какой из них работает сайт.

Сначала необходимо подключиться к аккаунту по протоколу SSH.

Если Вы пользуетесь OS Windows, то, скорее всего, Вам подойдет SSH-клиент PuTTy (статью по настройке можно прочитать здесь). Когда Putty настроена, можно продолжить.

Если Вы пользуетесь OS Linux или OS X, подойдет обычный терминал, который присутствует во всех Unix-подобных операционных системах. Подключиться можно следующей командой:

$ ssh username@username.beget.tech

Где username - логин, username.beget.tech - имя сервера, на котором располагается аккаунт. При подключении необходимо будет ввести пароль от аккаунта. Например:

denia@begetsupp:~$ ssh django17@django17.beget.tech
The authenticity of host 'django17.beget.tech (5.101.156.71)' can't be established.
ECDSA key fingerprint is e2:fb:d8:7d:fc:12:8f:6e:c3:24:b5:ce:46:da:ff:76.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'django17.beget.tech,5.101.156.71' (ECDSA) to the list of known hosts.
django17@django17.beget.tech's password:

 Welcome to LTD Beget server 'quasar'
Last login: Wed Jul 22 03:26:57 2015 from 80.79.241.142
chruby: unknown Ruby: 1.9.3-p551
django17@quasar:~ [0] $ 

Далее нужно перейти в специальный виртуальный контейнер на сервере (Docker), где доступны права на компиляцию. Для этого следует использовать следующую команду:

django17@quasar:~ [0] $ ssh localhost -p222

Затем ввести пароль. Он такой же, как и для доступа к аккаунту.

django17@localhost's password:
Welcome to Ubuntu 12.04.5 LTS (GNU/Linux 4.0.4-3-beget-acl x86_64)

 * Documentation:  https://help.ubuntu.com/
(docker) django17@quasar:~ [0] $ 

Затем нужно перейти в каталог cgi-bin для нужного сайта:

(docker) django17@quasar:~ [0] $ cd django17.bget.ru/public_html/cgi-bin/

Листинг файлов в каталоге:

(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin [0] $ ls -la
итого 88
drwx------+ 2 django17 newcustomers  4096 авг.  12 12:08 .
drwx------+ 3 django17 newcustomers  4096 авг.  12 12:08 ..
-rwx------+ 1 django17 newcustomers 72639 июля  22 04:05 php.ini

Нужно скачать исходный код Xdebug с официального сайта:

(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin [0] $ wget http://xdebug.org/files/xdebug-2.3.3.tgz
--2015-08-12 12:10:07--  http://xdebug.org/files/xdebug-2.3.3.tgz
Resolving xdebug.org (xdebug.org)... 82.113.146.227
Connecting to xdebug.org (xdebug.org)|82.113.146.227|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 268381 (262K) [application/x-gtar-compressed]
Saving to: `xdebug-2.3.3.tgz'

100%[=====================================================================================================================================================================================================>] 268 381      649K/s   in 0,4s

2015-08-12 12:10:07 (649 KB/s) - `xdebug-2.3.3.tgz' saved [268381/268381]

На текущий момент последняя версия Xdebug 2.3.3, скачать последнюю версию можно с официального сайта.

Далее нужно распаковывать архив и перейти в распакованный каталог:

(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin [0] $ tar xf xdebug-2.3.3.tgz ; cd xdebug-2.3.3
(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin/xdebug-2.3.3 [0] $

Окружение для PHP-расширения подготавливается командой phpize.

Обратите внимание!

Здесь мы используем phpize PHP версии 5.6: /usr/local/php-cgi/5.6/bin/phpize. Если у сайта иная версия PHP, указывайте в команде вместо 5.6 нужную версию, например, для PHP 5.3 команда будет выглядеть так:

/usr/local/php-cgi/5.3/bin/phpize
(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin/xdebug-2.3.3 [0] $ /usr/local/php-cgi/5.6/bin/phpize
Configuring for:
PHP Api Version:         20131106
Zend Module Api No:      20131226
Zend Extension Api No:   220131226

Утилитой configure настраиваются все зависимости, префиксы, переменные, после чего генерируется Makefile:

(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin/xdebug-2.3.3 [0] $ ./configure --enable-xdebug --with-php-config=/usr/local/php-cgi/5.6/bin/php-config --prefix=${HOME}/.local
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-unknown-linux-gnu
checking host system type... x86_64-unknown-linux-gnu
checking target system type... x86_64-unknown-linux-gnu
checking for PHP prefix... /usr/local/php-cgi/5.6.10
checking for PHP includes... -I/usr/local/php-cgi/5.6.10/include/php -I/usr/local/php-cgi/5.6.10/include/php/main -I/usr/local/php-cgi/5.6.10/include/php/TSRM -I/usr/local/php-cgi/5.6.10/include/php/Zend -I/usr/local/php-cgi/5.6.10/include/php/ext -I/usr/local/php-cgi/5.6.10/include/php/ext/date/lib
checking for PHP extension directory... /usr/local/php-cgi/5.6.10/lib/php/20131226
checking for PHP installed headers prefix... /usr/local/php-cgi/5.6.10/include/php
checking if debug is enabled... no
checking if zts is enabled... no
checking for re2c... re2c
checking for re2c version... 0.13.5 (ok)
checking for gawk... no
checking for nawk... nawk
checking if nawk is broken... no
checking whether to enable eXtended debugging support... yes, shared
checking Check for supported PHP versions... supported (5.6.10)
checking for gettimeofday... yes
checking for cos in -lm... yes
checking for ld used by cc... /usr/bin/ld
checking if the linker (/usr/bin/ld) is GNU ld... yes
checking for /usr/bin/ld option to reload object files... -r
checking for BSD-compatible nm... /usr/bin/nm -B
checking whether ln -s works... yes
checking how to recognize dependent libraries... pass_all
checking for ANSI C header files... yes
checking for sys/types.h... yes
checking for sys/stat.h... yes
checking for stdlib.h... yes
checking for string.h... yes
checking for memory.h... yes
checking for strings.h... yes
checking for inttypes.h... yes
checking for stdint.h... yes
checking for unistd.h... yes
checking dlfcn.h usability... yes
checking dlfcn.h presence... yes
checking for dlfcn.h... yes
checking the maximum length of command line arguments... 1572864
checking command to parse /usr/bin/nm -B output from cc object... ok
checking for objdir... .libs
checking for ar... ar
checking for ranlib... ranlib
checking for strip... strip
checking if cc supports -fno-rtti -fno-exceptions... no
checking for cc option to produce PIC... -fPIC
checking if cc PIC flag -fPIC works... yes
checking if cc static flag -static works... yes
checking if cc supports -c -o file.o... yes
checking whether the cc linker (/usr/bin/ld -m elf_x86_64) supports shared libraries... yes
checking whether -lc should be explicitly linked in... no
checking dynamic linker characteristics... GNU/Linux ld.so
checking how to hardcode library paths into programs... immediate
checking whether stripping libraries is possible... yes
checking if libtool supports shared libraries... yes
checking whether to build shared libraries... yes
checking whether to build static libraries... no

creating libtool
appending configuration tag "CXX" to libtool
configure: creating ./config.status
config.status: creating config.h

Затем нужно скомпилировать Xdebug из исходного кода:

(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin/xdebug-2.3.3 [0] $ make

После удачного выполнения команды make, в каталоге modules можно увидеть готовый модуль:

(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin/xdebug-2.3.3 [0] $ ls modules/
xdebug.so

Нужно скопировать его в каталог cgi-bin в каталог сайта (в нашем случае каталог сайта: ~/django17.bget.ru/public_html ):

(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin/xdebug-2.3.3 [0] $ cp modules/xdebug.so ~/django17.bget.ru/public_html/cgi-bin/

После чего перейти в этот каталог:

(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin/xdebug-2.3.3 [0] $ cd ~/django17.bget.ru/public_html/cgi-bin/

Следующая команда включит расширение в файле php.ini:

(docker) django17@quasar:~/django17.bget.ru/public_html/cgi-bin [0] $ echo "zend_extension = $(pwd)/xdebug.so" >> php.ini

Дальше нужно проверить, что расширение подключилось корректно. Для этого нужно добавить в корень сайта файл x.php со следующим содержимым:

И обратиться к нему через браузер, ссылка будет выглядеть следующим образом: http://domain.com/x.php

Компиляция Phalcon

Для успешного использования расширения Phalcon сайт должен работать в режиме CGI.

Ниже будет рассмотрена компиляция Phalcon для PHP 5.5. При желании можно скомпилировать для любой другой имеющейся у нас версии PHP: 4.4, 5.2, 5.3, 5.4, 5.6, 7.0, 7.1, 7.2, в зависимости от того, на какой из них работает сайт.

Сначала необходимо подключится к аккаунту по протоколу SSH.

Если Вы пользуетесь OS Windows, то, скорее всего, Вам подойдет SSH-клиент PuTTy (статью по настройке можно прочитать здесь). Когда настроите, можно переходить на шаг 2.

Если Вы пользуетесь OS Linux или OS X, подойдет обычный терминал, который присутствует во всех Unix-подобных операционных системах. Подключиться можно следующей командой:

$ ssh username@username.beget.tech

Где username - логин, username.beget.tech - имя сервера, на котором располагается аккаунт. При подключении необходимо будет ввести пароль от аккаунта. Например:

denia@begetsupp:~$ ssh django17@django17.beget.tech
The authenticity of host 'django17.beget.tech (5.101.156.71)' can't be established.
ECDSA key fingerprint is e2:fb:d8:7d:fc:12:8f:6e:c3:24:b5:ce:46:da:ff:76.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'django17.beget.tech,5.101.156.71' (ECDSA) to the list of known hosts.
django17@django17.beget.tech's password:

 Welcome to LTD Beget server 'quasar'
Last login: Wed Jul 22 03:26:57 2015 from 80.79.241.142
chruby: unknown Ruby: 1.9.3-p551
django17@quasar:~ [0] $ 

Далее нужно перейти в специальный виртуальный контейнер на сервере (Docker), где доступны права на компиляцию. Для этого следует использовать следующую команду:

django17@quasar:~ [0] $ ssh localhost -p222

Затем ввести пароль. Он такой же, как и для доступа к аккаунту.

django17@localhost's password:
Welcome to Ubuntu 12.04.5 LTS (GNU/Linux 4.0.4-3-beget-acl x86_64)

 * Documentation:  https://help.ubuntu.com/
(docker) django17@quasar:~ [0] $ 

После подключения нужно перейти во временный каталог .beget/tmp:

(docker) django17@quasar:~ [0] $ mkdir ~/.beget/tmp
(docker) django17@quasar:~ [0] $ cd ~/.beget/tmp

Затем нужно скопировать исходный код Phalcon из GIT-репозитория:

(docker) django17@quasar:~/.beget/tmp [0] $ git clone https://github.com/phalcon/cphalcon.git
Cloning into 'cphalcon'...
remote: Counting objects: 93079, done.
remote: Compressing objects: 100% (8/8), done.
remote: Total 93079 (delta 1), reused 0 (delta 0), pack-reused 93071
Receiving objects: 100% (93079/93079), 83.21 MiB | 10.95 MiB/s, done.
Resolving deltas: 100% (72208/72208), done.

После чего перейти в каталог с исходным кодом:

(docker) django17@quasar:~/.beget/tmp [0] $ cd cphalcon/build/php5/64bits/

Окружение для PHP-расширения подготавливается командой phpize:

(docker) django17@quasar:~/.beget/tmp/cphalcon/build/64bits [0] $ /usr/local/php-cgi/7.2/bin/phpize
Configuring for:
PHP Api Version:         20121113
Zend Module Api No:      20121212
Zend Extension Api No:   220121212

Обратите внимание!

Здесь мы используем phpize php версии 7.2: /usr/local/php-cgi/7.2/bin/phpize. Если у сайта иная версия PHP, указывайте в команде вместо 7.2 нужную версию, например, для PHP 5.3 команда будет выглядеть так:

/usr/local/php-cgi/5.3/bin/phpize

Утилитой configure настраиваются все зависимости, префиксы, переменные, после чего генерируется Makefile:

(docker) django17@quasar:~/.beget/tmp/cphalcon/build/64bits [0] $ ./configure --enable-phalcon --with-php-config=/usr/local/php-cgi/7.2/bin/php-config
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 whether to build static libraries... no

creating libtool
appending configuration tag "CXX" to libtool
configure: creating ./config.status
config.status: creating config.h

Если у сайта будет использоваться иная версия PHP, то в "--with-php-config=/usr/local/php-cgi/5.5/bin/php-config" указывайте иную версию PHP. Например, для PHP 5.3 будет выглядеть так:

./configure --enable-phalcon --with-php-config=/usr/local/php-cgi/5.3/bin/php-config

Затем нужно скомпилировать Phalcon из исходного кода:

(docker) django17@quasar:~/.beget/tmp/cphalcon/build/64bits [0] $ make -j33
/bin/bash /home/d/django17/.beget/tmp/cphalcon/build/64bits/libtool --mode=compile cc  -I. -I/home/d/django17/.beget/tmp/cphalcon/build/64bits -DPHP_ATOM_INC -I/home/d/django17/.beget/tmp/cphalcon/build/64bits/include -I/home/d/django17/.beget/tmp/cphalcon/build/64bits/main -I/home/d/django17/.beget/tmp/cphalcon/build/64bits -I/usr/local/php-cgi/5.5.26/include/php -I/usr/local/php-cgi/5.5.26/include/php/main -I/usr/local/php-cgi/5.5.26/include/php/TSRM -I/usr/local/php-cgi/5.5.26/include/php/Zend -I/usr/local/php-cgi/5.5.26/include/php/ext -I/usr/local/php-cgi/5.5.26/include/php/ext/date/lib  -DHAVE_CONFIG_H  -g -O2   -c /home/d/django17/.beget/tmp/cphalcon/build/64bits/phalcon.zep.c -o phalcon.lo
mkdir .libs
 cc -I. -I/home/d/django17/.beget/tmp/cphalcon/build/64bits -DPHP_ATOM_INC -I/home/d/django17/.beget/tmp/cphalcon/build/64bits/include -I/home/d/django17/.beget/tmp/cphalcon/build/64bits/main -I/home/d/django17/.beget/tmp/cphalcon/build/64bits -I/usr/local/php-cgi/5.5.26/include/php -I/usr/local/php-cgi/5.5.26/include/php/main -I/usr/local/php-cgi/5.5.26/include/php/TSRM -I/usr/local/php-cgi/5.5.26/include/php/Zend -I/usr/local/php-cgi/5.5.26/include/php/ext -I/usr/local/php-cgi/5.5.26/include/php/ext/date/lib -DHAVE_CONFIG_H -g -O2 -c /home/d/django17/.beget/tmp/cphalcon/build/64bits/phalcon.zep.c  -fPIC -DPIC -o .libs/phalcon.o
/bin/bash /home/d/django17/.beget/tmp/cphalcon/build/64bits/libtool --mode=install cp ./phalcon.la /home/d/django17/.beget/tmp/cphalcon/build/64bits/modules
cp ./.libs/phalcon.so /home/d/django17/.beget/tmp/cphalcon/build/64bits/modules/phalcon.so
cp ./.libs/phalcon.lai /home/d/django17/.beget/tmp/cphalcon/build/64bits/modules/phalcon.la
PATH="$PATH:/sbin" ldconfig -n /home/d/django17/.beget/tmp/cphalcon/build/64bits/modules
----------------------------------------------------------------------
Libraries have been installed in:
   /home/d/django17/.beget/tmp/cphalcon/build/64bits/modules

If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the `-LLIBDIR'
flag during linking and do at least one of the following:
   - add LIBDIR to the `LD_LIBRARY_PATH' environment variable
     during execution
   - add LIBDIR to the `LD_RUN_PATH' environment variable
     during linking
   - use the `-Wl,--rpath -Wl,LIBDIR' linker flag
   - have your system administrator add LIBDIR to `/etc/ld.so.conf'

See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------

Build complete.
Don't forget to run 'make test'.

Также необходимо заменить в файле Makefile путь до расширения Phalcon.

После удачного выполнения команды make, в каталоге modules можно увидеть готовый модуль:

(docker) django17@quasar:~/.beget/tmp/cphalcon/build/64bits [0] $ ls modules/
phalcon.la  phalcon.so

Нужно скопировать его в каталог cgi-bin в каталог сайта (в нашем случае каталог сайта: ~/redmine/public_html ):

(docker) django17@quasar:~/.beget/tmp/cphalcon/build/64bits [1] $ cp modules/phalcon.so ~/redmine/public_html/cgi-bin/

После чего перейти в этот каталог:

(docker) django17@quasar:~/.beget/tmp/cphalcon/build/64bits [0] $ cd ~/redmine/public_html/cgi-bin/

Следующая команда включит расширение в файле php.ini:

(docker) django17@quasar:~/redmine/public_html/cgi-bin [0] $ echo "zend_extension = $(pwd)/phalcon.so" >> php.ini

Дальше нужно проверить, что расширение подключилось корректно. Для этого нужно добавить в корень сайта файл x.php со следующим содержимым:

И обратиться к нему через браузер, ссылка будет выглядеть следующим образом: http://domain.com/x.php

Компиляция ssh2

Для успешного использования расширения ssh2 сайт должен работать в режиме CGI.

Ниже будет рассмотрена компиляция ssh2.

Сначала необходимо подключится к аккаунту по протоколу SSH.

Если Вы пользуетесь OS Windows, то, скорее всего, Вам подойдет SSH-клиент PuTTy (статью по настройке можно прочитать здесь). Когда настроите, можно переходить на шаг 2.

Если Вы пользуетесь OS Linux или OS X, подойдет обычный терминал, который присутствует во всех Unix-подобных операционных системах. Подключиться можно следующей командой:

$ ssh username@username.beget.tech

Где username - логин, username.beget.tech - имя сервера, на котором располагается аккаунт. При подключении необходимо будет ввести пароль от аккаунта. Например:

denia@begetsupp:~$ ssh django17@django17.beget.tech
The authenticity of host 'django17.beget.tech (5.101.156.71)' can't be established.
ECDSA key fingerprint is e2:fb:d8:7d:fc:12:8f:6e:c3:24:b5:ce:46:da:ff:76.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'django17.beget.tech,5.101.156.71' (ECDSA) to the list of known hosts.
django17@django17.beget.tech's password:

 Welcome to LTD Beget server 'quasar'
Last login: Wed Jul 22 03:26:57 2015 from 80.79.241.142
chruby: unknown Ruby: 1.9.3-p551
django17@quasar:~ [0] $ 

Далее нужно перейти в специальный виртуальный контейнер на сервере (Docker), где доступны права на компиляцию. Для этого следует использовать следующую команду:

deniatest@robin:~ [0] $ ssh localhost -p222

Затем ввести пароль, он такой же, как и для доступа к аккаунту.

deniatest@localhost's password:
Welcome to Ubuntu 12.04.5 LTS (GNU/Linux 4.0.4-3-beget-acl x86_64)

 * Documentation:  https://help.ubuntu.com/
(docker) deniatest@robin:~ [0] $ 

Необходимо создать каталог для скачивания и компиляции ssh2, после чего перейти в него:

(docker) deniatest@robin:~ [0] $ mkdir -p .local/lib/php && cd .local/lib/php

Для корректной компиляции ssh2 нужно скачать специальную библиотеку libssh:

(docker) deniatest@robin:~/.local/lib/php [0] $ wget https://github.com/libssh2/libssh2/releases/download/libssh2-1.6.0/libssh2-1.6.0.tar.gz
--2015-09-08 00:51:36--  https://github.com/libssh2/libssh2/releases/download/libssh2-1.6.0/libssh2-1.6.0.tar.gz
Resolving github.com (github.com)... 192.30.252.131
Connecting to github.com (github.com)|192.30.252.131|:443... connected.
HTTP request sent, awaiting response... 302 Found
Location: https://s3.amazonaws.com/github-cloud/releases/31701703/c27c01ae-110f-11e5-92eb-8661e8f1d84b.gz?response-content-disposition=attachment%3B%20filename%3Dlibssh2-1.6.0.tar.gz&response-content-type=application/octet-stream&AWSAccessKeyId=AKIAISTNZFOVBIJMK3TQ&Expires=1441666296&Signature=y3XfCzbMA6tpKu9OZF4uRUDC1KI%3D [following]
--2015-09-08 00:51:36--  https://s3.amazonaws.com/github-cloud/releases/31701703/c27c01ae-110f-11e5-92eb-8661e8f1d84b.gz?response-content-disposition=attachment%3B%20filename%3Dlibssh2-1.6.0.tar.gz&response-content-type=application/octet-stream&AWSAccessKeyId=AKIAISTNZFOVBIJMK3TQ&Expires=1441666296&Signature=y3XfCzbMA6tpKu9OZF4uRUDC1KI%3D
Resolving s3.amazonaws.com (s3.amazonaws.com)... 54.231.66.64
Connecting to s3.amazonaws.com (s3.amazonaws.com)|54.231.66.64|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 734110 (717K) [application/octet-stream]
Saving to: `libssh2-1.6.0.tar.gz'

100%[==============================================================================================================================>] 734 110      612K/s   in 1,2s

2015-09-08 00:51:38 (612 KB/s) - `libssh2-1.6.0.tar.gz' saved [734110/734110]

Затем нужно распаковать архив и перейти в каталог:

(docker) deniatest@robin:~/.local/lib/php [0] $ tar xvzf libssh2-1.6.0.tar.gz && cd libssh2-1.6.0
libssh2-1.6.0/
libssh2-1.6.0/depcomp
libssh2-1.6.0/docs/
libssh2-1.6.0/docs/libssh2_session_last_error.3
libssh2-1.6.0/docs/libssh2_scp_recv.3
libssh2-1.6.0/docs/libssh2_sftp_read.3
libssh2-1.6.0/docs/libssh2_userauth_publickey.3

Конфигурация Makefile:

(docker) deniatest@robin:~/.local/lib/php/libssh2-1.6.0 [0] $ ./configure --prefix=${HOME}/.local
checking whether to enable maintainer-specific portions of Makefiles... no
checking for sed... /bin/sed
checking for a BSD-compatible install... /usr/bin/install -c
checking whether build environment is sane... yes
/home/d/deniatest/.local/lib/php/libssh2-1.6.0/missing: Unknown `--is-lightweight' option
Try `/home/d/deniatest/.local/lib/php/libssh2-1.6.0/missing --help' for more information
configure: WARNING: 'missing' script is too old or missing
checking for a thread-safe mkdir -p... /usr/bin/mkdir -p
checking for gawk... no
checking for mawk... mawk
checking whether make sets $(MAKE)... yes


  version:          1.6.0
  Host type:        x86_64-unknown-linux-gnu
  Install prefix:   /home/d/deniatest/.local
  Compiler:         gcc
  Compiler flags:   -g -O2
  Library types:    Shared=yes, Static=yes
  Crypto library:   OpenSSL (AES-CTR: yes)
  Clear memory:     unsupported
  Debug build:      no
  Build examples:   yes
  Path to sshd:     /usr/sbin/sshd (only for self-tests)
  zlib compression: yes

Компиляция:

(docker) deniatest@robin:~/.local/lib/php/libssh2-1.6.0 [0] $ make -j33 && make install
Making all in src
make[1]: Entering directory `/home/d/deniatest/.local/lib/php/libssh2-1.6.0/src'
make  all-am
make[2]: Entering directory `/home/d/deniatest/.local/lib/php/libssh2-1.6.0/src'
/bin/bash ../libtool  --tag=CC   --mode=compile gcc -DHAVE_CONFIG_H   -I../include -I../src   -g -O2 -MT channel.lo -MD -MP -MF .deps/channel.Tpo -c -o channel.lo channel.c
/bin/bash ../libtool  --tag=CC   --mode=compile gcc -DHAVE_CONFIG_H   -I../include -I../src   -g -O2 -MT comp.lo -MD -MP -MF .deps/comp.Tpo -c -o comp.lo comp.c
/bin/bash ../libtool  --tag=CC   --mode=compile gcc -DHAVE_CONFIG_H   -I../include -I../src   -g -O2 -MT crypt.lo -MD -MP -MF .deps/crypt.Tpo -c -o crypt.lo crypt.c
/bin/bash ../libtool  --tag=CC   --mode=compile gcc -DHAVE_CONFIG_H   -I../include -I../src   -g -O2 -MT hostkey.lo -MD -MP -MF .deps/hostkey.Tpo -c -o hostkey.lo hostkey.c

Переход на директорию выше и листинг каталога:

(docker) deniatest@robin:~/.local/lib/php/libssh2-1.6.0 [0] $ cd .. ; ls -la
итого 744K
drwx------+  3 deniatest newcustomers 4,0K сент.  8 00:54 ./
drwx------+  5 deniatest newcustomers 4,0K сент.  8 00:57 ../
drwx------+ 11 deniatest newcustomers 4,0K сент.  8 00:54 libssh2-1.6.0/
-rw-------+  1 deniatest newcustomers 717K июня  12 15:31 libssh2-1.6.0.tar.gz

Затем нужно скачать сам ssh2:

(docker) deniatest@robin:~/.local/lib/php [0] $ wget https://pecl.php.net/get/ssh2-0.12.tgz
--2015-09-08 01:01:10--  https://pecl.php.net/get/ssh2-0.12.tgz
Resolving pecl.php.net (pecl.php.net)... 104.236.228.160
Connecting to pecl.php.net (pecl.php.net)|104.236.228.160|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 26223 (26K) [application/octet-stream]
Saving to: `ssh2-0.12.tgz'

100%[==============================================================================================================================>] 26 223      --.-K/s   in 0,1s

2015-09-08 01:01:11 (237 KB/s) - `ssh2-0.12.tgz' saved [26223/26223]

После чего распаковать архив и перейти в распакованную каталог:

(docker) deniatest@robin:~/.local/lib/php [0] $ tar xvzf ssh2-0.12.tgz && cd ssh2-0.12
package.xml
ssh2-0.12/config.m4
ssh2-0.12/ssh2.c
ssh2-0.12/php_ssh2.h
ssh2-0.12/ssh2_fopen_wrappers.c
ssh2-0.12/ssh2_sftp.c
ssh2-0.12/LICENSE

Окружение для PHP-расширения подготавливается командой phpize. В примере компилируется ssh2 для PHP 5.5, при необходимости версию PHP можно изменить на ту, которая используется на сайте:

(docker) deniatest@robin:~/.local/lib/php/ssh2-0.12 [0] $ /usr/local/php-cgi/5.5/bin/phpize
Configuring for:
PHP Api Version:         20121113
Zend Module Api No:      20121212
Zend Extension Api No:   220121212

Утилитой configure настраиваются все зависимости, префиксы, переменные, после чего генерируется Makefile. Если для phpize использовалась версия PHP, отличная от 5.5, при выполнении configure путь также необходимо изменить:

(docker) deniatest@robin:~/.local/lib/php/ssh2-0.12 [2] $ ./configure --with-php-config=/usr/local/php-cgi/5.5/bin/php-config --prefix=$HOME/.local --with-ssh2=$HOME/.local
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

Компиляция и копирование скомпилированной библиотеки:

(docker) deniatest@robin:~/.local/lib/php/ssh2-0.12 [0] $ make -j33 && cp modules/ssh2.so ~/cloudflare_test/public_html/cgi-bin/
/bin/bash /home/d/deniatest/.local/lib/php/ssh2-0.12/libtool --mode=compile cc  -I. -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -DPHP_ATOM_INC -I/home/d/deniatest/.local/lib/php/ssh2-0.12/include -I/home/d/deniatest/.local/lib/php/ssh2-0.12/main -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -I/usr/local/php-cgi/5.5.26/include/php -I/usr/local/php-cgi/5.5.26/include/php/main -I/usr/local/php-cgi/5.5.26/include/php/TSRM -I/usr/local/php-cgi/5.5.26/include/php/Zend -I/usr/local/php-cgi/5.5.26/include/php/ext -I/usr/local/php-cgi/5.5.26/include/php/ext/date/lib -I/home/d/deniatest/.local/include  -DHAVE_CONFIG_H  -g -O2   -c /home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2.c -o ssh2.lo
/bin/bash /home/d/deniatest/.local/lib/php/ssh2-0.12/libtool --mode=compile cc  -I. -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -DPHP_ATOM_INC -I/home/d/deniatest/.local/lib/php/ssh2-0.12/include -I/home/d/deniatest/.local/lib/php/ssh2-0.12/main -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -I/usr/local/php-cgi/5.5.26/include/php -I/usr/local/php-cgi/5.5.26/include/php/main -I/usr/local/php-cgi/5.5.26/include/php/TSRM -I/usr/local/php-cgi/5.5.26/include/php/Zend -I/usr/local/php-cgi/5.5.26/include/php/ext -I/usr/local/php-cgi/5.5.26/include/php/ext/date/lib -I/home/d/deniatest/.local/include  -DHAVE_CONFIG_H  -g -O2   -c /home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2_fopen_wrappers.c -o ssh2_fopen_wrappers.lo
/bin/bash /home/d/deniatest/.local/lib/php/ssh2-0.12/libtool --mode=compile cc  -I. -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -DPHP_ATOM_INC -I/home/d/deniatest/.local/lib/php/ssh2-0.12/include -I/home/d/deniatest/.local/lib/php/ssh2-0.12/main -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -I/usr/local/php-cgi/5.5.26/include/php -I/usr/local/php-cgi/5.5.26/include/php/main -I/usr/local/php-cgi/5.5.26/include/php/TSRM -I/usr/local/php-cgi/5.5.26/include/php/Zend -I/usr/local/php-cgi/5.5.26/include/php/ext -I/usr/local/php-cgi/5.5.26/include/php/ext/date/lib -I/home/d/deniatest/.local/include  -DHAVE_CONFIG_H  -g -O2   -c /home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2_sftp.c -o ssh2_sftp.lo
mkdir .libs
mkdir .libs
mkdir: cannot create directory `.libs': File exists
 cc -I. -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -DPHP_ATOM_INC -I/home/d/deniatest/.local/lib/php/ssh2-0.12/include -I/home/d/deniatest/.local/lib/php/ssh2-0.12/main -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -I/usr/local/php-cgi/5.5.26/include/php -I/usr/local/php-cgi/5.5.26/include/php/main -I/usr/local/php-cgi/5.5.26/include/php/TSRM -I/usr/local/php-cgi/5.5.26/include/php/Zend -I/usr/local/php-cgi/5.5.26/include/php/ext -I/usr/local/php-cgi/5.5.26/include/php/ext/date/lib -I/home/d/deniatest/.local/include -DHAVE_CONFIG_H -g -O2 -c /home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2_sftp.c  -fPIC -DPIC -o .libs/ssh2_sftp.o
 cc -I. -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -DPHP_ATOM_INC -I/home/d/deniatest/.local/lib/php/ssh2-0.12/include -I/home/d/deniatest/.local/lib/php/ssh2-0.12/main -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -I/usr/local/php-cgi/5.5.26/include/php -I/usr/local/php-cgi/5.5.26/include/php/main -I/usr/local/php-cgi/5.5.26/include/php/TSRM -I/usr/local/php-cgi/5.5.26/include/php/Zend -I/usr/local/php-cgi/5.5.26/include/php/ext -I/usr/local/php-cgi/5.5.26/include/php/ext/date/lib -I/home/d/deniatest/.local/include -DHAVE_CONFIG_H -g -O2 -c /home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2_fopen_wrappers.c  -fPIC -DPIC -o .libs/ssh2_fopen_wrappers.o
 cc -I. -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -DPHP_ATOM_INC -I/home/d/deniatest/.local/lib/php/ssh2-0.12/include -I/home/d/deniatest/.local/lib/php/ssh2-0.12/main -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -I/usr/local/php-cgi/5.5.26/include/php -I/usr/local/php-cgi/5.5.26/include/php/main -I/usr/local/php-cgi/5.5.26/include/php/TSRM -I/usr/local/php-cgi/5.5.26/include/php/Zend -I/usr/local/php-cgi/5.5.26/include/php/ext -I/usr/local/php-cgi/5.5.26/include/php/ext/date/lib -I/home/d/deniatest/.local/include -DHAVE_CONFIG_H -g -O2 -c /home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2.c  -fPIC -DPIC -o .libs/ssh2.o
/home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2_sftp.c:570:2: warning: excess elements in struct initializer [enabled by default]
/home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2_sftp.c:570:2: warning: (near initialization for ‘php_ssh2_sftp_wrapper’) [enabled by default]
/home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2_sftp.c:571:2: warning: excess elements in struct initializer [enabled by default]
/home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2_sftp.c:571:2: warning: (near initialization for ‘php_ssh2_sftp_wrapper’) [enabled by default]
/home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2.c: In function ‘zif_ssh2_publickey_add’:
/home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2.c:1063:4: warning: passing argument 1 of ‘_efree’ discards ‘const’ qualifier from pointer target type [enabled by default]
/usr/local/php-cgi/5.5.26/include/php/Zend/zend_alloc.h:60:15: note: expected ‘void *’ but argument is of type ‘const char *’
/home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2.c: In function ‘zif_ssh2_publickey_list’:
/home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2.c:1122:3: warning: passing argument 4 of ‘add_assoc_stringl_ex’ discards ‘const’ qualifier from pointer target type [enabled by default]
/usr/local/php-cgi/5.5.26/include/php/Zend/zend_API.h:382:14: note: expected ‘char *’ but argument is of type ‘const unsigned char *’
/home/d/deniatest/.local/lib/php/ssh2-0.12/ssh2.c:1123:3: warning: passing argument 4 of ‘add_assoc_stringl_ex’ discards ‘const’ qualifier from pointer target type [enabled by default]
/usr/local/php-cgi/5.5.26/include/php/Zend/zend_API.h:382:14: note: expected ‘char *’ but argument is of type ‘const unsigned char *’
/bin/bash /home/d/deniatest/.local/lib/php/ssh2-0.12/libtool --mode=link cc -DPHP_ATOM_INC -I/home/d/deniatest/.local/lib/php/ssh2-0.12/include -I/home/d/deniatest/.local/lib/php/ssh2-0.12/main -I/home/d/deniatest/.local/lib/php/ssh2-0.12 -I/usr/local/php-cgi/5.5.26/include/php -I/usr/local/php-cgi/5.5.26/include/php/main -I/usr/local/php-cgi/5.5.26/include/php/TSRM -I/usr/local/php-cgi/5.5.26/include/php/Zend -I/usr/local/php-cgi/5.5.26/include/php/ext -I/usr/local/php-cgi/5.5.26/include/php/ext/date/lib -I/home/d/deniatest/.local/include  -DHAVE_CONFIG_H  -g -O2   -o ssh2.la -export-dynamic -avoid-version -prefer-pic -module -rpath /home/d/deniatest/.local/lib/php/ssh2-0.12/modules  ssh2.lo ssh2_fopen_wrappers.lo ssh2_sftp.lo -Wl,-rpath,/home/d/deniatest/.local/lib -L/home/d/deniatest/.local/lib -lssh2
cc -shared  .libs/ssh2.o .libs/ssh2_fopen_wrappers.o .libs/ssh2_sftp.o  -Wl,--rpath -Wl,/home/d/deniatest/.local/lib -Wl,--rpath -Wl,/home/d/deniatest/.local/lib -L/home/d/deniatest/.local/lib /home/d/deniatest/.local/lib/libssh2.so  -Wl,-rpath -Wl,/home/d/deniatest/.local/lib -Wl,-soname -Wl,ssh2.so -o .libs/ssh2.so
creating ssh2.la
(cd .libs && rm -f ssh2.la && ln -s ../ssh2.la ssh2.la)
/bin/bash /home/d/deniatest/.local/lib/php/ssh2-0.12/libtool --mode=install cp ./ssh2.la /home/d/deniatest/.local/lib/php/ssh2-0.12/modules
cp ./.libs/ssh2.so /home/d/deniatest/.local/lib/php/ssh2-0.12/modules/ssh2.so
cp ./.libs/ssh2.lai /home/d/deniatest/.local/lib/php/ssh2-0.12/modules/ssh2.la
PATH="$PATH:/sbin" ldconfig -n /home/d/deniatest/.local/lib/php/ssh2-0.12/modules
----------------------------------------------------------------------
Libraries have been installed in:
   /home/d/deniatest/.local/lib/php/ssh2-0.12/modules

If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the `-LLIBDIR'
flag during linking and do at least one of the following:
   - add LIBDIR to the `LD_LIBRARY_PATH' environment variable
     during execution
   - add LIBDIR to the `LD_RUN_PATH' environment variable
     during linking
   - use the `-Wl,--rpath -Wl,LIBDIR' linker flag
   - have your system administrator add LIBDIR to `/etc/ld.so.conf'

See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------

Build complete.
Don't forget to run 'make test'.

Проверка, что расширение скомпилировалось и лежит в каталоге:

(docker) deniatest@robin:~/.local/lib/php/ssh2-0.12 [0] $ ls -l ~/cloudflare_test/public_html/cgi-bin/ssh2.so
-rwx------+ 1 deniatest newcustomers 238052 сент.  8 01:07 /home/d/deniatest/cloudflare_test/public_html/cgi-bin/ssh2.so

Затем нужно перейти в каталог cgi-bin в корне сайта, для которого компилировалось расширение:

(docker) deniatest@robin:~/.local/lib/php/ssh2-0.12 [0] $ cd ~/cloudflare_test/public_html/cgi-bin/

Следующая команда включит расширение в файле php.ini:

(docker) deniatest@robin:~/cloudflare_test/public_html/cgi-bin [0] $ echo "extension = $(pwd)/ssh2.so" >> php.ini

Дальше нужно проверить, что расширение подключилось корректно. Для этого нужно добавить в корень сайта файл x.php со следующим содержимым:

И обратиться к нему через браузер, ссылка будет выглядеть следующим образом: http://domain.com/x.php