-
-
Notifications
You must be signed in to change notification settings - Fork 156
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: adding tcp monitor, reinstating ping as reported in #243
- Loading branch information
Raj Nandan Sharma
authored and
Raj Nandan Sharma
committed
Feb 7, 2025
1 parent
103d64a
commit 07f59ac
Showing
10 changed files
with
587 additions
and
238 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,135 @@ | ||
--- | ||
title: TCP Monitors | Kener | ||
description: Learn how to set up and work with TCP monitors in kener. | ||
--- | ||
|
||
# TCP Monitors | ||
|
||
TCP monitors are used to monitor the livenees of your servers. You can use TCP monitors to monitor the uptime of your servers and get notified when they are down. | ||
|
||
<div class="border rounded-md"> | ||
|
||
 | ||
|
||
</div> | ||
|
||
## Hosts | ||
|
||
You can add as many hosts as you want to monitor. The host can be an IP(IP4 and IP6) address or a domain name. | ||
|
||
- Type: Choose the type of host you want to monitor. It can be either `IP4` or `IP6` or `DOMAIN`. | ||
- Host: Enter the IP address or domain name of the host you want to monitor. | ||
- Port: Enter the port number of the host you want to monitor. | ||
- Timeout: Enter the timeout in milliseconds for each ping request of each host | ||
|
||
## Eval | ||
|
||
The eval is used to define the JavaScript code that should be used to evaluate the response. It is optional and has be a valid JavaScript code. | ||
|
||
This is an anonymous JS function, it should return a **Promise**, that resolves or rejects to `{status, latency}`, by default it looks like this. | ||
|
||
> **_NOTE:_** The eval function should always return a json object. The json object can have only status(UP/DOWN/DEGRADED) and latency(number) | ||
> `{status:"DEGRADED", latency: 200}`. | ||
```javascript | ||
(async function (responseDataBase64) { | ||
let arrayOfPings = JSON.parse(atob(responseDataBase64)); | ||
let latencyTotal = arrayOfPings.reduce((acc, ping) => { | ||
return acc + ping.latency; | ||
}, 0); | ||
|
||
let alive = arrayOfPings.reduce((acc, ping) => { | ||
if (ping.status === "open") { | ||
return acc && true; | ||
} else { | ||
return false; | ||
} | ||
}, true); | ||
|
||
return { | ||
status: alive ? "UP" : "DOWN", | ||
latency: latencyTotal / arrayOfPings.length | ||
}; | ||
}); | ||
``` | ||
|
||
- `responseDataBase64` **REQUIRED** is a string. It is the base64 encoded response data. To use it you will have to decode it and the JSON parse it. Once parse it will be an array of objects. | ||
|
||
```js | ||
let decodedResp = atob(responseDataBase64); | ||
let jsonResp = JSON.parse(decodedResp); | ||
console.log(jsonResp); | ||
/* | ||
[ | ||
{ | ||
status: 'open', | ||
latency: 31.93, | ||
host: '66.51.120.219', | ||
port: 465, | ||
type: 'IP4' | ||
}, | ||
{ | ||
status: 'open', | ||
latency: 47.041417, | ||
host: '2404:6800:4003:c1c::66', | ||
port: 80, | ||
type: 'IP6' | ||
}, | ||
{ | ||
status: 'open', | ||
latency: 82.1865, | ||
host: 'rajnandan.com', | ||
port: 80, | ||
type: 'DOMAIN' | ||
} | ||
] | ||
*/ | ||
``` | ||
|
||
### Understanding the Input | ||
|
||
The input to the eval function is a base64 encoded string. You will have to decode it and then parse it to get the array of objects. Each object in the array represents the ping response of a host. | ||
|
||
- `host`: The host that was pinged. | ||
- `port`: The port that was pinged. Defaults to 80 if not provided. | ||
- `type`: The type of IP address. Can be `IP4` or `IP6`. | ||
- `status`: The status of the ping. Can be `open` , `error` or `timeout`. | ||
- `open`: The host is reachable. | ||
- `error`: There was an error while pinging the host. | ||
- `timeout`: The host did not respond in time. | ||
- `latency`: The time taken to ping the host. This is in milliseconds. | ||
|
||
### Example | ||
|
||
The following example shows how to use the eval function to evaluate the response. The function checks if the combined latency is more 10ms then returns `DEGRADED`. | ||
|
||
```javascript | ||
(async function (responseDataBase64) { | ||
let arrayOfPings = JSON.parse(atob(responseDataBase64)); | ||
let latencyTotal = arrayOfPings.reduce((acc, ping) => { | ||
return acc + ping.latency; | ||
}, 0); | ||
|
||
let areAllOpen = arrayOfPings.reduce((acc, ping) => { | ||
if (ping.status === "open") { | ||
return acc && true; | ||
} else { | ||
return false; | ||
} | ||
}, true); | ||
|
||
let avgLatency = latencyTotal / arrayOfPings.length; | ||
|
||
if (areAllOpen && avgLatency > 10) { | ||
return { | ||
status: "DEGRADED", | ||
latency: avgLatency | ||
}; | ||
} | ||
|
||
return { | ||
status: areAllOpen ? "UP" : "DOWN", | ||
latency: avgLatency | ||
}; | ||
}); | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.