Instana offers comprehensive monitoring of your PHP application environment, providing end-to-end visibility into your system. After you install the Instana host agent, the agent automatically
deploys the PHP sensor and tracer in your PHP environment. You can view infrastructure metrics and end-to-end traces of all requests in your PHP environment in the Instana UI.
- Supported information
- Configuring PHP sensors
- Viewing metrics
- Integrating with OpenTracing
- Service naming
- Setting the process name
Supported operating system
The PHP sensor is supported only on Linux operating systems. For more information about this support, see the CPU architecture column of the table in Supported PHP versions.
Supported PHP versions
Instana supports the following PHP versions for metrics and configuration data:
|PHP version||CPU architecture||Supported Zend Thread Safety (ZTS)||Supported type|
|PHP 5.3 - PHP 8.2||x86_64||Both ZTS and non-ZTS||GA|
|PHP 7.2 - PHP 8.1||aarch64||Both ZTS and non-ZTS||GA|
Supported PHP SAPIs
Instana supports the following PHP Server Application Programming Interface (SAPIs) for configuration data, metrics, and tracing:
|Apache with mod_php||GA|
Instana can provide tracing for CLI if you configure the tracing extension with the flag
instana.enable_cli = 1. However, because CLI requests are usually of short duration, Instana cannot connect them to the Dynamic Graph. Therefore,
you can see the trace, but you cannot obtain any information about the connected services or infrastructure. Also, you must install the tracing extension. For support with setting up CLI tracing, contact IBM support.
Instana doesn't support the following PHP configurations:
- Using PHP on Windows systems
- Using Apache HTTP Server that is configured to serve PHP content with threaded MPM "worker" or "event" and PHP ZTS
- Using multiple tracing tools like Instana and a third-party tracer, for example, New Relic, Otel, Dynatrace, or Datadog, simultaneously with PHP
Configuring PHP sensors
After you install the Instana agent, the PHP sensor is automatically installed and configured with reasonable defaults. Usually, you don't need to modify these settings in the Instana agent's configuration.yaml file:
The following YAML snippet shows the available settings:
# PHP Tracing #com.instana.plugin.php: # # Lightweight PHP Tracing. Requires the Instana Tracing extension. Enabled by default. # tracing: # # Enabling tracing will automatically download the Instana Tracing # # extension and enable it in your php.ini. If you are using preforked # # PHP workers, like PHP-FPM, you will need to restart them. Disabling # # tracing again will not remove the extension. It will only disable the # # tracing sensor. # enabled: true # # Whether to install the PHP Tracing extension. Default is true. Disabling # # the installation will still create the TraceAcceptor daemon though. # installExtension: true # # The filename to use when querying Apache or PHP-CGI installations for # # environment data such as version, architecture, etc. By default, this # # is "instana." + Math.random(). + ".php". Uncommenting the setting # # as follows will force a static filename instead. # phpInfoFilename: instana.php # # Pins the PHP Tracing extension to download and install to a specific # # version. This can be used to rollback to previous versions of the # # extension or to test beta versions (when asked to do so). Expects # # the version to be given as major.minory.patch, e.g. 0.3.7 # pinExtensionVersion: x.y.z # # The absolute path to the script to trigger whenever the sensor installed # # a different version of the PHP tracing extension than is currently # # installed. Works for upgrades and downgrades. Default is empty. # notificationScript: /path/to/restart_php.sh # # The number of executor threads to use for processing traces. This setting # # can be used to fine tune the PHP sensor for specific load environments. # # Defaults to the number of available logical processors or 8 (whichever is less). # # In general, you don't need to touch this setting unless advised to do so. # executorThreads: n # # The maximum number of traces the sensor is allowed to keep in the backlog # # for processing. Can be used in conjunction with executorThreads to fine tune # # the sensor for specific load environments. In general, you don't need to touch # # this setting unless advised to do so. Defaults to 1000. # executorQueueLimit: 1000 # # Port on which the sensor is listening for traces. Changing this setting will # # not automatically update any .ini files created for the PHP Tracing extension. # # In general, you don't need to touch this setting unless advised to do so. # # Defaults to port 16816. # port: 16816 # # Whether to remove values in SQL queries to prevent sensitive data from # # reaching our backend. This can help to improve agent performance in certain # # setups. In general, you don't need to touch this setting unless advised to do so. # sanitizeSql: true
Enabling PHP 8.2 support
To enable PHP 8.2 support, use the following configuration:
# PHP Tracing com.instana.plugin.php: tracing: enabled: true pinExtensionVersion: 1.20.0
Some minor issues are reported for monitoring PHP 8.2. If you encounter any issues, open a case with IBM Support.
Enabling automatic restarts
You can change how the PHP sensor attempts to restart your PHP environment through the
notificationScript configuration setting. For more information about how to use the
notificationScript setting, see the Automatic restarts section.
Enabling PHP-FPM status page
To thoroughly monitor PHP-FPM metrics, you need to enable the status page. To enable the page, open the worker pool configuration file and add the entry
pm.status_path = /status. The Instana PHP-FPM sensor directly accesses the
endpoint for accessing the PHP-FPM status page through FastCGI.
The Apache configuration must contain the following line:
Without the line, the sensor fails to load and the following error message is logged:
> "PHP Sensor is failing because of "NO Version found"
To view metrics for PHP, complete the following steps:
- In the sidebar of the Instana UI, select Infrastructure.
- Click a specific monitored host.
You can see a host dashboard with all the collected metrics and monitored processes.
Like any other Instana sensor, the PHP sensor does not need any configuration. It automatically detects your PHP installation and collects the following data from the installation:
For PHP, the configuration data, performance metrics, and the health signatures depend on the SAPI used. For more information, see Supported PHP SAPIs.
Configuration data and metrics
The following table lists the generally tracked configuration data:
- PHP version
- Server API
- Zend Thread Safety
- Loaded Modules
- Main Ini file
- Ini directory
- Additional Ini files parsed
- PHP extensions directory
Note: The generally tracked configuration for Apache with mod_php is included in the Apache dashboard. For PHP-CGI, this configuration data is included in the used webserver's dashboard (if applicable).
In addition to the generally tracked configuration, the PHP-FPM dashboard includes the following configuration data:
- Master Process ID
- Master Configuration
- Worker Pools
PHP-FPM dashboard also includes the following metrics:
Each sensor has a curated knowledge base of health signatures that are evaluated continuously against the incoming metrics. These health signatures are used to raise issues or incidents that depend on user impact.
Built-in events trigger issues or incidents based on failing health signatures on entities, and custom events trigger issues or incidents based on the thresholds of an individual metric of any specific entity.
For more information about built-events for PHP-FPM, see the Built-in events reference.
Instana provides both automatic and manual instrumentation for PHP.
Instana automatically instruments your PHP applications. To instruments your PHP applications, the Instana agent requires the PHP tracing extension, which is automatically downloaded when the PHP sensor is enabled. The configuration is at
<agent_install_dir>/etc/instana/configuration.yaml and the current version of the Instana agent contains an example of the required configuration settings.
PHP tracing is active by default. For more information about disabling tracing, see Disabling the PHP tracing sensor. The PHP sensor is linked to a PHP SAPI sensor. So tracing starts only when the Instana agent detects a supported SAPI sensor (currently PHP-FPM, mod_php, and php-cgi). For more information, see Supported PHP SAPI sensors.
The PHP sensor gathers information about the SAPI's configuration and downloads an appropriate Instana extension based on your version of PHP and your host's architecture. The PHP sensor always downloads the most recent version of the Instana
extension. However, you can also pin (force) a specific version by setting
pinExtensionVersion: x.y.z in the
For more information about PHP tracing extension and its following settings, see PHP tracing extension:
- Required PHP extensions
- Customizing PHP extension settings
- Available flags
- Uninstalling the Instana PHP tracing extension
- Automatic restarts
Instana instruments your PHP application at the PHP engine level and provides the following traces for selected function calls:
- HTTP Streams
- Zend Framework
- AMQP (pecl-amqp) -AMQP (php-amqp-lib)
- Google Cloud Pub/Sub
- IBM Db2
- CUBRID (PDO)
- MS SQL Server (PDO)
- Firebird (PDO)
- IBM (PDO)
- Informix (PDO)
- MySQL (PDO)
- MS SQL Server (PDO)
- Oracle (PDO)
- ODBC and Db2 (PDO)
- PostgreSQL (PDO)
- SQLite (PDO)
- PostgreSQL (PDO, not ext-pgsql)
- Redis (via predis or PECL redis)
- Drupal logger
- Kohana logger
- Magento logger
- Yii logger
- Shell calls
- Compile time
- OpCache metrics
Note: Stack traces in span details are only supported by PHP 5.4 and later versions.
You can also manually instrument your PHP code through tracing SDKs that allow you to add tracing data to those automatically collected by Instana.
The PHP tracing extension comes with a minimal SDK. By using this SDK, you can manually instrument your code. For more information, see PHP-SDK.
Integrating with OpenTracing
Instana provides a separate PHP SDK for tracing with OpenTracing. Unlike Instana's own PHP instrumentation, the OpenTracing SDK requires you to manually instrument your code. Traces that are generated through the PHP OpenTracing SDK are separate from traces that are generated by Instana's own tracing.
Instana automatically tries to determine a useful service name from the traces it collects. However, you can force a service name manually. The PHP tracer looks for the
INSTANA_SERVICE_NAME key in PHP's
$_ENV arrays and uses whatever is set for a value as the service name. If
INSTANA_SERVICE_NAME is set in both the
$_ENV arrays, then the
$_ENV value is used.
Setting the process name
You can use the environment variable
INSTANA_PROCESS_NAME to set a custom label for the infrastructure entity that represents the PHP process.