Skip to content

PowerShell solution for creating PRTG sensors and reports on environments, based on json custom configurations.

License

Notifications You must be signed in to change notification settings

EngageLabsIt/AutoPRTG

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 

Repository files navigation

AutoPRTG

AutoPRTG is a solution based on a set of PowerShell script which allows us to create PRTG sensors and reports automatically. PRTG is a monitoring tool by Paessler and lets system administrators to monitor many environments at a glance. With sensors (sets of counters) you can view the status of servers, check their health and setup notifications. Unfortunately, creating new sensors manually is a challenging task. Indeed, each sensor needs many clicks, many configurations and, once created some kind of them cannot be edited. Wit AutoPRTG you can create JSON configuration files one shot and just execute the script using them. The complex task is moved to the JSON files configuration and you can run the script as you need (also dropping existing sensors if needed). You can make your templates, too, in order to avoid any manual re-creation of the PRTG items. You can configure also the thresholds for notifications, the target of them and also the scheduled reports that you can check later.

AutoPRTG is based on PRTG API solution made by Lord Milko.

Advantages

  • Quick create sensors
  • Store the sensors configuration on JSON files
  • Version the configurations on your own Source Control Manager
  • Replicate the configurations for similar environments with minimal effort

Usage

  1. Set the "Probe" options
  2. Configure the JSON files for each set of sensors
  3. Install the solution with .bat file. It will install automatically the PRTG API, too.

Set the Probe options

The so-called Probe is the server that monitors and keeps track of one or more environment. It stores also the current configuration of PRTG and its sensors. The Probe settings file contains the connection information of PRTG. To configure it, modify the file probe-settings.json:

  • prtg_http_host: contains the PRTG host name (with port number).

    Example monitoring.mycompany.com:23456

  • prtg_username: username used for accessing to PRTG portal. The user must have the privileges to see user accounts and user groups in order to assign reports to another user and user groups (see the Reports section).

  • prtg_password: user password

  • device_name: target device where the sensors and/or report will be created

Configure the JSON files

The configuration files are stored in the folder configuration. The file name must start with config and its extension must be .json as well as the syntax. These files contain the list of sensors and the list of reports that you would like to create.

If you need to make a report, you must add the sensors configurations, too. The reason is that the report will refer to them, using internal ids.

The configuration samples in this github project are ready to use while the report's one must be changed, depending on your personal PRTG data. In particular, you've to change:

  • owner
  • emailaddress
  • accessrights_group

Sensors configuration option

  • internal_sensorId: is the ID used in report configuration to link the sensor name

  • name: sensor name

  • type: sensor type. Following, the list of the supported type:

    • pccustom: “PerfCounter Custom”: Monitor a configured set of Performance Counters
    • mssqlv2: “Microsoft SQL v2”: Monitor a database on a Microsoft SQL Server (MSSQL)
    • aggregation: Aggregation channel based on other sensors.
  • tags: list of sensors tag. You can use tags to group sensors and use tag–filtered views later on. Tags are case insensitive.

  • priority: sensor priority. This setting determines where the sensor is placed in sensor lists. Top priority is at the top of a list. Choose from one (low priority) to five (top priority).

  • InheritInterval: 1 = inerhit scanning interval

  • interval: Scanning interval: The scanning interval determines the time the sensor waits between two scans.

  • primary_channel: Primary Channel Id.

  • channels: list of channels.

Channel configuration option

  • channelId: Id of the channel. Start to set the configuration from ID number 2. Some of the first identifiers are used by the system.
  • name: Channel Name
  • measure_unit: Channel unit of measurement
  • limit_type: limit type. Use
    • upper: to set an upper limit
    • “lower**: to set a lower limit
    • none: to not set the limit
  • properties: list of channel limit property.

Channel limit property configuration option

To set a limit you have to set an upper limit or lower limit, it is not possible set both limits.

  • upper_error_limit: Upper error limit
  • upper_warning_limit: Upper warning limit
  • lower_error_limit: Lower error limit
  • lower_warning_limit: Lower warning limit
  • error_limit_message: Error limit message
  • warning_limit_message: Warning limit message

Reports option

  • name: Report name

  • template: Name of the template that this report uses. You have to use one of the templates here.

  • owner: PRTG user account that PRTG uses to run the report. This user must have the grant to see the sensors.

  • timezone: timezone for all dates in this report. This includes schedule dates, report time span, and dates in tables and graphs. You have to use one of the values from here.

  • papersize: Define the paper size in which PDF reports are created. Choose between:

    • "none": Do not specify a paper format. The size is set automatically.
    • "a4": Use German DIN A4 format.
    • "a3": Use DIN A3 format.
    • "a2": Use DIN A2 format.
    • "legal": Use North American legal paper format.
    • "letter": Use North American letter paper format.
    • "ledger": Use North American ledger paper format.
  • orientation: Define the page orientation for the data in PDF reports. Choose between:

    • “0” = Portrait: Use portrait mode for the page orientation.
    • “1” = Landscape: Use landscape mode for the page orientation. The landscape format is designed to properly show data tables of sensors with many channels. Other parts of the report will remain in portrait mode and do not re-size to the landscape format.
  • scheduletype:

    • "0": No schedule (run interactively/on-demand only): Only use the options on the Run Now tab to start generating this report manually.
    • "1": Every full hour: Run this report every 60 minutes.
    • "2" #Every day at a specific hour: Run this report every 24 hours.
    • "3" #Every specific day of a week: Run this report every 7 days. Specify the day below.
    • "4" #Every specific day of a month: Run this report on a specific day every month. Specify below
    • "6" #The day after a quarter has finished (i.e. on 1. April for the 1. January - 31. March Quarter): Run this report for every quarter of the year.
    • "5" #Every specific date. Run this report on a specific date every year. (Not implemented)
  • maildisk: This setting is used only if you set the “scheduletype” to a value different to “0”. Define what to do with a finished report. Choose between:

    • "0": Save report to disk and send it by email: Create a PDF file and, depending on the Data Files setting, data files of the report, store it, and send it via email. You find the report in your emails and on the Stored Reports tab. Define an email address in "emailaddress" option.
    • "1": Save report to disk only: reate a PDF file and, depending on the Data Files setting, data files of the report and store it. Once finished, you find them on the Stored Reports tab. You receive also a ToDo ticket from PRTG. By default, PRTG sends out a notification email to the administrator in this case.
    • "2": Send report by email only: Create a PDF file and, depending on the Data Files setting, data files of the report and send them via email once finished. With this option the report is not permanently stored in PRTG. Define an email address below.
  • emailaddress: This setting is used only if you select a send by email option above. Enter a valid email address to which PRTG sends the report. To enter more addresses, separate them by comma. PRTG sends a message with all recipients in the "To" field of the email.

  • emailgroup: This setting is used only if you select a send by email option above. Set a user group to send an email with the report to all members of this group. You can edit user groups in PRTG System Administration—User Groups.

  • usecompression: This setting is used only if you select a send by email option above. Define if PRTG will compress the attached report files before sending them out. Choose between:

    • "0": Send files uncompressed (default): PRTG sends the report files by email in their original size.
    • "1": Send all in one ZIP file: PRTG will compress the report files to a ZIP file before they are sent by email.
  • dataperiod: Define the time span the report covers. Choose between:

    • "0": Current: Use monitoring data of the current period. Define the period type below.
    • "1": Previous: Use monitoring data of the last period. Define the period type below.
  • reporttype: Define the type of period you want to create a report for. Choose between:

    • "0": Day
    • "1": Week
    • "2": Month
    • "3": Quarter (January-March, April-June, etc.)
    • "4": Year
  • accessrights_group: User Group Access. Define which user group(s) will have access to the object that you are editing. You must use one user groups from your PRTG setup.

  • accessrights_value: User group access right. For the previous user group, you can choose from the following access rights:

    • "0": None: Users in this group cannot see or edit the object. The object does not show up in lists.
    • "100": Read: Users in this group can see the object and review its settings.
    • "200": Write: Users in this group can see the object, as well as review and edit its settings. However, they cannot edit access rights settings.
    • "400": Full: Users in this group can see the object, as well as review and edit its settings as well as edit access rights.
  • sensors: list of sensors.

Report sensor configuration option

  • internal_sensorId: This is the internal id defined in the sensor configuration. This id is used to get the name of the sensor.

  • channels: list of channels

Report sensor channel configuration option
  • channelId: Identifier of the channel

License

AutoPRTG is released under the MIT License.

Contributors

AutoPRTG is made by part of Engage IT Services team:

A special thanks to Lord Milko.

About

PowerShell solution for creating PRTG sensors and reports on environments, based on json custom configurations.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published