tail-jsonl


Nametail-jsonl JSON
Version 1.2.5 PyPI version JSON
download
home_pagehttps://github.com/kyleking/tail-jsonl
SummaryPretty Print Tailed JSONL Logs
upload_time2023-07-23 22:45:03
maintainer
docs_urlNone
authorKyle King
requires_python>=3.8.12,<4.0.0
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # tail-jsonl

Tail JSONL Logs

## Background

I wanted to find a tool that could:

1. Convert a stream of JSONL logs into a readable `logfmt`-like output with minimal configuration
1. Show exceptions on their own line

I investigated a lot of alternatives such as: [humanlog](https://github.com/humanlogio/humanlog), [lnav](https://docs.lnav.org/en/latest/formats.html#), [goaccess](https://goaccess.io/get-started), [angle-grinder](https://github.com/rcoh/angle-grinder#rendering), [jq](https://github.com/stedolan/jq), [textualog](https://github.com/rhuygen/textualog), etc. but nothing would both cleanly format the JSONL data and show the exception.

![.github/assets/demo.gif](https://raw.githubusercontent.com/KyleKing/tail-jsonl/main/.github/assets/demo.gif)

## Installation

[Install with `pipx`](https://pypi.org/project/pipx/)

```sh
pipx install tail-jsonl
```

## Usage

Pipe JSONL output from any file, kubernetes (such as [stern](https://github.com/stern/stern)), Docker, etc.

```sh
# Example piping input in shell
echo '{"message": "message", "timestamp": "2023-01-01T01:01:01.0123456Z", "level": "debug", "data": true, "more-data": [null, true, -123.123]}' | tail-jsonl
cat tests/data/logs.jsonl | tail-jsonl

# Optionally, pre-filter or format with jq, grep, awk, or other tools
cat tests/data/logs.jsonl | jq '.record' --compact-output | tail-jsonl

# An example stern command (also consider -o=extjson)
stern envvars --context staging --container gateway --since="60m" --output raw | tail-jsonl

# Or with Docker Compose (note that awk, cut, and grep all buffer. For awk, add '; system("")')
docker compose logs --follow | awk 'match($0, / \| \{.+/) { print substr($0, RSTART+3, RLENGTH); system("") }' | tail-jsonl
```

## Configuration

Optionally, specify a path to a custom configuration file. See an example configuration file at: [tests/config_default.toml](https://github.com/KyleKing/tail-jsonl/blob/main/tests/config_default.toml)

```sh
echo '...' | tail-jsonl --config-path=~/.tail-jsonl.toml
```

## Project Status

See the `Open Issues` and/or the [CODE_TAG_SUMMARY]. For release history, see the [CHANGELOG].

## Contributing

We welcome pull requests! For your pull request to be accepted smoothly, we suggest that you first open a GitHub issue to discuss your idea. For resources on getting started with the code base, see the below documentation:

- [DEVELOPER_GUIDE]
- [STYLE_GUIDE]

## Code of Conduct

We follow the [Contributor Covenant Code of Conduct][contributor-covenant].

### Open Source Status

We try to reasonably meet most aspects of the "OpenSSF scorecard" from [Open Source Insights](https://deps.dev/pypi/tail-jsonl)

## Responsible Disclosure

If you have any security issue to report, please contact the project maintainers privately. You can reach us at [dev.act.kyle@gmail.com](mailto:dev.act.kyle@gmail.com).

## License

[LICENSE]

[changelog]: https://tail-jsonl.kyleking.me/docs/CHANGELOG
[code_tag_summary]: https://tail-jsonl.kyleking.me/docs/CODE_TAG_SUMMARY
[contributor-covenant]: https://www.contributor-covenant.org
[developer_guide]: https://tail-jsonl.kyleking.me/docs/DEVELOPER_GUIDE
[license]: https://github.com/kyleking/tail-jsonl/blob/main/LICENSE
[style_guide]: https://tail-jsonl.kyleking.me/docs/STYLE_GUIDE

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/kyleking/tail-jsonl",
    "name": "tail-jsonl",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.8.12,<4.0.0",
    "maintainer_email": "",
    "keywords": "",
    "author": "Kyle King",
    "author_email": "dev.act.kyle@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/65/48/2b14d261253eeb1216c9b5b0336c9711cf11385ba3bf02db723ca53146ce/tail_jsonl-1.2.5.tar.gz",
    "platform": null,
    "description": "# tail-jsonl\n\nTail JSONL Logs\n\n## Background\n\nI wanted to find a tool that could:\n\n1. Convert a stream of JSONL logs into a readable `logfmt`-like output with minimal configuration\n1. Show exceptions on their own line\n\nI investigated a lot of alternatives such as: [humanlog](https://github.com/humanlogio/humanlog), [lnav](https://docs.lnav.org/en/latest/formats.html#), [goaccess](https://goaccess.io/get-started), [angle-grinder](https://github.com/rcoh/angle-grinder#rendering), [jq](https://github.com/stedolan/jq), [textualog](https://github.com/rhuygen/textualog), etc. but nothing would both cleanly format the JSONL data and show the exception.\n\n![.github/assets/demo.gif](https://raw.githubusercontent.com/KyleKing/tail-jsonl/main/.github/assets/demo.gif)\n\n## Installation\n\n[Install with `pipx`](https://pypi.org/project/pipx/)\n\n```sh\npipx install tail-jsonl\n```\n\n## Usage\n\nPipe JSONL output from any file, kubernetes (such as [stern](https://github.com/stern/stern)), Docker, etc.\n\n```sh\n# Example piping input in shell\necho '{\"message\": \"message\", \"timestamp\": \"2023-01-01T01:01:01.0123456Z\", \"level\": \"debug\", \"data\": true, \"more-data\": [null, true, -123.123]}' | tail-jsonl\ncat tests/data/logs.jsonl | tail-jsonl\n\n# Optionally, pre-filter or format with jq, grep, awk, or other tools\ncat tests/data/logs.jsonl | jq '.record' --compact-output | tail-jsonl\n\n# An example stern command (also consider -o=extjson)\nstern envvars --context staging --container gateway --since=\"60m\" --output raw | tail-jsonl\n\n# Or with Docker Compose (note that awk, cut, and grep all buffer. For awk, add '; system(\"\")')\ndocker compose logs --follow | awk 'match($0, / \\| \\{.+/) { print substr($0, RSTART+3, RLENGTH); system(\"\") }' | tail-jsonl\n```\n\n## Configuration\n\nOptionally, specify a path to a custom configuration file. See an example configuration file at: [tests/config_default.toml](https://github.com/KyleKing/tail-jsonl/blob/main/tests/config_default.toml)\n\n```sh\necho '...' | tail-jsonl --config-path=~/.tail-jsonl.toml\n```\n\n## Project Status\n\nSee the `Open Issues` and/or the [CODE_TAG_SUMMARY]. For release history, see the [CHANGELOG].\n\n## Contributing\n\nWe welcome pull requests! For your pull request to be accepted smoothly, we suggest that you first open a GitHub issue to discuss your idea. For resources on getting started with the code base, see the below documentation:\n\n- [DEVELOPER_GUIDE]\n- [STYLE_GUIDE]\n\n## Code of Conduct\n\nWe follow the [Contributor Covenant Code of Conduct][contributor-covenant].\n\n### Open Source Status\n\nWe try to reasonably meet most aspects of the \"OpenSSF scorecard\" from [Open Source Insights](https://deps.dev/pypi/tail-jsonl)\n\n## Responsible Disclosure\n\nIf you have any security issue to report, please contact the project maintainers privately. You can reach us at [dev.act.kyle@gmail.com](mailto:dev.act.kyle@gmail.com).\n\n## License\n\n[LICENSE]\n\n[changelog]: https://tail-jsonl.kyleking.me/docs/CHANGELOG\n[code_tag_summary]: https://tail-jsonl.kyleking.me/docs/CODE_TAG_SUMMARY\n[contributor-covenant]: https://www.contributor-covenant.org\n[developer_guide]: https://tail-jsonl.kyleking.me/docs/DEVELOPER_GUIDE\n[license]: https://github.com/kyleking/tail-jsonl/blob/main/LICENSE\n[style_guide]: https://tail-jsonl.kyleking.me/docs/STYLE_GUIDE\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Pretty Print Tailed JSONL Logs",
    "version": "1.2.5",
    "project_urls": {
        "Bug Tracker": "https://github.com/kyleking/tail-jsonl/issues",
        "Changelog": "https://github.com/kyleking/tail-jsonl/blob/main/docs/docs/CHANGELOG.md",
        "Documentation": "https://tail-jsonl.kyleking.me",
        "Homepage": "https://github.com/kyleking/tail-jsonl",
        "Repository": "https://github.com/kyleking/tail-jsonl"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "b9124efc1ed20d8dcbb920ab543f071fbdc9b589abae86ca0fca6ec9bc5a35f3",
                "md5": "2fd9ec1dfbbba5fc078fe830d3d5b51d",
                "sha256": "67576612d52bd3eb551a5e2f821d537d24bfbb86843f3ee1a9dbb9506b6c58c3"
            },
            "downloads": -1,
            "filename": "tail_jsonl-1.2.5-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "2fd9ec1dfbbba5fc078fe830d3d5b51d",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8.12,<4.0.0",
            "size": 7478,
            "upload_time": "2023-07-23T22:45:01",
            "upload_time_iso_8601": "2023-07-23T22:45:01.738328Z",
            "url": "https://files.pythonhosted.org/packages/b9/12/4efc1ed20d8dcbb920ab543f071fbdc9b589abae86ca0fca6ec9bc5a35f3/tail_jsonl-1.2.5-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "65482b14d261253eeb1216c9b5b0336c9711cf11385ba3bf02db723ca53146ce",
                "md5": "279e0a7365abe53c31b51dd8ed9e0aee",
                "sha256": "d1dd05a1fceac6eae23c07a95745efaf1a451a691343eadf42029d4b16e62787"
            },
            "downloads": -1,
            "filename": "tail_jsonl-1.2.5.tar.gz",
            "has_sig": false,
            "md5_digest": "279e0a7365abe53c31b51dd8ed9e0aee",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8.12,<4.0.0",
            "size": 5554,
            "upload_time": "2023-07-23T22:45:03",
            "upload_time_iso_8601": "2023-07-23T22:45:03.744350Z",
            "url": "https://files.pythonhosted.org/packages/65/48/2b14d261253eeb1216c9b5b0336c9711cf11385ba3bf02db723ca53146ce/tail_jsonl-1.2.5.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-07-23 22:45:03",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "kyleking",
    "github_project": "tail-jsonl",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "tail-jsonl"
}
        
Elapsed time: 0.09928s