Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ugosan/logshark
Logshark is a debugger CLI for JSON logs written in Go
https://github.com/ugosan/logshark
filebeat json logstash
Last synced: about 1 month ago
JSON representation
Logshark is a debugger CLI for JSON logs written in Go
- Host: GitHub
- URL: https://github.com/ugosan/logshark
- Owner: ugosan
- Created: 2020-11-12T18:38:53.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2022-12-13T20:47:42.000Z (about 2 years ago)
- Last Synced: 2024-06-19T17:50:58.521Z (7 months ago)
- Topics: filebeat, json, logstash
- Language: Go
- Homepage:
- Size: 5.88 MB
- Stars: 18
- Watchers: 4
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-tuis - logshark
README
# logshark
Logshark is a debugger for JSON logs.
![](./_doc/demo.gif)
Logshark works by listening for logs on an HTTP port, it mimicks the Elasticsearch protocol so as to receive data from Beats (Filebeat, Metricbeat, Heartbeat, etc.) and Logstash using the standard elasticsearch output.
Features:
- Terminal UI
- Navigable list of logs
- Highlightable, pretty printed JSON
- 🎨 Colorful
- Beats/Logstash integration
- Stats such as *Events per second* and *Average size* in bytes per event - useful for calculating bulk/batch size## Download
Releases [here](https://github.com/ugosan/logshark/releases)
## 1) Start the server
### binary
```perl
./logshark --host 0.0.0.0 --port 9200 --max 1000
```### docker
```perl
docker run -p 9200:9200 -it ugosan/logshark -host 0.0.0.0 -port 9200
```You can reach the logshark container from another container using `host.docker.internal` like `docker run --rm byrnedo/alpine-curl -v -XPOST -d '{"hello":"test"}' http://host.docker.internal:9200`
### docker-compose
```
docker-compose run -p 9200:9200 logshark -port 9200
``````yaml
version: "3.2"
services:#note you should not use "docker-compose up" but instead "docker-compose run logshark sh" since docker-compose doesnt attach to containers with "up". e.g. docker-compose run -p 9200:9200 logshark -port 9200
logshark:
image: ugosan/logshark
tty: true
stdin_open: true
```
## 2) Point your Logstash pipeline's output to itJust like a normal `elasticsearch` output:
```ruby
input {}filter {}
output {
elasticsearch {
hosts => ["http://host.docker.internal:9200"]
}
}
```