jLoga is a log analyzer, optimized for performance, written in java 11 and capable to open huge files. The UI is designed to for heavy log analysis and to show multiple files and multiple search results, inspired by glogg a great native and multiplatform log analyzer.
Files and results can be view in grid mode and inspected with finos perspective, a standalone perspective viewer launcher is also provided.
The project started in my spare time to simplify crash analisys.
For each jloga variant Java 11 or later is required, you can download OpenJDK jre available from Adoptium, search it from Oracle's java.com or use the one bundled with your operating system if any.
The .exe
file is an all-in-one executable file built with Launch4J for windows in order to simplify file associations. You don't need to extract it, just double click to run. The app uses the standard java preferences to store the user selections.
For other platforms you can download the .jar
file and execute it with java -jar jloga-all.jar
, all dependencies are included.
Head directly to this page for downloads.
- Hierarchical panel structure to ease files and results navigation
- No size limit on open files, each file is indexed and paged from disk. The only limit is the memory of your computer
- Fast and multithread simple searches like text and regex, each can be case-sensitive or not, inclusive or exclusive
- More advanced analysis such as frequency and function duration reports
- Autodetect most common log lines formats for timestamp extraction
- Save and reload search parameters
- Capable of running external commands as new analyzers
- Convert and show data into finos perspective
- Favorites folders support
There is no limit in file size, maximum number of lines is 263-1.
Each open file is indexed keeping a reference to the position on disk each (for example) 1MB, so the heap impact is minimum even for very big files.
Past pages of the files are kept in memory until garbage collection starts in order to reduce disk i/o activity, due to the nature of the application, the best performance is achieved when reading files from a ssd.
jLoga can open many 4GB log files in few senconds and with default jvm settings, you can increase heap if you have a slow disk in order to explicitly cache text pages and reduce disk accesses.
You can check current memory usage and limits of a running instance by running the command line in this example:
$ java -jar jloga-all.jar -remote-info
Available Processors = 8
Heap Memory = 536870912
Free Memory = 503673600
Max Memory = 8558477312
WARNING: executing unsafe scripts may be a security risk!
Be sure that every external analyzer you define comes from a trusted source, jloga can't apply any security related restriction on external processes.
You can create a set of files with extension .jloga.json
inside a dedicated folder and then have those commands be executed inside jloga as custom analyzers.
This folder can be specified inside the settings or via the system property jloga.ext.dir
.
Each command must be able to parse data from stdin and produce output to stdout, each line emitted from the command is associated to the last line parsed from the source.
Processes will be started in the folder where the json files are stored, if a env.jloga.properties
file is present in the same directory it will be parsed as input variables for the external script definition, if a variable is not found in system environment, provided variables or custom ones, an error message will appear and the script will not be executed.
Normally os environment will not override variables contained in properties files, if you want to change this behaviour you can use the system property -Djloga.env.override=true
.
In addition to env.jloga.properties
a env-windows.jloga.properties
will be read when running in Windows environment and a env-unix.jloga.properties
otherwise. The more specific env file will override the less specific properties.
Inside the .json.jloga
files the command
tag is an array of strings or other array of string, in the latter case the array contents will be concatenated with the system path separator.
Without any other specification, external scripts are ordered by filename. You can specify order in other ways:
- inside the .jloga.json config file with the
order
tag - at the .jloga.json filename beginning with a number (will override alphabetical order)
When the order value of two different scripts is the same, alphabetical filename ordering will take place.
By default, lines are matched with the source files at the moment the child process emits an output.
If your analyzer supports emitting the line number you can specify a full-line-match regex to extract the line number
and the rest of the text line.
For example, grep emits matches in this form:
$ find . -name "*.java" | xargs grep -n printStackTrace
./ext/ExtEnv.java:47: e.printStackTrace(System.err);
./ext/ExtProcessManager.java:71: ex.printStackTrace(System.err);
./ext/ExtProcessPipeSearch.java:54: e.printStackTrace(System.err);
./ext/ExtProcessPipeSearch.java:104: _err.printStackTrace(System.err);
...
and you can specify inside the .json.jloga
file something like:
"command": [...],
"matchRegex": "^(?<file>[^:]*):(?<line>\\d*):(?<text>.*)",
"params": {
Consider that:
- only groups named with "line" and "text" are considered and are mandatory
- the regex must match the whole line, if not old behaviour will be applied for that line
- line numbers emitted by the child process are considered starting from 1 (one)
- specifying
grep
as regular expression will be translated into^(?<file>[^:]*):(?<line>\\d*):(?<text>.*)
which should be quite common
By specifing a %VarName%
in each part of the .json.jloga file you can access to system environment variables plus some
more predefined one as in the below table:
Name | Description |
---|---|
Title | The title of the search panel |
RootTitle | The title of the root search panel, ususally contains the file name. |
The variables are read in sequence from: system environment, custom provided variables and search provided variables. Each source takes precedence over the previous ones.
See the folder ext-search-samples for some examples.
Inside .json.jloga files you can define new variables bound to UI widgets, by now the most complete example is cyggrep.jloga.json.
If your external analyzer outputs more sections, you can grab them and see a single section after having
selected it in the search results viewer.
To begin sectioning the output of your external script you must add a sectionRegex
value in you script
definition that will match the full line: if a capturing group is specified the contents will be used as
the title of the section, otherwise the full line will be used as title instead.
I've fallen in love with Data Preview for Visual Studio Code then discovered finos perspective.
Perspective is a powerful data analysis tool (check their site) and you can now apply that analysis on your search results. Input data is automatically translated and adapted into a compatible format, perspective is then opened in a standalone browser.
Unfortunately firefox has problems with perspective and even javaFX browser does not support webassembly and workers, you will have to use a chromium based browser.
You can launch a standalone perspective viewer with:
java -cp build/libs/jloga-all.jar org.riekr.jloga.httpd.FinosPerspectiveServer input_data.csv
Once you close the browser, the app will automatically close.
The app supports a preliminary menu for accessing favorites folders, there is no way other than modifying an external file to list favorites. Create a properties file like favorites-sample.properties and use the system property -Djloga.favorites=favorites.properties
to specify the file you just created.
If you launch jloga from a workspace configuration you will find this feature useful :)
This software is free as in speech, do whatever you want with it.
As a spare time project sources are updated only when possible, don't expect fast response times to bug/issues or requests. I'll do my best anyway.
- FlatLaf - Flat Look and Feel (home - license)
- fontchooser (home - license)
- NanoHTTPD – a tiny web server in Java (home - license)
- Gson (home - license)
- Launch4J - Cross-platform Java executable wrapper (license - home - gradle plugin)
- Perspective (home - license)
- Text Icon (home)
- Last but not least IntelliJ Idea Community Edition