Skip to content

Latest commit

 

History

History
120 lines (88 loc) · 4.62 KB

README.md

File metadata and controls

120 lines (88 loc) · 4.62 KB

access-log-monitor

CircleCI Coverage Status Go Report Card

The tool access-log-monitor tails the file access.log and shows metrics and alerts.

The tool can be downloaded from the release page.

Tools and development

Structure

The folder pkg contains the source code.

The folder access-log-monitor contains the source code for the application. It uses github.com/spf13/cobra structure.

The file Dockerfile uses multi-staging to generate a docker image with the binaries (access-log-monitor).

The file docker-compose uses the tool flog to generate logs.

The folder flog contains a dockerfile to build the latest version of github.com/mingrammer/flog. It is used as a log generator for testing purposes.

Software architecture

sofware architecture

Tools

  • make helps to manage common command lines.
  • go the go module must be activated GO111MODULE=on.
  • docker for the containerization.
  • docker-compose for testing

Development

The default goals are described with the command line make help.

make help
clean                          clean the target folder
cover-html                     show the coverage in HTML page
dependencies                   Download the dependencies
docker-build                   build the docker image
docker-push                    push the docker image
fmt                            go fmt
gocyclo                        check cyclomatic
help                           prints help.
it-test                        integration test
lint                           go lint on packages
misspell                       gmisspell packages
publish                        publish the application in tag in progress (TODO move in circleci)
test                           test
tools                          download tools
ui-test                        It runs the docker-compose. The flog container generates log and access-log-monitor is launched
vet                            go vet on packages

Run the unit tests and integration tests

The tests are written in a Behavior Driven Development way and most of the time in TDD.

make tools #install the requirements for the test
make dependencies #download the go dependencies
make test

The integration tests are not considered as short test.

Run the UI test

The following command line runs the docker-compose. It uses flog to generate logs in /tmp/access.log.

make ui-test

Run the applcation

access-log-monitor watch -h
watch an access log file

Usage:
  access-log-monitor watch [flags]

Flags:
      --aggregation-duration duration   The aggregation duration (default 10s)
      --alert-duration duration         The alert duration (default 2m0s)
      --alert-threshold int             The number of requests (default 10)
  -f, --file string                     The access log file (default "/tmp/access.log")
  -h, --help                            help for watch
  -s, --start string                    The start time '02/Jan/2006:15:04:05 -0700' default is now. (default "21/Nov/2019:13:52:51 +0100")

Global Flags:
  -l, --log-level string   The log level (default "info")

application

Improvements

  • Test:
    • Improve error test parser_test.go.
    • Make a choice about the anonymous funtion? (parser_test.go#context(request, section)).
    • Improve the test with the channels.
    • Move mustParseTime in common packge for test.
    • Improve the coverage
  • Manage the channel errors (tail and parsing)
  • Add more context of error. Example when a line isn't normalized, error should be more explicit.
  • For the scalabity, kafka or pulsar or database timeseries.
  • For the querying, elastic search.
  • For the alerting Grafana. kibana,
  • Use gRPC to identify a protocol to fetch the metrics an alerts.
  • Pattern Fan in and Fan out to process the lines.
  • Identity if there is a need of mutex.