Skip to main content

OpenObserve client for Python

Project description

python-openobserve

Actions Status - Main PyPI Downloads Documentation build status OpenSSF Scorecard

A python connector to interact with OpenObserve (https://github.com/openobserve/openobserve) be it sending data, searching, or exporting/importing settings.

The idea is to have a similar python connector to the "Elasticsearch" package, which allows a 1:1 replacement of the "Elasticsearch" package with the "OpenObserve" package.

OpenObserve is way more lightweight than Elasticsearch, and it is open source, like everything should be.

install

pip install python-openobserve

usage

see example.ipynb for a full example

from python_openobserve.openobserve import OpenObserve

OO = OpenObserve(user = "root@example.com", password = "Complexpass#123")

from datetime import datetime
from random import random
from pprint import pprint
document = {
    "@timestamp" : datetime.utcnow(),
    "component" : "testagent",
    "action" : "buy",
    "amount" : random() * 100,
    "portfolio" : {
        "USD" : random() * 100.0,
        "BTC" : 0.1 + random() * 0.1
    }
}
pprint(document)

# insert document
OO.index("dd", document)

#search
# example sql parsing helper
sql = 'SELECT * FROM "dd"'
results = OO.search(sql, days=1)
print(f"got {len(results)} results")
pprint(results)

OO = OpenObserve(host="https://o2.example.com", user="root@example.com", password="Complexpass#123")
sql = 'SELECT log_file_name,count(*) FROM "default" GROUP BY log_file_name'
start_timeperiod = datetime.now() - timedelta(days=7)
end_timeperiod = datetime.now()
df_search_results = oo_conn.search2df(
    sql,
    start_time=start_timeperiod,
    end_time=end_timeperiod,
    verbosity=5,
)

# Export settings in split json, csv, or xlsx
OO.config_export(f"{tmpdir}/", verbosity=0, split=True)
OO.config_export(f"{tmpdir}/", verbosity=0, outformat="csv")
OO.config_export(f"{tmpdir}/", verbosity=0, outformat="xlsx")

Troubleshooting

If you have issues, try:

  • increase verbosity
  • reproduce issue with curl directly
  • check known issues

Known issues

There are notable gaps and inconsistence in openobserve API at Q2 2025. Check against documentation and swagger. Report API issues upstream.

  • folder_id in alerts creation is ignored
  • API field names are variable (id, alert_id)
  • API returns are inconsistent (use folderId at alert creation but get folder name at alert listing)

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

python_openobserve-0.5.0.tar.gz (31.2 kB view details)

Uploaded Source

Built Distribution

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

python_openobserve-0.5.0-py3-none-any.whl (34.8 kB view details)

Uploaded Python 3

File details

Details for the file python_openobserve-0.5.0.tar.gz.

File metadata

  • Download URL: python_openobserve-0.5.0.tar.gz
  • Upload date:
  • Size: 31.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for python_openobserve-0.5.0.tar.gz
Algorithm Hash digest
SHA256 8cbffb316db53d2a4bca21a6b99cb73ed902652f0d2d399af954e1d52297f982
MD5 ad59ad9dd0486c19601b220053addaf8
BLAKE2b-256 20dcda5f2627a38d1058161cbb1eb5057d85d327ef6f490edb4f304189bd051e

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_openobserve-0.5.0.tar.gz:

Publisher: python-publish.yml on JustinGuese/python-openobserve

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file python_openobserve-0.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for python_openobserve-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7d127dd3ea4f0c4957e0a4062d7d50968ebc1054f9cd4d612b99d060e5a1a136
MD5 948767673f528ddfecca078248b93e62
BLAKE2b-256 aba45ae1fe66f0b18dcc144fdf3d0662180f27e3a0b19c86fa9d86a5fed832be

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_openobserve-0.5.0-py3-none-any.whl:

Publisher: python-publish.yml on JustinGuese/python-openobserve

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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