Azure Application Insights SDK for PHP
Перейти к файлу
Sergey Kanzhelev 7176fcb08a updated name in license 2018-05-22 11:19:34 -07:00
ApplicationInsights bump the version 2018-05-22 11:18:53 -07:00
Tests finalizing track error improvements (#48) 2018-05-22 11:15:09 -07:00
.gitattributes Initial project setup, including basic unit tests. 2014-12-02 11:14:30 -07:00
.gitignore More progress on PHP to service interaction. Moved to composer for managing dependencies, including adding a dependency on GuzzleHttp. 2014-12-03 12:20:15 -07:00
.travis.yml fix testCompleteException test 2018-05-14 15:35:53 -07:00
Application.Insights.phpproj Renamed Message_SeverityLevel class to respect naming conventions. 2017-05-16 21:50:33 +02:00
Application.Insights.sln More progress on PHP to service interaction. Moved to composer for managing dependencies, including adding a dependency on GuzzleHttp. 2014-12-03 12:20:15 -07:00
CHANGELOG.md bump the version 2018-05-22 11:18:16 -07:00
CONTRIBUTING.md contributing guide and travis 2018-05-14 12:18:18 -07:00
LICENSE.txt updated name in license 2018-05-22 11:19:34 -07:00
README.md fixed travis 2018-05-14 15:11:24 -07:00
composer.json updated Guzzle to 6.3.3 (latest) 2018-05-21 23:25:53 -07:00
phpdoc.xml Adding support for documentation generation and added some documentation to the main readme. 2014-12-19 18:42:46 -08:00
phpunit.xml Fix phpunit 2017-10-12 13:53:57 +01:00

README.md

Application Insights for PHP

Build Status Packagist Pre Release

This project extends the Application Insights API surface to support PHP. Application Insights is a service that allows developers to keep their application available, performing and succeeding. This PHP module will allow you to send telemetry of various kinds (event, trace, exception, etc.) to the Application Insights service where they can be visualized in the Azure Portal.

Requirements

PHP version >=5.4.2 is supported.

For opening the project in Microsoft Visual Studio you will need PHP Tools for Visual Studio. This is not required however.

Installation

We've published a package you can find on Packagist. In order to use it, first, you'll need to get Composer.

Once you've setup your project to use Composer, just add a reference to our package with whichever version you'd like to use to your composer.json file.

require: "microsoft/application-insights": "*"

Make sure you add the require statement to pull in the library:

require_once 'vendor/autoload.php';

Usage

Once installed, you can send telemetry to Application Insights. Here are a few samples.

Note: before you can send data to you will need an instrumentation key. Please see the Getting an Application Insights Instrumentation Key section for more information.

Initializing the client and setting the instrumentation key

$telemetryClient = new \ApplicationInsights\Telemetry_Client();
$telemetryClient->getContext()->setInstrumentationKey('YOUR INSTRUMENTATION KEY');
$telemetryClient->trackEvent('name of your event');
$telemetryClient->flush();

Sending a simple event telemetry item with event name

$telemetryClient->trackEvent('name of your event');
$telemetryClient->flush();

Sending an event telemetry item with custom properties and measurements

$telemetryClient->trackEvent('name of your event', ['MyCustomProperty' => 42, 'MyCustomProperty2' => 'test'], ['duration', 42]);
$telemetryClient->flush();

Sending more than one telemetry item before sending to the service is also supported; the API will batch everything until you call flush()

$telemetryClient->trackEvent('name of your event');
$telemetryClient->trackEvent('name of your second event');
$telemetryClient->flush();

Sending a simple page view telemetry item with page name and url

$telemetryClient->trackPageView('myPageView', 'http://www.foo.com');
$telemetryClient->flush();

Sending a page view telemetry item with duration, custom properties and measurements

$telemetryClient->trackPageView('myPageView', 'http://www.foo.com', 256, ['InlineProperty' => 'test_value'], ['duration' => 42.0]);
$telemetryClient->flush();

Sending a simple metric telemetry item with metric name and value*

$telemetryClient->trackMetric('myMetric', 42.0);
$telemetryClient->flush();

Sending a metric telemetry item with point type, count, min, max, standard deviation and measurements

$telemetryClient->trackMetric('myMetric', 42.0, \ApplicationInsights\Channel\Contracts\Data_Point_Type::Aggregation, 5, 0, 1, 0.2, ['InlineProperty' => 'test_value']);
$telemetryClient->flush();

Sending a simple message telemetry item with message*

$telemetryClient->trackMessage('myMessage', \ApplicationInsights\Channel\Contracts\Message_Severity_Level::INFORMATION, ['InlineProperty' => 'test_value']);
$telemetryClient->flush();

Sending a simple request telemetry item with request name, url and start time*

$telemetryClient->trackRequest('myRequest', 'http://foo.bar', time());
$telemetryClient->flush();

Sending a request telemetry item with duration, http status code, whether or not the request succeeded, custom properties and measurements

$telemetryClient->trackRequest('myRequest', 'http://foo.bar', time(), 3754, 200, true, ['InlineProperty' => 'test_value'], ['duration_inner' => 42.0]);
$telemetryClient->flush();

Sending an exception telemetry, with custom properties and metrics

try
{
    // Do something to throw an exception
}
catch (\Exception $ex)
{
    $telemetryClient->trackException($ex, ['InlineProperty' => 'test_value'], ['duration_inner' => 42.0]);
	$telemetryClient->flush();
}

Registering an exception handler

class Handle_Exceptions
{
    private $_telemetryClient;

    public function __construct()
    {
        $this->_telemetryClient = new \ApplicationInsights\Telemetry_Client();
		$this->_telemetryClient->getContext()->setInstrumentationKey('YOUR INSTRUMENTATION KEY');

        set_exception_handler(array($this, 'exceptionHandler'));
    }

    function exceptionHandler(\Exception $exception)
    {
        if ($exception != NULL)
        {
            $this->_telemetryClient->trackException($exception);
            $this->_telemetryClient->flush();
        }
    }
}

Sending a successful SQL dependency telemetry item

$telemetryClient->trackDependency('MySQL', \ApplicationInsights\Channel\Contracts\Dependency_Type::OTHER, 'SELECT * FROM table;', time(), 122, true);
$telemetryClient->flush();

Sending a failed HTTP dependency telemetry item

$telemetryClient->trackDependency('http://example.com/api/method', \ApplicationInsights\Channel\Contracts\Dependency_Type::HTTP, null, time(), 324, false, 503);
$telemetryClient->flush();

Sending any other kind dependency telemetry item

$telemetryClient->trackDependency('Whatever Service', \ApplicationInsights\Channel\Contracts\Dependency_Type::OTHER, 'Service Command', time(), 23, true);
$telemetryClient->flush();