Community discussions

MikroTik App
 
User avatar
Hammy
Forum Veteran
Forum Veteran
Topic Author
Posts: 776
Joined: Fri May 28, 2004 5:53 pm
Location: DeKalb, IL
Contact:

Request: IP-SLA

Wed May 07, 2014 5:33 am

http://www.cisco.com/c/en/us/products/i ... index.html


I would like to see something similar to Cisco's IP-SLA. Something to monitor the jitter latency, throughput, etc. in real time for enforcing or proving SLAs.

Sent from my EVO using Tapatalk
 
gregsowell
Member Candidate
Member Candidate
Posts: 128
Joined: Tue Aug 28, 2007 1:24 am
Contact:

Re: Request: IP-SLA

Wed May 07, 2014 5:47 am

Would love to use these as probes as well as pull stats off of existing routers.
 
roadracer96
Forum Veteran
Forum Veteran
Posts: 736
Joined: Tue Aug 25, 2009 12:01 am

Re: Request: IP-SLA

Wed May 07, 2014 7:01 am

Ccm messaging as part of g.8032 ethernet rings can be used this way. Kill 2 birds with one stone.
 
User avatar
StubArea51
Trainer
Trainer
Posts: 1742
Joined: Fri Aug 10, 2012 6:46 am
Location: stubarea51.net
Contact:

Re: Request: IP-SLA

Fri May 16, 2014 12:18 am

+1 !

Netwatch can do some of this but it would be nice to have a protocol baked into ROS that can handle this
 
sashavl
Frequent Visitor
Frequent Visitor
Posts: 56
Joined: Mon Nov 01, 2010 8:19 pm
Contact:

Re: Request: IP-SLA

Fri May 16, 2014 12:55 am

That would be nice.
 
pkelly1603
Member Candidate
Member Candidate
Posts: 106
Joined: Mon Jun 15, 2009 11:13 pm

Re: Request: IP-SLA

Thu Jul 03, 2014 10:27 pm

Yes, I also need this for latency/jitter/packet loss detection
 
User avatar
nz_monkey
Forum Guru
Forum Guru
Posts: 2182
Joined: Mon Jan 14, 2008 1:53 pm
Location: Over the Rainbow
Contact:

Re: Request: IP-SLA

Fri Jul 04, 2014 4:21 am

I would love to see this feature.

We maintain some fairly large WAN's and this would be a huge benefit to us.
 
joncolby
newbie
Posts: 40
Joined: Wed Nov 13, 2013 8:09 am
Location: Southern California

Re: Request: IP-SLA

Sat Jul 05, 2014 10:26 pm

I want IP-SLA Please.....


Please.... It would be nice to be able to make adjustments to how much of the router's resources can be dedicated to IP-SLA Tasking.
 
pkelly1603
Member Candidate
Member Candidate
Posts: 106
Joined: Mon Jun 15, 2009 11:13 pm

Re: Request: IP-SLA

Fri Aug 15, 2014 9:52 pm

I wrote a script for monitoring latency and packet loss. If anyone else would like to use it, let me know and I'll post it.
 
tweetyspn
just joined
Posts: 14
Joined: Wed Jul 13, 2011 10:48 pm

Re: Request: IP-SLA

Mon Aug 18, 2014 5:03 pm

I wrote a script for monitoring latency and packet loss. If anyone else would like to use it, let me know and I'll post it.
I'm interested.

Thanks
 
User avatar
NetHorror
just joined
Posts: 22
Joined: Fri Dec 06, 2013 8:12 am

Re: Request: IP-SLA

Tue Aug 19, 2014 9:10 am

I'm interested too.

Thanks
 
markom
Member Candidate
Member Candidate
Posts: 112
Joined: Thu Dec 17, 2009 10:42 pm

Re: Request: IP-SLA

Tue Aug 19, 2014 11:06 am

I know that this is not for this topic but I am interested. How much money is SLA in your countries? Could You give me some prices ?
 
pkelly1603
Member Candidate
Member Candidate
Posts: 106
Joined: Mon Jun 15, 2009 11:13 pm

Re: Request: IP-SLA

Mon Aug 25, 2014 7:14 pm

OK, here it is.

The below script is a "setup" to create all the items necessary to setup a monitor on one IP address. By its self, this setup does nothing but monitor one ip address and based on the results, sets a global variable for to "up" or "down". You need another "failover" script to monitor these global variables and take action. I'll post my failover script shortly.

Here is what the setup script does though:
1. Creates a "probe" script & schedule that runs a ping and stores the latency
- Set "probeInterval" to decide how frequently scheduler runs this
- Set "livesKept" to decide how many ping results to store (I recommend keeping 100)
- Set "target" to the IP you want to monitor
- Set "ipslaName" to the name. Should be "ipsla1", "ipsla2", etc.. Each must be unique.
2. Creates a "analyze" script & schedule that runs analysis on the stored ping responses
- Set "analyzeInterval" to decide how frequently scheduler runs this
- Set "checkNumStats" to decide how many previous statistics to calculate loss on. I set this to the same value as "livesKept" since I don't care about storing data longer than it is used to calculate the average latency/average packet loss
- Set "latencyThreshold" to the average milliseconds threshold for the monitor to go to a "down" state
- Set "lossThreshold" to the percent packet loss threshold for the monitor to go to a "down" state
3. Creates rules in /ip proxy access . These rules do nothing but store ping values for each instance
- If you use "/ip proxy" for it's intended purpose (running a proxy), you will have to find a different area to store the ping variables in and adjust this script.

Before running the setup, please edit values under the, "User set Variables" comment first. This was tested on ROS version 5.26.
#Script creates variable storage in /ip proxy access for an ipsla instance. 
# User set Variables
#Variable represents the name of the ipsla instance (recommended to name them: ipsla1, ipsla2...ipslaN)
:local ipslaName ipsla1;
#IP to ping
:local target "4.2.2.2";
#Size of pings to send
:local size "1200";
#Variable represents total number of ping records to keep
:local livesKept 100;
:local probeInterval "10s";
#Analyze Interval should be a multiple of the probe interval
:local analyzeInterval "4m";
#Number of previous statistics to calculate loss/latency averages on
:local checkNumStats 100;
#Threshold for when latency will cause monitor to be down status
:local latencyThreshold 500;
#Threshold for when packet loss will cause monitor to be down status (this_variable is a percentage)
:local lossThreshold 15;

#Add proxy rules for storing ping statistics
#Add record with comment stating rules
/ip proxy access add action=allow comment="9999 - Flag for ping timed out.     For \"Current Index\" record: dst-port is current index, dst-host is total number of records           For standard records:  dst-port column is latency, dst-host column is number"
:for i from=0 to=$livesKept do=\
{ 
    :if (i=0) do={ /ip proxy access add action=allow disabled=no dst-port=1 dst-host="$livesKept" comment="Current Index - $ipslaName";}\
    else=\
    {
        /ip proxy access \
        add action=allow disabled=no dst-port=0 dst-host="$i" method=$ipslaName;
    };
};

#Add scheduling for probe and analyze scripts
/system scheduler
add comment="Run every X seconds" disabled=no interval=$probeInterval name=\
    ($ipslaName."_probe") on-event=($ipslaName."_probe") policy=\
    ftp,reboot,read,write,policy,test,winbox,password,sniff,sensitive,api \
    start-time=startup
add comment="Should run on an interval that is a multiple of $ipslaName _probe interv\
    al (Recommended to multiply by the \"checkNumStats\" variable in the analyze\
    \_script)" disabled=no interval=$analyzeInterval name=($ipslaName."_analyze") \
    on-event=($ipslaName."_analyze") policy=\
    ftp,reboot,read,write,policy,test,winbox,password,sniff,sensitive,api \
    start-time=startup

#Add probe script
/system script
add name=($ipslaName."_probe") policy=ftp,reboot,read,write,policy,test,winbox,password,sniff,sensitive,api source="# Variables - $ipslaName\
    \n:global $ipslaName;\
    \n:local name $ipslaName;\
    \n:local response  -1;\
    \n:local target $target;\
    \n:local pingSize $size;\
    \n\
    \n#Variables derived from stored settings\
    \n:global floodpingisbusy;\
    \n:local currentIndex;\
    \n:local livesKept;\
    \n:local currentStat;\
    \n\
    \n#Check if floodping is being used and delay if so\r\
    \n:while (\$floodpingisbusy) do={ /delay delay-time=1 };\r\
    \n\r\
    \n#Mark floodping as used before using\r\
    \n:set floodpingisbusy value=true;\r\
    \n#Ping target and gather latest statistic\r\
    \n/tool flood-ping \$target count=1 size=\$pingSize do=\\\r\
    \n{\r\
    \n    :set response \$\"avg-rtt\";\r\
    \n};\r\
    \n#reset floodpingisbusy so other processes can use it again\r\
    \n:set floodpingisbusy value=false;\r\
    \n\r\
    \n#Get stored Index\r\
    \n:set currentIndex [/ip proxy access get [find comment=\"Current Index - \$name\"] dst-port]; \
    \n:set currentStat [/ip proxy access find (method=\"\$name\" and dst-host=\"\$currentIndex\")];\
    \n:set livesKept [/ip proxy access get [find comment=\"Current Index - \$name\"] dst-host]; \
    \n\
    \n#Check if no response\
    \n:if (\$response = 0) do=\\\
    \n{\
    \n    /ip proxy access set \$currentStat dst-port=9999 dst-address=\$target;\
    \n} \\\
    \nelse=\\\
    \n{\
    \n    /ip proxy access set \$currentStat dst-port=\$response dst-address=\$target;\
    \n};\
    \n\
    \n#Increment index to next (set back to start if at end)\
    \n:if (\$currentIndex>=\$livesKept) do=\\\
    \n{\
    \n    :set currentIndex 1;\
    \n} else=\\\
    \n{\
    \n    :set currentIndex (\$currentIndex+1);\
    \n};\
    \n\
    \n/ip proxy access set [/ip proxy access find comment=\"Current Index - \$name\"] dst-port=\$currentIndex"

#Add analyze script
/system script
add name=($ipslaName."_analyze") policy=\
   ftp,reboot,read,write,policy,test,winbox,password,sniff,sensitive,api \
   source=("\
   \n#User set variables\
   \n#Variable for storing up/down status of ipsla (if this variable is edited, make sure to edit checks at the end of this script)\
   \n:global $ipslaName\
   \n## Global variable for viewing current packet loss\
   \n:global ".$ipslaName."PacketLossPercent\
   \n##Global variable for viewing current average latency\
   \n:global ".$ipslaName."AverageLatency\
   \n##Name (must match the name used in createStorageVariables script\
   \n:local ipslaName $ipslaName;\
   \n#Number of previous statistics to calculate loss/latency averages on\
   \n:local checkNumStats $checkNumStats;\
   \n#Threshold for when latency will cause monitor to be down status\
   \n:local latencyThreshold $latencyThreshold;\
   \n#Threshold for when packet loss will cause monitor to be down status (this\
   \_variable is a percentage)\
   \n:local lossThreshold $lossThreshold;\
   \n\
   \n#Variables derived from stored settings\
   \n:local livesKept [/ip proxy access get [find comment=\"Current Index - \$i\
   pslaName\"] dst-host]; \
   \n:local currentStatLatency;\
   \n:local currentIndex [/ip proxy access get [find comment=\"Current Index - \
   \$ipslaName\"] dst-port];\
   \n#Decrease current index by one since current index is pending update but c\
   urrentindex-1 is the most recently updated\
   \n:if (\$currentIndex=1) do=\\\
   \n{ \
   \n    :set currentIndex (\$livesKept); \
   \n} else=\\\
   \n{ \
   \n    :set currentIndex (\$currentIndex-1); \
   \n};\
   \n:local startIndex \$currentIndex;\
   \n:local totalLatency 0;\
   \n:local avgLatency;\
   \n:local percentLoss;\
   \n:local received 0;\
   \n:local lost 0;\
   \n:local polledIp;\
   \n\
   \n#Go through loop as many times as necessary to gather each statistic that \
   will be calucalted upon\
   \n:for i from=1 to=(\$checkNumStats) do=\\\
   \n{\
   \n#### Store latency of current statistic\
   \n    :set currentStatLatency [/ip proxy access get [find (method=\"\$ipslaN\
   ame\" and dst-host=\"\$currentIndex\")] dst-port]; \
   \n#### Check if value is flagged with 9999 (ping timed out)\
   \n    :if (\$currentStatLatency=9999) do={:set lost (\$lost+1);} else=\\\
   \n    {\
   \n######## If not timed out, add latency to total\
   \n#        :put \$currentStatLatency\
   \n        :set received (\$received+1);\
   \n        :set totalLatency (\$totalLatency+\$currentStatLatency);\
   \n    };\
   \n####Check if index is at the end of the statistic list, reset to beginning\
   \_if necessary\
   \n    :if (\$currentIndex=1) do=\\\
   \n    { \
   \n        :set currentIndex (\$livesKept); \
   \n    } else=\\\
   \n    { \
   \n        :set currentIndex (\$currentIndex-1); \
   \n    };\
   \n};\
   \n:set polledIp [/ip proxy access get [find (method=\"\$ipslaName\" and dst-\
   host=\"\$currentIndex\")] dst-address];\
   \n:set percentLoss ((\$lost*100) / ((\$received+\$lost)));\
   \n:if (\$received=0) do=\\\
   \n{\
   \n    :set avgLatency 0;\
   \n} else=\\\
   \n{\
   \n    :set avgLatency (\$totalLatency/\$received);\
   \n};\
   \n\
   \n#Log statistics\
   \n:log info \"Ran \$ipslaName analyze script, checked last \$checkNumStats p\
   oll(s) on \$polledIp\"\
   \n:log info \"Average Latency: \$avgLatency\";\
   \n:log info \"Percent loss: \$percentLoss (lost: \$lost, Received \$received\
   )\";\
   \n\
   \n#Add whatever checks on latency and percent loss down here along with acti\
   ons\
   \n:if ((\$percentLoss>\$lossThreshold) || (\$avgLatency>\$latencyThreshold))\
   \_do=\\\
   \n{\
   \n    :if (("."\$"."$ipslaName)!=\"down\") do=\\\
   \n    {\
   \n        :set $ipslaName \"down\"\
   \n        :log error (\"\$ipslaName is down\"); \
   \n        :log error (\"Packet Loss: \$percentLoss  Average Latency: \$avgLa\
   tency\");\
   \n    };\
   \n} else=\\\
   \n{\
   \n    :if (("."\$"."$ipslaName)=\"down\") do=\\\
   \n    {\
   \n        :log error (\"\$ipslaName is back up\");\
   \n    };\
   \n    :set $ipslaName \"up\";\
   \n    :set ".$ipslaName."PacketLossPercent \$percentLoss;\
   \n    :set ".$ipslaName."AverageLatency \$avgLatency;\
   \n };")


Keep in mind that this script uses floodping since regular ping can not return a latency value to a script. Floodping can only run one instance at a time so these scripts use a global variable called, "floodpingisbusy" to check whether it is in use by another probe monitor before trying to probe. For this reason, I don't think you can run many more than 4 or 5 probe scripts at a time (depending on the probe interval, this 4-5 estimate is based on 10s interval).

Some useful suggestions after running initial setup:
1. Go to IP -> Proxy -> Access and see current values to confirm this is working
2. Go to System -> Scripts -> Environment to see current values of global variables
3. Watch logs to see "analyze" scripts running and current statistics

Please feel free to post suggestions or improvements.
 
User avatar
Hammy
Forum Veteran
Forum Veteran
Topic Author
Posts: 776
Joined: Fri May 28, 2004 5:53 pm
Location: DeKalb, IL
Contact:

Re: Request: IP-SLA

Thu Dec 18, 2014 3:41 am

I believe IP-SLA goes in hand with, yet different from Y.1731. I want that too. ;-)


http://forum.mikrotik.com/viewtopic.php?f=1&t=92278
 
mmario
just joined
Posts: 12
Joined: Mon May 05, 2014 2:34 am

Re: Request: IP-SLA

Tue Jan 20, 2015 6:22 am

+1 on this
 
User avatar
Hammy
Forum Veteran
Forum Veteran
Topic Author
Posts: 776
Joined: Fri May 28, 2004 5:53 pm
Location: DeKalb, IL
Contact:

Re: Request: IP-SLA

Sat Jan 21, 2017 6:11 pm

*bump*
 
alijorjani
just joined
Posts: 2
Joined: Fri Apr 08, 2011 8:07 pm

Re: Request: IP-SLA

Fri Apr 07, 2017 10:28 pm

I want IP-SLA Please.................................................
 
idlemind
Forum Guru
Forum Guru
Posts: 1146
Joined: Fri Mar 24, 2017 11:15 pm
Location: USA

Re: Request: IP-SLA

Fri Apr 07, 2017 11:46 pm

Yup, +1

That said, I still rank most of the IPv6 feature requests above this one in respect to dev time.
 
User avatar
hansel84
just joined
Posts: 6
Joined: Mon Jan 11, 2016 6:54 am
Contact:

Re: Request: IP-SLA

Thu Oct 19, 2017 8:45 am

+1 IP-SLA
 
veljko
just joined
Posts: 8
Joined: Tue Nov 23, 2010 9:56 pm
Location: Serbia

Re: Request: IP-SLA

Wed Jan 10, 2018 12:20 pm

*bump*
 
User avatar
davey
just joined
Posts: 9
Joined: Tue Jan 17, 2017 1:22 pm
Location: Nairobi Kenya
Contact:

Re: Request: IP-SLA

Mon Dec 14, 2020 11:08 am

Bump ++
 
uberdome
Frequent Visitor
Frequent Visitor
Posts: 97
Joined: Fri Oct 31, 2014 5:50 pm

Re: Request: IP-SLA

Tue Feb 07, 2023 9:22 pm

IP-SLA would be very useful. I'm specifically interested in the VoIP RTP packet / MOS report that Cisco offers.
 
elico
Member Candidate
Member Candidate
Posts: 158
Joined: Mon Nov 07, 2016 3:23 am

Re: Request: IP-SLA

Fri Jul 12, 2024 6:25 pm

I opened a post in the scripting section:
viewtopic.php?p=1085355

I believe some of these can be done using a container which has more powerful tools them what's already on RouterOS.
The basic thing to do is to write a script that will verify if the WAN connection is up in the HTTP level.
Also combine with that either a traceroute or ping tests which will help to find out the current state of the connection.
Once you have fq_codel and you can test for buffer bloat then all the other things are much easier to test.
I believe a simple linux cli tool under a Prometheus script exporter or another tool can provide the relevant information.
With this in mind, let say you have 2 to 4 wan connections you can dedicate a container per WAN interface and in the container service use some basic caching/storage and run a set of tests every couple seconds(3-20?) and periodically(30 - 60 Minutes) also run a short speed test which will provide more insights on the wan connections.

What do you think?
 
alidamji
just joined
Posts: 13
Joined: Sat Jul 25, 2009 1:54 pm

Re: Request: IP-SLA

Fri Jul 12, 2024 7:27 pm

+1 add DISMAN-PING-MIB to SNMP