funkdaddy_31014
Nov 21, 2011Nimbostratus
maintenance iRule behavior - multiple redirect/respond and event disable
Hello iRules gurus!
We have an iRule called "maintenance" that we put up on many VIPs (with highest priority - fires first) at once when we're doing scheduled maintenance that should respond to all client requests from outside our network with HTML showing that the site is under maintenance. Only problem is that it doesn't behave exactly as designed. The iRule below generally works EXCEPT when one of the other iRules on the associated VIPs hits an HTTP::respond or HTTP::redirect, in which case we get a TCL Error "Multiple redirect/respond invocations not allowed".
Maintenance iRule:
when HTTP_REQUEST priority 10 {
if { ([matchclass [IP::client_addr] equals $::internal_net]) } {
for matched IPs - allows pass-thru
} else {
switch -glob [HTTP::path] {
"/xyz" {
exception to maint page - do something here
}
default {
HTTP::respond 200 content {
html content here
}
event disable
}
}
}
}
I have tried the adding an "event disable" (see commented out line above) to stop future HTTP_REQUEST events from firing. This appears to work but ONLY on the first load. Successive refreshes from the client browser will, for some reason, then bypass the maintenance page and display the content we're trying to block from the outside. Does anyone have a reasonable explanation for why that fails?
Short of catching all the HTTP::respond and HTTP::redirect's from the other iRules, is there a better solution or implementation of "event disable" to make this work?
Thanks!
-funkdaddy