2017 © Pedro Peláez
 

library xray

A basic PHP instrumentation library for AWS X-Ray

image

pkerrigan/xray

A basic PHP instrumentation library for AWS X-Ray

  • Friday, July 13, 2018
  • by patrickkerrigan
  • Repository
  • 1 Watchers
  • 1 Stars
  • 103 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 5 Versions
  • 232 % Grown

The README.md

Build Status Maintainability Test Coverage PHP >=7.1 Packagist, (*1)

pkerrigan\xray

A basic PHP instrumentation library for AWS X-Ray, (*2)

Until Amazon releases an official PHP SDK for AWS X-Ray this library allows you to add basic instrumentation to PHP applications and report traces via the AWS X-Ray daemon., (*3)

Please note that no automatic instrumentation of popular libraries is provided. In order to instrument SQL queries, HTTP requests and/or other services you'll be required to create your own wrappers which start and end tracing segments as appropriate., (*4)

Installation

The recommended way to install this library is using Composer:, (*5)

$ composer require pkerrigan/xray ^1

Usage

Starting a trace

The Trace class represents the top-level of an AWS X-Ray trace, and can function as a singleton for easy access from anywhere in your code, including before frameworks and dependency injectors have been initialised., (*6)

You should start a trace as early as possible in your request:, (*7)

use Pkerrigan\Xray\Trace;

Trace::getInstance()
    ->setTraceHeader($_SERVER['HTTP_X_AMZN_TRACE_ID'] ?? null)
    ->setName('app.example.com')
    ->setUrl($_SERVER['REQUEST_URI'])
    ->setMethod($_SERVER['REQUEST_METHOD'])
    ->begin(); 

Adding a segment to a trace

You can add as many segments to your trace as necessary, including nested segments. To add an SQL query to your trace, you'd do the following:, (*8)

Trace::getInstance()
    ->getCurrentSegment()
    ->addSubsegment(
        (new SqlSegment())
            ->setName('db.example.com')
            ->setDatabaseType('PostgreSQL')
            ->setQuery($mySanitisedQuery)    // Make sure to remove sensitive data before passing in a query
            ->begin()    
    );


// Run your query here

Trace::getInstance()
    ->getCurrentSegment()
    ->end();

The getCurrentSegment() method will always return the most recently opened segment, allowing you to nest as deeply as necessary., (*9)

Ending a trace

At the end of your request, you'll want to end and submit your trace. By default only submitting via the AWS X-Ray daemon is supported., (*10)

Trace::getInstance()
    ->end()
    ->setResponseCode(http_response_code())
    ->submit(new DaemonSegmentSubmitter());

Features not yet implemented

  • Exception and stack trace support
  • Submission of incomplete segments

The Versions

13/07 2018

dev-master

9999999-dev

A basic PHP instrumentation library for AWS X-Ray

  Sources   Download

BSD-3-Clause

The Requires

  • php >=7.0
  • ext-json *

 

The Development Requires

aws apm tracing x-ray aws x-ray

13/07 2018

v1.1.0

1.1.0.0

A basic PHP instrumentation library for AWS X-Ray

  Sources   Download

BSD-3-Clause

The Requires

  • php >=7.0
  • ext-json *

 

The Development Requires

aws apm tracing x-ray aws x-ray

01/06 2018

v1.0.1

1.0.1.0

A basic PHP instrumentation library for AWS X-Ray

  Sources   Download

BSD-3-Clause

The Requires

  • php >=7.0
  • ext-json *

 

The Development Requires

aws apm tracing x-ray aws x-ray

01/06 2018

dev-fragment-long-traces

dev-fragment-long-traces

A basic PHP instrumentation library for AWS X-Ray

  Sources   Download

BSD-3-Clause

The Requires

  • php >=7.0
  • ext-json *

 

The Development Requires

aws apm tracing x-ray aws x-ray

19/05 2018

v1.0.0

1.0.0.0

A basic PHP instrumentation library for AWS X-Ray

  Sources   Download

BSD-3-Clause

The Requires

  • php >=7.0
  • ext-json *

 

The Development Requires

aws apm tracing x-ray aws x-ray