All Projects → microsoft → Applicationinsights Php

microsoft / Applicationinsights Php

Licence: other
Azure Application Insights SDK for PHP

Projects that are alternatives of or similar to Applicationinsights Php

Applicationinsights Home
Application Insights main repository for documentation of overall SDK offerings for all platforms.
Stars: ✭ 221 (+125.51%)
Mutual labels:  azure, sdk, monitoring, logging, distributed-tracing, telemetry, application-insights
Applicationinsights Dotnet
ApplicationInsights-dotnet
Stars: ✭ 367 (+274.49%)
Mutual labels:  azure, sdk, monitoring, logging, distributed-tracing, telemetry, application-insights
Applicationinsights Dotnet Server
Microsoft Application Insights for .NET Web Applications
Stars: ✭ 130 (+32.65%)
Mutual labels:  azure, sdk, monitoring, distributed-tracing, telemetry, application-insights
Applicationinsights Dotnet Logging
.NET Logging adaptors
Stars: ✭ 100 (+2.04%)
Mutual labels:  azure, sdk, monitoring, logging, telemetry, application-insights
Applicationinsights Go
Microsoft Application Insights SDK for Go
Stars: ✭ 113 (+15.31%)
Mutual labels:  azure, monitoring, logging, distributed-tracing, telemetry, application-insights
Applicationinsights Python
Application Insights SDK for Python
Stars: ✭ 114 (+16.33%)
Mutual labels:  sdk, monitoring, logging, distributed-tracing, telemetry, application-insights
Applicationinsights Node.js
Microsoft Application Insights SDK for Node.js
Stars: ✭ 229 (+133.67%)
Mutual labels:  azure, sdk, monitoring, logging, distributed-tracing, application-insights
Applicationinsights Java
Application Insights for Java
Stars: ✭ 172 (+75.51%)
Mutual labels:  azure, sdk, monitoring, distributed-tracing, application-insights
Applicationinsights Aspnetcore
ASP.NET Core web applications monitoring
Stars: ✭ 306 (+212.24%)
Mutual labels:  azure, monitoring, distributed-tracing, telemetry, application-insights
Applicationinsights Js
Microsoft Application Insights SDK for JavaScript
Stars: ✭ 462 (+371.43%)
Mutual labels:  azure, sdk, monitoring, application-insights
Opentelemetry Js
OpenTelemetry JavaScript Client
Stars: ✭ 700 (+614.29%)
Mutual labels:  monitoring, distributed-tracing, telemetry
Azuremonitoringhackathon
Operationalize Azure deployments with Azure platform tools​
Stars: ✭ 46 (-53.06%)
Mutual labels:  azure, monitoring, application-insights
Sysmontools
Utilities for Sysmon
Stars: ✭ 903 (+821.43%)
Mutual labels:  monitoring, logging
Logbook
An extensible Java library for HTTP request and response logging
Stars: ✭ 822 (+738.78%)
Mutual labels:  monitoring, logging
Epsagon Go
Automated tracing library for Go 1.x ⚡️
Stars: ✭ 24 (-75.51%)
Mutual labels:  monitoring, distributed-tracing
Azure Grafana Dashboard Templates
Grafana dashboard templates for Azure
Stars: ✭ 31 (-68.37%)
Mutual labels:  azure, monitoring
Dnn.appinsights
A module to use Visual Studio Application Insights with the DNN Platform (formerly DotNetNuke) CMS
Stars: ✭ 12 (-87.76%)
Mutual labels:  monitoring, application-insights
Zmonitor
Azure Multi-subscription/tenant Monitoring Solution
Stars: ✭ 35 (-64.29%)
Mutual labels:  azure, monitoring
Llama Archive
Loss & LAtency MAtrix
Stars: ✭ 44 (-55.1%)
Mutual labels:  monitoring, telemetry
Sentinel Attack
Tools to rapidly deploy a threat hunting capability on Azure Sentinel that leverages Sysmon and MITRE ATT&CK
Stars: ✭ 676 (+589.8%)
Mutual labels:  azure, logging

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.

Status

This SDK is NOT maintained or supported by Microsoft even though we've contributed to it in the past. Note that Azure Monitor only provides support when using the supported SDKs. We’re constantly assessing opportunities to expand our support for other languages, so follow our GitHub Announcements page to receive the latest SDK news.

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": "*"

Or you can use the composer command to automatically add the package to your composer.json file.

composer 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 and other optional configurations

$telemetryClient = new \ApplicationInsights\Telemetry_Client();
$context = $telemetryClient->getContext();

// Necessary
$context->setInstrumentationKey('YOUR INSTRUMENTATION KEY');

// Optional
$context->getSessionContext()->setId(session_id());
$context->getUserContext()->setId('YOUR USER ID');
$context->getApplicationContext()->setVer('YOUR VERSION');
$context->getLocationContext()->setIp('YOUR IP');

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

Setup Operation context

For correct Application Insights reporting you need to setup Operation Context, reference to Request

$telemetryClient->getContext()->getOperationContext()->setId('XX');
$telemetryClient->getContext()->getOperationContext()->setName('GET Index');

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();
}

Set the Client to gzip the data before sending

$telemetryClient->getChannel()->setSendGzipped(true);

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('Query table', "SQL", 'SELECT * FROM table;', time(), 122, true);
$telemetryClient->flush();

Sending a failed HTTP dependency telemetry item

$telemetryClient->trackDependency('method', "HTTP", "http://example.com/api/method", time(), 324, false, 503);
$telemetryClient->flush();

Sending any other kind dependency telemetry item

$telemetryClient->trackDependency('Name of operation', "service", 'Arguments', time(), 23, true);
$telemetryClient->flush();

Changing the operation id (which links actions together)

$telemetryClient->trackMetric('interestingMetric', 10);
$telemetryClient->getContext()->getOperationContext()->setId(\ApplicationInsights\Channel\Contracts\Utils::returnGuid())
$telemetryClient->trackMetric('differentOperationMetric', 11);
$telemetryClient->flush();

Code of conduct

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].