Skip to main content

tracing for insanic

Project description

https://github.com/crazytruth/incendiary/raw/master/artwork/incendiary.jpg

Incendiary

Build Status Documentation Status Codecov

PyPI pyversions PyPI version PyPI license Black

A Tracing extension for Insanic that integrates AWS X-Ray.

Why?

Tracing is needed in any micro service architecture, and this plugin traces requests received and traces any requests with Insanic’s interservice’s communications and sends it’s traced information to AWS X-Ray.

You might be asking why this package is called incendiary. In the military there, rifles and machine guns are usually loaded with tracer rounds every 3-4 rounds which help adjust for aim. And tracer rounds usually have a mild “incendiary” effect to help with visibility.

Tracing is a distributed system also samples(every X request) to help with overall visibility of the system.

Features

  • Tracing with AWS X-ray.

  • Creates a segment when Insanic receives a request.

  • End the segment before return the response.

  • Sampling configuration

  • Starts and ends subsegments for interservice requests with Insanic.

  • Capture other parts of your code.

Installation

Prerequisites for using:

  • python >= 3.6

  • Local running instance of AWS X-Ray Daemon. (Running instructions can be found here)

  • AWS Credentials (if you want to actually send data to AWS-Ray)

To install:

pip install insanic-incendiary

Basic Usage

Basic usage is actually quite simple. You should be able to get it running without any extra configurations.

To Initialize

# app.py

...

from insanic import Insanic
from incendiary import Incendiary

app = Insanic("my_app", version="0.1.0")
Incendiary.init_app(app)

Now if you run, you should be able to start tracing.

To Capture

# in_some_module_you_want_to_capture.py

from incendiary import Incendiary

# if async function

@Incendiary.capture_async(name="Name of subsegment")
async def i_want_to_capture_async():
    pass

# if sync function

@Incendiary.capture(name="Name of subsegment")
def i_want_to_capture():
    pass

These functions will be its own subsegments in X-Ray.

For more information please refer to Incendiary’s Documentation.

Release History

View release history

Contributing

For guidance on setting up a development environment and how to make a contribution to Incendiary, see the CONTRIBUTING.rst guidelines.

Meta

Distributed under the MIT license. See LICENSE for more information.

Thanks to all the people at my prior company that worked with me to make this possible.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

insanic-incendiary-0.2.0.tar.gz (45.2 kB view details)

Uploaded Source

Built Distribution

insanic_incendiary-0.2.0-py3-none-any.whl (15.6 kB view details)

Uploaded Python 3

File details

Details for the file insanic-incendiary-0.2.0.tar.gz.

File metadata

  • Download URL: insanic-incendiary-0.2.0.tar.gz
  • Upload date:
  • Size: 45.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/28.8.0 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.6.1

File hashes

Hashes for insanic-incendiary-0.2.0.tar.gz
Algorithm Hash digest
SHA256 4e98c03243a5a946d647b01d367681a3c5f12649e85e21efa765a4f19491b221
MD5 df9fa28264764ef76bcabb32a6ce872f
BLAKE2b-256 c0da1172dc3bac19e4e18e30934f80ac38084d40d123e06c2938a29115a80ea7

See more details on using hashes here.

File details

Details for the file insanic_incendiary-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: insanic_incendiary-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 15.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/28.8.0 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.6.1

File hashes

Hashes for insanic_incendiary-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6a485304fc33bf2f871624c756874e0061ab8dd82457a8bd596fe2b946a35846
MD5 3f6a25084a4c9b2ff5a5f34e5e04f4a6
BLAKE2b-256 d18100306fc9004c6077eb2572cdc29618ba295f9dd5e8da52408f033b74da13

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page