Skip to content

Latest commit

 

History

History
160 lines (123 loc) · 4.41 KB

File metadata and controls

160 lines (123 loc) · 4.41 KB

Snap Collector Plugin - SysInternals

This Snap plugin collects a few metrics using pslist.exe (# of processes, threads, handles). The script will also automatically download the executable from the Microsoft site.

  1. Getting Started
  1. Documentation
  1. Community Support
  2. Contributing
  3. License
  4. Acknowledgements

Getting Started

System Requirements

  • golang 1.7+ (needed only for building as code is written in Go)

Installation

To build this plugin through the Snap github repository:

  1. Download the zip file from github (or clone the repo)

  2. Set up Golang on your machine

a. Download Golang

b. Install Golang

c. Set up environmnet variables (both GO and GOPATH)

  1. Download Glide (to be able to download packages)

a. Download Glide

b. Set an environment path for glide (or just move the exe file around)

  1. Set up the dependencies through Glide
glide.exe install
  1. Build Snap through Go (you cannot be in the scripts folder!)
go build scripts\build_all.sh
  1. Download the sysinternals plugin

  2. Install dependencies for the plugin using glide

  3. Build the project through Go

go build github.com\Snap-for-Windows\snap-plugin-collector-sysinternals

Configuration and Usage

  1. Run snapteld.exe with the appropriate flags (example below)
snapteld.exe --plugin-trust 0 --log-level 1
  1. Load the plugin through snaptel.exe
snaptel.exe plugin load snap-plugin-collector-sysinternals.exe
Plugin loaded
Name: sysinternals-collector
Version: 1
Type: collector
Signed: false
Loaded Time: Mon, 20 Feb 2017 11:17:17 MST
  1. Enjoy!

Documentation

Collected Metrics

The plugin collects the following:

Namespace Description
/intel/sysinternals/handleCount gets the number of handles
/intel/sysinternals/processCount gets the number of processes
/intel/sysinternals/threadCount gets the number of threads

Examples

Load sysinternals plugin

See available metrics for your system

snaptel.exe metric list

Run the plugin using a task manifest file (the below example uses the Snap mock file plugin to output the data to a text file)

{ 
    "version": 1,
    "schedule": {
        "type": "simple",
        "interval": "30s"
    },
    "max-failures": 10,
    "workflow": {
        "collect": {
            "metrics": {
                "/intel/sysinternals/handleCount": {},
                "/intel/sysinternals/processCount": {},
                "/intel/sysinternals/threadCount": {}
            },
            "process": [
                {
                    "plugin_name": "passthru-grpc",
                    "process": null,
                    "publish": [
                        {
                            "plugin_name": "mock-file-grpc",
                            "config": {
                                "file": "C:\\SnapLogs\\snap-sysinternals-file.log"
                            }
                        }
                    ]
                
            ]
        }
    }
}

Create task:

snaptel.exe task create -t sysinternal-file.yaml

Stop task (use the task ID that was given the the task was initially created):

snaptel.exe task stop 4a156b0f-582f-4a13-8d67-120a2ba72e1d
Task stopped:
ID: 4a156b0f-582f-4a13-8d67-120a2ba72e1d

Community Support

This repository is one of many plugins in Snap, a powerful telemetry framework. See the full project at http://github.com/intelsdi-x/snap To reach out to other users, head to the main framework

Contributing

We love contributions!

There's more than one way to give back, from examples to blogs to code updates. See our recommended process in CONTRIBUTING.md.

License

Snap, along with this plugin, is an Open Source software released under the Apache 2.0 License.

Acknowledgements

And thank you! Your contribution, through code and participation, is incredibly important to us.