Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mthenw/frontail
📝 streaming logs to the browser. Sponsored by https://cloudash.dev
https://github.com/mthenw/frontail
devops log-stream log-viewer stream-logs syslog tail
Last synced: 6 days ago
JSON representation
📝 streaming logs to the browser. Sponsored by https://cloudash.dev
- Host: GitHub
- URL: https://github.com/mthenw/frontail
- Owner: mthenw
- License: mit
- Created: 2012-03-28T22:38:29.000Z (almost 13 years ago)
- Default Branch: master
- Last Pushed: 2023-11-12T18:53:23.000Z (about 1 year ago)
- Last Synced: 2025-01-09T05:07:31.505Z (13 days ago)
- Topics: devops, log-stream, log-viewer, stream-logs, syslog, tail
- Language: JavaScript
- Homepage: https://cloudash.dev
- Size: 816 KB
- Stars: 1,824
- Watchers: 43
- Forks: 249
- Open Issues: 56
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - mthenw/frontail - 📝 streaming logs to the browser. Sponsored by https://cloudash.dev (JavaScript)
README
# frontail – streaming logs to the browser
`frontail` is a Node.js application for streaming logs to the browser. It's a `tail -F` with UI.
![frontial](https://user-images.githubusercontent.com/455261/29570317-660c8122-8756-11e7-9d2f-8fea19e05211.gif)
[![Docker Pulls](https://img.shields.io/docker/pulls/mthenw/frontail.svg)](https://hub.docker.com/r/mthenw/frontail/)
## Quick start
- `npm i frontail -g` or download a binary file from [Releases](https://github.com/mthenw/frontail/releases) page
- `frontail /var/log/syslog`
- visit [http://127.0.0.1:9001](http://127.0.0.1:9001)## Features
- log rotation (not on Windows)
- auto-scrolling
- marking logs
- pausing logs
- number of unread logs in favicon
- themes (default, dark)
- [highlighting](#highlighting)
- search (`Tab` to focus, `Esc` to clear)
- set filter from url parameter `filter`
- tailing [multiple files](#tailing-multiple-files) and [stdin](#stdin)
- basic authentication## Installation options
- download a binary file from [Releases](https://github.com/mthenw/frontail/releases) pagegit st
- using [npm package](https://www.npmjs.com/package/frontail): `npm i frontail -g`
- using [Docker image](https://cloud.docker.com/repository/docker/mthenw/frontail): `docker run -d -P -v /var/log:/log mthenw/frontail /log/syslog`## Usage
frontail [options] [file ...]
Options:
-V, --version output the version number
-h, --host listening host, default 0.0.0.0
-p, --port listening port, default 9001
-n, --number starting lines number, default 10
-l, --lines number on lines stored in browser, default 2000
-t, --theme name of the theme (default, dark)
-d, --daemonize run as daemon
-U, --user Basic Authentication username, option works only along with -P option
-P, --password Basic Authentication password, option works only along with -U option
-k, --key Private Key for HTTPS, option works only along with -c option
-c, --certificate Certificate for HTTPS, option works only along with -k option
--pid-path if run as daemon file that will store the process id, default /var/run/frontail.pid
--log-path if run as daemon file that will be used as a log, default /dev/null
--url-path URL path for the browser application, default /
--ui-hide-topbar hide topbar (log file name and search box)
--ui-no-indent don't indent log lines
--ui-highlight highlight words or lines if defined string found in logs, default preset
--ui-highlight-preset custom preset for highlighting (see ./preset/default.json)
--path prefix path for the running application, default /
--disable-usage-stats disable gathering usage statistics
--help output usage informationWeb interface runs on **http://[host]:[port]**.
### Tailing multiple files
`[file ...]` accepts multiple paths, `*`, `?` and other shell special characters([Wildcards, Quotes, Back Quotes and Apostrophes in shell commands](http://www.codecoffee.com/tipsforlinux/articles/26-1.html)).
### stdin
Use `-` for streaming stdin:
./server | frontail -
### Highlighting
`--ui-highlight` option turns on highlighting in UI. By default preset from `./preset/default.json` is used:
```
{
"words": {
"err": "color: red;"
},
"lines": {
"err": "font-weight: bold;"
}
}
```which means that every "err" string will be in red and every line containing "err" will be bolded.
_New presets are very welcome. If you don't like default or you would like to share yours, please create PR with json file._
Available presets:
- default
- npmlog
- python### Running behind nginx
Using the `--url-path` option `frontail` can run behind nginx with the example configuration
Using `frontail` with `--url-path /frontail`
```
events {
worker_connections 1024;
}http {
server {
listen 8080;
server_name localhost;location /frontail {
proxy_pass http://127.0.0.1:9001/frontail;proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
}
```### Usage statistics
`frontail` by default (from `v4.5.0`) gathers **anonymous** usage statistics in Google Analytics. It can be disabled with
`--disable-usage-stats`.The data is used to help me understand how `frontail` is used and I can make it better.