bigfix-log-tail

command module
v0.0.0-...-4675217 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 16, 2023 License: Apache-2.0 Imports: 12 Imported by: 0

README

bigfix-log-tail

A CLI tool, written in Go, which will tail the BigFix agent logs indefinitely. It uses goroutines to write the lines and to find and read the newest file in the client log directory. It assumes the default location for the logs based on the OS, and allows a folder name to be specified on the command line to override it. It will always follow the most recent file in the specified directory.

This really is in no way BigFix specific, but I wrote it to scratch an itch with the way BigFix client logs are written. They do not do it in an "syslog" manner. Usually with syslog, the current log name is fixed and when the log "rolls," the name is changed. The standard "tail" command handles this automatically. But the BigFix agent names the log uniquely each day. So this program sets up two goroutines. One which just writes strings that come in on a channel to stdout. Another reads lines from the most recent file in a directory and sends them to the channel, then checks to see if there is a newer file than the current one. If there is, it switches to that file and continues to monitor it.

This has been improved to use an already existing tail library and the fsnotify library. The changes in behavior are that it will initially open and tail the most recently modified file in a directory. If a new file is later created in that directory, it will switch to tailing that file. It will do this until you terminate the program.

On Windows, you can right click on the exe and choose "Run as Administrator" and it will open in command window.

You can specify the directory to "watch" on the command line. If you do not, it attempts to default to either:

C:\Program Files (x86)\BigFix Enterprise\BES Client\__BESData\__Global\Logs

or

/var/opt/BESClient/__BESData/__Global/Logs

This is currently based solely on the value of os.PathSeparator. So lots of room for improvement!

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL