Skip to content

Latest commit

 

History

History
175 lines (137 loc) · 6.8 KB

README.md

File metadata and controls

175 lines (137 loc) · 6.8 KB

Scout APM PHP Extension

CI Build

The Scout APM PHP extension allows instrumentation of internal PHP functions that can't be done in regular PHP. The scout-apm-php package detects if the scoutapm extension is loaded and will automatically send this data if available.

This extension allows instrumentation of:

  • Core functions: file_get_contents, file_put_contents, fread, fwrite
  • Curl functions: curl_exec
  • PDO methods: PDO->exec, PDO->query, PDOStatement->execute
  • Predis PHP library methods
  • phpredis PHP extension methods
  • Memcached PHP extension methods
  • Elasticsearch PHP library methods

If you would like another function instrumented, please let us know on our issues.

The following functions are exposed when the extension is enabled:

  • scoutapm_enable_instrumentation(bool $enabled): void
    • Enable or disable instrumentation by ScoutAPM at runtime. Instrumentation is disabled by default, so this must be called with $enabled to true.
  • scoutapm_get_calls(): array
    • Returns a list of any instrumented function calls since scoutapm_get_calls() was last called. The list is cleared each time the function is called.
  • scoutapm_list_instrumented_functions(): array
    • Returns a list of the functions the extension will instrument if called.

Prerequisites for cURL

In order to have instrumentation for cURL functions enabled, you MUST have libcurl available when building or installing from pecl.

For example, if you are using the ppa:ondrej/php PPA on Ubuntu, you must install libcurl before building scoutapm extension, e.g.:

$ apt-get -y install libcurl4-openssl-dev
$ pecl install scoutapm

To confirm if cURL instrumentation is working, check php -i:

scoutapm

scoutapm support => enabled
scoutapm Version => 1.9.1
scoutapm curl HAVE_CURL => No
scoutapm curl HAVE_SCOUT_CURL => Yes
scoutapm curl enabled => Yes
  • scoutapm curl HAVE_CURL was PHP itself compiled with cURL. This will not always be Yes, for example when using pre-packaged binaries where curl extension is separate.
  • scoutapm curl HAVE_SCOUT_CURL was the scoutapm extension compiled and libcurl available? If this is No, then cURL instrumentation will not be available at all.
  • scoutapm curl enabled tells you if scoutapm has enabled monitoring (i.e. curl extension was available at runtime, and libcurl was available when scoutapm was compiled). If this value is No and you think it should be Yes, check that libcurl was available when scoutapm was compiled, and that you have the curl PHP extension enabled.

Installing from PECL

The Scout APM extension is available to install using PECL.

$ sudo pecl install scoutapm

You may need to add zend_extension=scoutapm.so into your php.ini to enable the extension.

Installing with Docker

If you are using Docker, with the official PHP images, you can install the scoutapm extension using PECL still, for example:

FROM php:8.2-cli

RUN pecl install scoutapm-1.9.1 \
    && docker-php-ext-enable scoutapm

For more information on this installation method, see here.

Building

$ phpize
$ ./configure --enable-scoutapm
$ make test

Run tests with installed PHP (avoids skipped tests):

make && php run-tests.php -d zend_extension=$(pwd)/modules/scoutapm.so --show-diff -q

Note: whilst a CMakeLists.txt exists, this project does NOT use CMake. The CMakeLists.txt exists so this project can be worked on in CLion. See https://dev.to/jasny/developing-a-php-extension-in-clion-3oo1.

Building with specific PHP build

$ /path/to/bin/phpize
$ ./configure --with-php-config=/path/to/bin/php-config --enable-scoutapm
$ make test

Debugging

Use gdb (e.g. in CLion) to debug. Once running, php-src has a GDB helper:

source /path/to/php-src/.gdbinit
printzv <thing>
print_ht <thing>
zbacktrace
print_cvs

Windows builds

Release Procedure

  • Open package.xml
  • Copy the current release into a new changelog.release element
  • Update the current release section (date/time/version/stability/notes)
  • pecl package-validate to check everything looks good
  • Increase/verify PHP_SCOUTAPM_VERSION version listed in zend_scoutapm.h
  • Commit update to package.xml
  • Rebuild from scratch (full-clean.sh, then build as above)
  • make test to ensure everything passes locally
  • Push the branch (optionally, make a PR to GitHub) to trigger CI to build
  • Once merged, close the milestone to automatically release & generate the TGZ asset
  • Go to the latest release just created
  • Download the TGZ asset and upload it to pecl.php.net