Project

silw

0.0
Repository is archived
No commit activity in last 3 years
No release in over 3 years
Read various system stats from local or remote systems and publish them in a simple and configurable dashboard
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.5
>= 0
>= 0

Runtime

~> 3.1.4
~> 0.6.0
>= 0
~> 1.0.2
~> 1.4.1
~> 1.1.0
~> 1.1.0
~> 1.3.2
>= 0
>= 0
~> 1.4
 Project Readme

SILW

This is a simple utility that allows one user to monitor several remote systems, provided he has the proper credentials and the authorization to execute remote commands. Inspired from usagewatch, SILW differs by targeting remote systems and exposing a simple and customizable Sinatra web app.

SILW Plugins available in this release

  • Meminfo - report the memory stats collected from a remote system.
  • CPU info - report the total CPU usage for a remote system.
  • Diskio - report the disk usage on a remote system.

In order to use SILW, you must be authorized to use the target systems, and make sure you can authenticate and that you are authorized to run various system commands i.e. top, free, read the content of the /proc/meminfo file.

Using the gem in command line mode

First create a silw.yaml config file in your home directory. Excerpt from ~/silw.yaml:

:monitoring:
  router:
    :freq: 10s
    :plugins: cpu mem diskio

:authentication:
  :username: username_with_remote_access
  :password: ~/.ssh/id_dsa (or password!!)

:server: 
  :port: 8080

and use SILW for querying the remote servers defined under the :monitoring::

silw exec cpu
silw exec mem cpu diskio

Or specify a different remote server, for example:

silw exec cpu mem -s router

{"host":"router","cpu":{"cpu_usage":"12.5%"}}
{"host":"router","mem":{"total":2075624.0,"active":538692.0,"free":1135688.0,"usagepercentage":26}}

Without a configuration file, you'll have to specify the remote server and a valid username and password combination, for example:

silw exec cpu -s honeypot -u florin -k ~/.ssh/xtraterrestrial_dsa

Using the gem as a local web service

You can use SILW to monitor remote systems from your browser. For this you will have to create or modify the SILW configuration file: silw.yaml. Example:

:monitoring:
  triba:
    :freq: 1min
    :plugins: mem, diskio, cpu
  zorius:
    :freq: 30s
    :plugins: cpu, diskio
authentication:
  :username: johndoe
  :password: ~/.ssh/id_dsa
:server: 
  :port: 8080

Say the config file above is called: silw.yaml and it is created in your home folder. Then start the SILW server like this:

silw server start -c ~/silw.yaml

View the data collected in your web browser by pointing it to http://0.0.0.0:8080, if the server.port in the config file was 8080. You will see a similar interface:

Run: silw server stop, to stop the server.

Integration with Logstash

Because you are using a centralized logging system for collecting your metrics :) SILW can be configured to echo the stats collected to Logstash.

	# Echo the stats directly to logstash
	:logstash:
	  :host: localhost
		:port: 5228, udp
		# or:
		# :port: 5229, tcp

Excerpt from a SILW-logstash output:

		{
         "message" => "{\"@tags\":[],\"@fields\":{\"host\":\"honeypot\",\"diskio\":[0,24]},
           \"@timestamp\":\"2014-04-18T13:48:00.663-04:00\",\"@version\":\"1\",\"severity\":\"INFO\"}",
        "@version" => "1",
      "@timestamp" => "2014-04-18T17:48:00.663Z",
            "host" => "127.0.0.1:50719",
            "type" => "silw",
           "@tags" => [],
         "@fields" => {
            "host" => "honeypot",
          "diskio" => [
              [0] 0,
              [1] 24
          ]
      },
        "severity" => "INFO"
  }

SILW is using the logstash-logger gem

Testing

cd silw
bundle exec rake

Contributing

  • Fork it
  • Create your feature branch (git checkout -b my-new-feature)
  • Add some tests and please make sure they pass
  • Commit your changes (git commit -am 'Added some feature')
  • Push to the branch (git push origin my-new-feature)
  • Create new Pull Request

License

Copyright (c) 2014 Florin T.Pătraşcu

MIT License