Set up App and API Protection for PHP on Linux
This product is not supported for your selected 
Datadog site. (
).
You can enable App and API Protection for PHP services with the following setup options:
- If your PHP service already has APM tracing set up and running, then skip to service configuration
- If your PHP service doesn't have APM tracing set up, you can easily enable App and API Protection with Datadog's Automatic Installation
- Otherwise, keep reading the following manual setup instructions
Overview
App and API Protection leverages the Datadog PHP library to monitor and secure your PHP service. The library integrates seamlessly with your existing application without requiring code changes.
For detailed compatibility information, including supported PHP versions, frameworks, and deployment environments, see PHP Compatibility Requirements.
This guide explains how to set up App and API Protection (AAP) for PHP applications. The setup involves:
- Installing the Datadog Agent
- Enabling App and API Protection monitoring
- Running your PHP application with the Datadog Agent
- Verifying the setup
Prerequisites
- Linux operating system
- PHP application
- Root or sudo privileges
- Systemd (for service management)
- Your Datadog API key
- Datadog PHP tracing library (see version requirements)
1. Installing the Datadog Agent
Install the Datadog Agent by following the setup instructions for Linux hosts.
2. Enabling App and API Protection monitoring
Automatically enabling App and API Protection through Remote Configuration
You can enable remote configuration on your services dashboard.
Simply check the box for the service you want to enable App and API Protection for under "Activate on your APM services".
Manually enabling App and API Protection monitoring
Install the Datadog PHP tracing library:
RUN curl -LO https://github.com/DataDog/dd-trace-php/releases/latest/download/datadog-setup.php
RUN php datadog-setup.php --php-bin=all
Configure and run your service with Datadog:
Set the required environment variables and start your PHP application:
export DD_APPSEC_ENABLED=true
export DD_SERVICE=<YOUR_SERVICE_NAME>
export DD_ENV=<YOUR_ENVIRONMENT>
To disable APM tracing while keeping App and API Protection enabled, you must set the APM tracing variable to false.
Set the required environment variables and start your PHP application:
export DD_APPSEC_ENABLED=true
export DD_APM_TRACING_ENABLED=false
export DD_SERVICE=<YOUR_SERVICE_NAME>
export DD_ENV=<YOUR_ENVIRONMENT>
3. Run your application
Start your PHP application with the settings described above.
4. Verify setup
To verify that App and API Protection is working correctly:
- Send some traffic to your application.
- Check for security signals and vulnerabilities in the Application Signals Explorer in Datadog.
Troubleshooting
If you encounter issues while setting up App and API Protection for your PHP application, see the PHP App and API Protection troubleshooting guide.
Further Reading
Additional helpful documentation, links, and articles: