# 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"
}