Skip to main content

LoongSuite QwenPaw Instrumentation

Project description

LoongSuite QwenPaw Instrumentation

LoongSuite instrumentation for QwenPaw, a personal assistant built on AgentScope.

Compatibility note: CoPaw was renamed to QwenPaw. Installations pinned to copaw<=1.0.2 are still supported during the transition.

Getting Started

QwenPaw is started as its own app (CLI / process entrypoint), not as a library you embed with a few lines of python your_script.py. The practical approach is to install QwenPaw, enable LoongSuite Site-bootstrap so instrumentation loads before the app imports run, then start it with qwenpaw app.

Step 1 — Install QwenPaw

pip install qwenpaw

Step 2 — Site-bootstrap

Site-bootstrap installs a .pth hook under site-packages so a small bootstrap module runs very early in the interpreter, before the app imports. That path applies the same OpenTelemetry auto-instrumentation as loongsuite-instrument / sitecustomize, so you do not edit QwenPaw source or wrap the CLI in a custom launcher. Installing loongsuite-site-bootstrap does not install instrumentations by itself; pair it with loongsuite-bootstrap (or equivalent pip install of the packages you need).

2.1 — Install loongsuite-site-bootstrap

pip install loongsuite-site-bootstrap

2.2 — Install instrumentations (including this package)

pip install loongsuite-instrumentation-qwenpaw loongsuite-instrumentation-agentscope

2.3 — Enable the hook

In every shell or service manager that starts QwenPaw, set:

export LOONGSUITE_PYTHON_SITE_BOOTSTRAP=True

The value is treated case-insensitively as on/off (True enables). You can also put "LOONGSUITE_PYTHON_SITE_BOOTSTRAP": "true" in bootstrap-config.json (see below); environment variables take precedence over the file for any key that is already set in the process.

2.4 — Configure export via ~/.loongsuite/bootstrap-config.json

Create the directory and file if needed. The JSON root must be an object; string keys; values are applied to os.environ with setdefault semantics so already-set environment variables are never overwritten by the file.

Example for OTLP/gRPC (adjust host, port, and service name):

{
  "OTEL_SERVICE_NAME": "qwenpaw",
  "OTEL_EXPORTER_OTLP_PROTOCOL": "grpc",
  "OTEL_EXPORTER_OTLP_ENDPOINT": "http://127.0.0.1:4317",
  "OTEL_TRACES_EXPORTER": "otlp",
  "OTEL_METRICS_EXPORTER": "otlp"
}

Example for quick local debugging with console exporters:

{
  "OTEL_SERVICE_NAME": "qwenpaw",
  "OTEL_TRACES_EXPORTER": "console",
  "OTEL_METRICS_EXPORTER": "console"
}

After a successful run you should see a line on stdout such as: loongsuite-site-bootstrap: started successfully (OpenTelemetry auto-instrumentation initialized). Do not start Python with python -S (that disables site and .pth processing).

Beta / scope: With the hook enabled, every Python process in that environment that imports site may load the bootstrap—not only qwenpaw app. Use a dedicated virtual environment for production if you need isolation.

Step 3 — Run QwenPaw

With Site-bootstrap enabled in the same shell/session, start the app as usual:

qwenpaw app

Telemetry for AgentRunner.query_handler (Entry span) is then active without modifying QwenPaw source code.

Optional: programmatic hook

If you control an embedding process and prefer not to use site-bootstrap, you can call QwenPawInstrumentor().instrument() (and uninstrument() when done) before QwenPaw runs in that process—the hook point is still AgentRunner.query_handler. You must still configure the global TracerProvider / export (for example via OpenTelemetry env vars) consistently with the rest of your app.

What this package instruments

When you enable LoongSuite for QwenPaw, each user or channel “turn” that goes through the app conversation runner produces one application Entry trace for that turn (span name enter_ai_application_system). It covers the full path on the app side—approval, built-in commands, or a normal agent run—not only the LLM call inside the agent.

Recorded on that span (when the data is available):

  • Operation: entry into the AI application (gen_ai.operation.name=enter, gen_ai.span.kind=ENTRY).
  • Streaming: time from the start of the turn to the first streamed chunk (gen_ai.response.time_to_first_token, in nanoseconds).
  • Identity / routing: session id (gen_ai.session.id), user id (gen_ai.user.id), QwenPaw agent id (qwenpaw.agent_id), channel (qwenpaw.channel).

Compatibility note: the instrumentation also emits legacy copaw.* attributes during the transition so existing dashboards and processors do not break immediately.

Calls to models, tools, and other AgentScope primitives are not duplicated here: use AgentScope (and your existing model client) instrumentations alongside this package so they appear as child spans under this entry when configured.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file loongsuite_instrumentation_qwenpaw-0.6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for loongsuite_instrumentation_qwenpaw-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b527e56ca40f5bc67f6f93d4137f1c94a97a7daffdb0e5d47156f29c68ed6686
MD5 fe0b5687ddb7a9ef93cd163175168c68
BLAKE2b-256 a89f1b11e3c92a352938b4451eaae616d84ab2b94b212d595b78f5ae6c017d83

See more details on using hashes here.

Supported by

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