Skip to main content

HiQ - A Modern Observability System

Project description

Documentation Status CodeCov Github release lic

HiQ is a declarative, non-intrusive, dynamic and transparent tracking system for both monolithic application and distributed system. It brings the runtime information tracking and optimization to a new level without compromising with speed and system performance, or hiding any tracking overhead information. HiQ applies for both I/O bound and CPU bound applications.

To explain the four features, declarative means you can declare the things you want to track in a text file, which could be a json, yaml or even csv,and no need to change program code. Non-intrusive means HiQ doesn’t requires to modify original python code. Dynamic means HiQ supports tracing metrics featuring at run time, which can be used for adaptive tracing. Transparent means HiQ provides the tracing overhead and doesn’t hide it no matter it is huge or tiny.

In addition to latency tracking, HiQ provides memory, disk I/O and Network I/O tracking out of the box. The output can be saved in form of normal line by line log file, or HiQ tree, or span graph.

Installation

pip install hiq-python

Get Started

Let start with a simplest example by running HiQ against a simple monolithic python code 📄 main.py:

# this is the main.py python source code
import time

def func1():
    time.sleep(1.5)
    print("func1")
    func2()

def func2():
    time.sleep(2.5)
    print("func2")

def main():
    func1()

if __name__ == "__main__":
    main()

In this code, there is a simple chain of function calls: main() -> func1 -> func2.

Now we want to trace the functions without modifying its code. Let’s run the following:

git clone https://github.com/oracle-samples/hiq.git
cd hiq/examples/quick_start
python main_driver.py

If everything is fine, you should be able to see the output like this:

https://raw.githubusercontent.com/oracle-samples/hiq/main/hiq/docs/source/img/main_driver.jpg

An HiQ Simplest Example

From the screenshot we can see the timestamp and the latency of each function:

main

func1

func2

tracing overhead

latency(second)

4.0045

4.0044

2.5026

0.0000163

HiQ just traced the main.py file running without touching one line of its code.

Documentation

HTML: 🔗 HiQ Online Document, PDF: 🔗 HiQ PDF Document.

Examples

Please check 🔗 examples for usage examples.

Contributing

HiQ welcomes contributions from the community. Before submitting a pull request, please review our 🔗 contribution guide.

Security

Please consult the 🔗 security guide for our responsible security vulnerability disclosure process.

License

Copyright (c) 2022 Oracle and/or its affiliates. Released under the Universal Permissive License v1.0 as shown at https://oss.oracle.com/licenses/upl/.

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

hiq-python-1.0.4.tar.gz (46.3 kB view details)

Uploaded Source

Built Distribution

hiq_python-1.0.4-py3-none-any.whl (54.8 kB view details)

Uploaded Python 3

File details

Details for the file hiq-python-1.0.4.tar.gz.

File metadata

  • Download URL: hiq-python-1.0.4.tar.gz
  • Upload date:
  • Size: 46.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for hiq-python-1.0.4.tar.gz
Algorithm Hash digest
SHA256 3195e56db60b9c2812d2f71f4499d317ce5b8926d052530bb022d3f8d67389e2
MD5 e2472b7803037a0f07cf49ecb010b583
BLAKE2b-256 dcc00331719fb4568d8e397cfb74e541ae6e608e4bfeb4ec428f09db0f112e50

See more details on using hashes here.

File details

Details for the file hiq_python-1.0.4-py3-none-any.whl.

File metadata

  • Download URL: hiq_python-1.0.4-py3-none-any.whl
  • Upload date:
  • Size: 54.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for hiq_python-1.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a472c9e1ff75dcd50c9727d1e4dab63a841aeea66efa639e8e4d3ba3edb410a8
MD5 ed3b559e1285e73564fca1fee2df7596
BLAKE2b-256 31c01a271effe7c15a88507a2f60f8283049bc6a82071779a44d4901e7b9c2fb

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