Forum Discussion
just for giggles, is the iRule switch performance any different if the switch cases are bound since all the pool destinations are the same? Example:
when CLIENT_ACCEPTED {
set time(iRULE_50switch_default) [clock clicks]
}
when HTTP_REQUEST {
switch -exact -- [HTTP::host] {
"www.domain-01.de" -
"www.domain-02.de" -
... truncated ...
"www.domain-49.de" -
"www.domain-50.de" { pool www.itacs.de }
default { pool REST_API }
}
lappend time(LTP_50rules_default) [clock clicks]
eval $static::debug_page
}
similar for the policy, a single condition with all the hosts in the matches any field...
Hi Jason,
for the [switch] it does basically dont matter if multiple condition trigger the same script or different scripts. The overhead from evaluating 50 strings is the same...
Single Script:
when HTTP_REQUEST {
lappend time(iRule_50rules_single_scripts) [clock clicks]
switch -exact -- [HTTP::host] {
"www.domain-01.de" -
"www.domain-02.de" -
... truncated ...
"www.domain-48.de" -
"www.domain-49.de" -
"www.domain-50.de" { pool www.itacs.de }
default { pool REST_API }
}
lappend time(iRule_50rules_single_scripts) [clock clicks]
eval $static::debug_page
}
Many individual Scripts:
when HTTP_REQUEST {
lappend time(iRule_50rules_single_scripts) [clock clicks]
switch -exact -- [HTTP::host] {
"www.domain-01.de" { pool www.itacs.de }
"www.domain-02.de" { pool www.itacs.de }
... truncated ...
"www.domain-50.de" { pool www.itacs.de }
"www.domain-50.de" { pool www.itacs.de }
default { pool REST_API }
}
lappend time(iRule_50rules_single_scripts) [clock clicks]
eval $static::debug_page
}
But it does matter if you trigger [switch]'s first (see below) or default (see above) conditions....
1st hit:
25th hit:
50th hit:
Old facts remaining the same. The more item in the list and the deeper your have to dig into the list the longer it takes to evaluate it.
Lets see if we can find some better replacements for [switch]...
Using [if]:
when HTTP_REQUEST {
lappend time(iRule_5if_1st_hit) [clock clicks]
if { [HTTP::host] eq "www.domain-01.de" } then { pool www.itacs.de }
elseif { [HTTP::host] eq "www.domain-02.de" } then { pool www.itacs.de }
elseif { [HTTP::host] eq "www.domain-03.de" } then { pool www.itacs.de }
elseif { [HTTP::host] eq "www.domain-04.de" } then { pool www.itacs.de }
elseif { [HTTP::host] eq "www.domain-05.de" } then { pool www.itacs.de }
else { pool REST_API }
lappend time(iRule_5if_1st_hit) [clock clicks]
eval $static::debug_page
}
1st hit [if] is slightly quicker than [switch}, 5th hit [if] is about the same as [switch]. Nothing new about...
[eval] loading a script from static::array() with 1.000.000 bucket entries
when RULE_INIT {
for { set x 1 } { $x < 1000000 } { incr x } {
set my_conditional_scripts(www.domain-${x}.de) { pool www.itacs.de }
}
}
when HTTP_REQUEST {
lappend time(iRule_eval_1million_bucket) [clock clicks]
if { [catch {
eval $my_conditional_scripts([HTTP::host])
}] } then {
pool REST_API
}
lappend time(iRule_eval_1million_bucket) [clock clicks]
eval $static::debug_page
}
Performance in the range of a 50-entry [switch] statemen, not bad. Can LTP handle 1M URLs? And how fast?
Will do some additional LTP tests in the evening. Lets see where LTP limits are...
Cheers, Kai
- JRahmDec 09, 2022Admin
Some of this reminds me of an article Joe did years ago to test where the sweet spots were for if/else vs switch vs class matching.
https://community.f5.com/t5/technical-articles/comparing-irule-control-statements/ta-p/282675
- Kai_WilkeDec 09, 2022MVP
Joe did some great work back then.
The only highly argueable part in his article is the conslusion, that [switch] is overall the best choice across the board.
His article did somehow not included a comparsion with just 1 or 5 items to compare. This is the area where [if] starts to shine. Beyond that scale [switch] will be undoubtedly the better choice.
When I started with iRules i've read Joes article and basically used [switch] everywhere. Took me a while to review my code and migrate back to [if] once I saw test results on TCL boards and did my own tests...
Over the years I've faced a couple guys who stricly followed this article and used also [switch] everywhere.... so it wasnt just me who followed his conclusion 😉
Cheers, Kai
- JRahmDec 09, 2022Admin
I think in user group presentations we landed on guidance of if/else for only the simplest solutions, switch to maybe 20, and data-groups for everything else.