Skip to main content

No project description provided

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.4.0.tar.gz (30.5 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.4.0-py3-none-any.whl (34.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: python_openobserve-0.4.0.tar.gz
  • Upload date:
  • Size: 30.5 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.4.0.tar.gz
Algorithm Hash digest
SHA256 0ccc33629eca4b74b7017c93c160f3f47b05761ca417e09bf0409c7349d2d50c
MD5 a588014ee024fb29eaf028db981896fa
BLAKE2b-256 8002433163d5da872c19652ba1cbf9d31a68dc62f3229cc5ac1a844071f9c079

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_openobserve-0.4.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.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for python_openobserve-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 37c709a8fa9f406fd1a6652db721a5c314e9a973a322664d80cd66d7407bc563
MD5 8b257fc99acac54ac29040864e06c893
BLAKE2b-256 822b1149d5726d49741d21d4d89ac693ff35f5343ef4755028272f6289baa5a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_openobserve-0.4.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