Fiberplane studio integration with FastAPI
Project description
fpxpy
Provides instrumentation and route detection for FastAPI apps.
Installation
The package is available on PyPy, installing it as simple as
uv add fpxpy
After installing fpxpy either from source or from pip, simply add the second line
referencing your FastAPI app.
from fpxpy import setup
app = FastAPI()
setup(app)
After that, when running your FastAPI server, be sure to set the FPX_ENDPOINT env variable
pointing to your instance of Fiberplane Studio, e.g:
$ FPX_ENDPOINT=http://localhost:8788/v1/traces uv run fastapi dev main.py
If you don't specify this environment variable, the library will not be enabled.
API
The package exports two functions:
setupwhich is used for adding middleware to the FastAPI appmeasurewhich is used for creating spans each time a function is called. Typically used as a decorator.
setup
Function
Initializes FPX instrumentation for a FastAPI application by configuring route detection and span instrumentation.
Parameters
- app (
FastAPI): The FastAPI application instance that was instrumented
Returns
FastAPI: The instrumented application instance
Environment Variables
FPX_ENDPOINT: Required. The endpoint URL for FPX instrumentation
Example Usage
from fastapi import FastAPI
from fpxpy import setup
app = FastAPI()
setup(app)
Behavior
- Checks for
FPX_ENDPOINTenvironment variable - If not set:
- Prints warning message
- Returns unmodified app
- If set:
- Installs route detection
- Configures span instrumentation with parsed URL
- Returns instrumented app
Notes
- Must be called after FastAPI app creation
- Requires
FPX_ENDPOINTenvironment variable - Modifies app in-place by adding middleware and route handlers
Measure
A decorator that wraps functions with OpenTelemetry span instrumentation to measure execution time and track errors.
Usage
Basic Usage:
from fpxpy import measure
from opentelemetry.trace import SpanKind
@measure()
def my_function():
return "Hello World"
@measure("custom-name")
def named_function():
return "Hello Named World"
With Custom Span Configuration:
@measure(
name="db-query",
span_kind=SpanKind.CLIENT,
attributes={"db.system": "postgresql"}
)
async def query_database():
# ... database code
pass
With Callbacks:
def on_start_cb(span, *args, **kwargs):
span.set_attribute("custom.start", "started")
@measure(
name="monitored-function",
on_start=on_start_cb,
on_success=lambda span, result: span.set_attribute("result.value", str(result)),
on_error=lambda span, exc: span.set_attribute("error.message", str(exc))
)
def monitored_function():
pass
Parameters
- name (
Optional[str]): Name of the span. Defaults to the function name if not provided. - func (
Optional[Callable]): Function to wrap. Used internally by the decorator. - span_kind (
SpanKind): Kind of span to create. Defaults toSpanKind.INTERNAL - on_start (
Optional[Callable]): Callback executed when span starts. Receives span and function arguments. - on_success(
Optional[Callable]): Callback executed on successful completion. Receives span and function result. - on_error (
Optional[Callable]): Callback executed on error. Receives span and exception. - check_result (
Optional[Callable]): Optional validation function for the result. - attributes (
Optional[Dict]): Initial attributes to set on the span.
Returns
Returns a wrapped function that:
- Creates a new span when called
- Executes the original function
- Records success/failure in the span
- Supports both sync and async functions
Notes
- Automatically handles both synchronous and asynchronous functions
- Preserves function signatures and docstrings
- Supports direct function decoration and configuration via parameters
- Integrates with OpenTelemetry context propagation
- Thread-safe and context-manager compatible
Examples
Track Database Queries:
@measure(
name="db-query",
span_kind=SpanKind.CLIENT,
attributes={"db.system": "postgresql"}
)
async def get_user(user_id: str):
# ... database code
pass
Monitor HTTP Requests
@measure(
name="http-request",
span_kind=SpanKind.CLIENT,
attributes={"http.method": "GET"}
)
async def fetch_data(url: str):
# ... http request code
pass
Track Function Performance
@measure(
name="expensive-calculation",
attributes={"calculation.type": "matrix-multiply"}
)
def matrix_multiply(a: np.ndarray, b: np.ndarray):
# ... calculation code
pass
Example application
We also have an example application that can be found under /examples/python-fastapi
Development
This package uses uv for its dependencies and running the tooling. The following tools are used for linting, checking & formatting. They are listed as part of the dev dependencies (and will be installed by uv by default).
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file fpxpy-0.3.4.tar.gz.
File metadata
- Download URL: fpxpy-0.3.4.tar.gz
- Upload date:
- Size: 51.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d6c5a65f0ad083a174d4004aa3c3c9fda0f7fff3c8b69d3d46a72e36adfe0a16
|
|
| MD5 |
30ba31372bfb5e7c89de3d7c9d172450
|
|
| BLAKE2b-256 |
2ddfeebb59f902fea3674a1e7db56ab6ea51e889f98557db035a6b1b725abfeb
|
File details
Details for the file fpxpy-0.3.4-py3-none-any.whl.
File metadata
- Download URL: fpxpy-0.3.4-py3-none-any.whl
- Upload date:
- Size: 16.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
56969ec3534f564417121a212fe514d0049be0dd14835672ed1f436c0a3a5cdc
|
|
| MD5 |
c3949c78b124db5547990041598be457
|
|
| BLAKE2b-256 |
aa64e473832ab901de52603a4cab4f76d160af805129950e57cdc3e23901f500
|