Skip to content

Latest commit

 

History

History
94 lines (66 loc) · 2.98 KB

README.md

File metadata and controls

94 lines (66 loc) · 2.98 KB

GoAccess

What is it?

GoAccess is an open source real-time web log analyzer and interactive viewer that *runs in a terminal in nix systems. It provides fast and valuable HTTP statistics for system administrators that require a visual server report on the fly. More info at: http://goaccess.prosoftcorp.com/

GoAccess Main Dashboard

Features

GoAccess parses the specified web log file and outputs the data to the X terminal. Features include:

  • General Statistics, bandwidth etc.
  • Time taken to serve the request
  • Top Visitors
  • Requested files
  • Requested static files, images, swf, js, etc.
  • Referrers URLs
  • 404 or Not Found
  • Operating Systems
  • Browsers and Spiders
  • Hosts, Reverse DNS, IP Location
  • HTTP Status Codes
  • Referring Sites
  • Keyphrases
  • Support for IPv6
  • Different Color Schemes
  • Unlimited log file size
  • Custom log format
  • Output statistics to a file.

Nearly all web log formats...

GoAccess allows any custom log format string. Predefined options include, but not limited to:

  • Common Log Format (CLF) Apache
  • Combined Log Format (XLF/ELF) Apache
  • W3C format (IIS).
  • Amazon CloudFront (Download Distribution).
  • Apache virtual hosts

Why GoAccess?

The main idea behind GoAccess is being able to quickly analyze and view web server statistics in real time without having to generate an HTML report. Although it is possible to generate an HTML report, by default it outputs to a terminal.

You can see it more as a monitor command tool than anything else.

Installation

GoAccess can be compiled and used on Linux, OSX, OpenBSD, NetBSD, FreeBSD.

Briefly, the shell commands ./configure; make; make install should configure, build, and install GoAccess. An INSTALL file is attached within the package for more-detailed instructions.

http://goaccess.prosoftcorp.com/download#installation

Usage

The simplest and fastest usage would be:

# goaccess -f access.log

That will generate an interactive text-only output.

To generate an HTML report:

# goaccess -f access.log -a > report.html

To generate full statistics we can run GoAccess as:

# goaccess -f access.log -a

The -a flag indicates that we want to process an agent-list for every host parsed. The -c flag will prompt the date and log format configuration window. Only when curses is initialized.

Now if we want to add more flexibility to GoAccess, we can do a series of pipes. For instance:

If we would like to process all access.log.*.gz we can do:

# zcat access.log.*.gz | goaccess 
OR
# zcat -f access.log* | goaccess

Another useful pipe would be filtering dates out of the web log

The following will get all HTTP requests starting on 05/Dec/2010 until the end of the file.

# sed -n '/05\/Dec\/2010/,$ p' access.log | goaccess -a

For more examples, please check GoAccess' man page: http://goaccess.prosoftcorp.com/man

Enjoy!