Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 02 Feb 2012 11:46:17 +0100
From:      Damien Fleuriot <ml@my.gd>
To:        peter knezel <peter.knezel@gmail.com>
Cc:        freebsd-questions@freebsd.org
Subject:   Re: carp+devd+ifstated on master problem
Message-ID:  <4F2A6979.9090403@my.gd>
In-Reply-To: <CAAwfu_nOgDU-K2=NErBOGteraAOQh1P8bMCTiCzWnpaeFJ3Fkw@mail.gmail.com>
References:  <CAAwfu_nrrqod80kg2qO28-LBuubiZe_BV--PoNxqjn_OUrV=hg@mail.gmail.com> <4F292596.2090000@my.gd> <CAAwfu_nOgDU-K2=NErBOGteraAOQh1P8bMCTiCzWnpaeFJ3Fkw@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
We're using ifstated to send nagios passive alerts in case a lagg or
carp's interface's state should become degraded.

Find below the config we're using:








carp_up = "carp410.link.up && carp13.link.up"
carp_down = "carp410.link.down && carp13.link.down"
carp_unknown = "carp410.link.unknown || carp13.link.unknown"
init-state auto

state auto {
	set-state inconnu
	if $carp_up {
		set-state primary
	}
	if $carp_down {
		set-state backup
	}
        if $carp_unknown {
                set-state inconnu
        }
}

state primary {
	init {
		run "echo \"pf1-gs.hipay;carp;0;carp Master\"| send_nsca_2.7 -H
monit1.hipay.eqx -d \";\" -c /usr/local/etc/send_nsca.cfg"
		run "echo \"pf1-gs.hipay;carp;0;carp Master\"| send_nsca_2.7 -H
monit1.hipay -d \";\" -c /usr/local/etc/send_nsca.cfg"
	}
        if $carp_down {
                set-state backup
        }
        if $carp_unknown {
                set-state inconnu
        }
        if bce0.link.up && bce1.link.up {
                run "echo \"pf1-gs.hipay;bond;0;BONDING OK\"|
send_nsca_2.7 -H monit1.hipay.eqx -d \";\" -c /usr/local/etc/send_nsca.cfg"
		run "echo \"pf1-gs.hipay;bond;0;BONDING OK\"| send_nsca_2.7 -H
monit1.hipay -d \";\" -c /usr/local/etc/send_nsca.cfg"
        }
        if bce0.link.down || bce1.link.down {
                run "echo \"pf1-gs.hipay;bond;2;BONDING DEGRADED\"|
send_nsca_2.7 -H monit1.hipay.eqx -d \";\" -c /usr/local/etc/send_nsca.cfg"
		run "echo \"pf1-gs.hipay;bond;2;BONDING DEGRADED\"| send_nsca_2.7 -H
monit1.hipay -d \";\" -c /usr/local/etc/send_nsca.cfg"
        }
}


state backup {
	init {
		run "echo \"pf1-gs.hipay;carp;2;carp Backup\"| send_nsca_2.7 -H
monit1.hipay.eqx -d \";\" -c /usr/local/etc/send_nsca.cfg"
		run "echo \"pf1-gs.hipay;carp;2;carp Backup\"| send_nsca_2.7 -H
monit1.hipay -d \";\" -c /usr/local/etc/send_nsca.cfg"
	}
        if $carp_up {
                set-state primary
        }
        if $carp_unknown {
                set-state inconnu
        }
        if bce0.link.up && bce1.link.up {
		run "echo \"pf1-gs.hipay;bond;0;BONDING OK\"| send_nsca_2.7 -H
monit1.hipay.eqx -d \";\" -c /usr/local/etc/send_nsca.cfg"
		run "echo \"pf1-gs.hipay;bond;0;BONDING OK\"| send_nsca_2.7 -H
monit1.hipay -d \";\" -c /usr/local/etc/send_nsca.cfg"
        }
        if bce0.link.down || bce1.link.down {
		run "echo \"pf1-gs.hipay;bond;2;BONDING DEGRADED\"| send_nsca_2.7 -H
monit1.hipay.eqx -d \";\" -c /usr/local/etc/send_nsca.cfg"
		run "echo \"pf1-gs.hipay;bond;2;BONDING DEGRADED\"| send_nsca_2.7 -H
monit1.hipay -d \";\" -c /usr/local/etc/send_nsca.cfg"
        }

}

state inconnu {
	init {
		run "echo \"pf1-gs.hipay;carp;2;carp INIT\"| send_nsca_2.7 -H
monit1.hipay.eqx -d \";\" -c /usr/local/etc/send_nsca.cfg"
		run "echo \"pf1-gs.hipay;carp;2;carp INIT\"| send_nsca_2.7 -H
monit1.hipay -d \";\" -c /usr/local/etc/send_nsca.cfg"
	}
        if $carp_up {
                set-state primary
        }
        if $carp_down {
                set-state backup
        }
        if bce0.link.up && bce1.link.up {
                run "echo \"pf1-gs.hipay;bond;0;BONDING OK\"|
send_nsca_2.7 -H monit1.hipay.eqx -d \";\" -c /usr/local/etc/send_nsca.cfg"
		run "echo \"pf1-gs.hipay;bond;0;BONDING OK\"| send_nsca_2.7 -H
monit1.hipay -d \";\" -c /usr/local/etc/send_nsca.cfg"
        }
        if bce0.link.down || bce1.link.down {
                run "echo \"pf1-gs.hipay;bond;2;BONDING DEGRADED\"|
send_nsca_2.7 -H monit1.hipay.eqx -d \";\" -c /usr/local/etc/send_nsca.cfg"
		run "echo \"pf1-gs.hipay;bond;2;BONDING DEGRADED\"| send_nsca_2.7 -H
monit1.hipay -d \";\" -c /usr/local/etc/send_nsca.cfg"
        }
}















On 2/2/12 11:25 AM, peter knezel wrote:
> Hello Damien,
> 
> of course, the tnewpass was my copy error - newpass is OK and is in
> config files  everywhere.
> And the carp interfaces' advskew, vhid and
> pass are already in /etc/rc.conf.local.
> 
> What I simply would like to try is run scripts if carp interfaces change.
> Actually my real aim is to synchronize file from slave server to
> master if master reboots or slave becomes master due to carp problems
> on the master.
> Regards,
> Peter
> 
> 
> On 01/02/2012, Damien Fleuriot <ml@my.gd> wrote:
>>
>>
>> On 2/1/12 12:12 PM, peter knezel wrote:
>>> Hello all,
>>>
>>> I have configured devd and ifstated on a master FreeBSD server (slave
>>> not changed so far) on which carp was configured with three
>>> carp0,carp1 and carp2 virtual addresses.
>>>
>>> When I as root do ifconfig carp0 down and up, the corresponding
>>> testdown.sh and testup.sh
>>> scripts are run (defined in ifstated.conf).
>>> The status of carp0 interface changes to INIT then to MASTER (after
>>> ifconfig carp0 up).
>>>
>>> However this is not valid when doing the same with carp1 or carp2.
>>> It goes to INIT+testdown.sh executed but then immediately afterwards
>>> it goes to MASTER+testup.sh executed.
>>>
>>> What can be the problem?
>>>
>>> cd /usr/local/etc
>>> cat ifstated.conf
>>> init-state one
>>>
>>> net = '( "ifconfig -a -u |grep carp0 > /dev/null" every 3 && "ifconfig -a
>>> -u
>>> |grep carp1 > /dev/null" every 3 && "ifconfig -a -u |grep carp2 >
>>> /dev/null"
>>> every 3)'
>>>
>>> state one {
>>>         if ( ! $net ) {
>>>                 run "/sbin/ifconfig_carp0 vhid 1 pass newpass
>>> 192.xx.xx.1/24"
>>>                 run "/sbin/ifconfig carp1 vhid 2 pass newpass
>>> 192.xx.xx.2/24"
>>>                 run "/sbin/ifconfig carp2 vhid 3 pass newpass
>>> 192.xx.xx.3/24"
>>>                 run "/usr/local/testdown.sh"
>>>                 set-state two
>>>         }
>>> }
>>>
>>> state two {
>>>         if ( $net ) {
>>>                 run "/sbin/ifconfig carp0 vhid 1 advskew 100 pass
>>> tnewpass 192.xx.xx.1/24"
>>>                 run "/sbin/ifconfig carp1 vhid 2 advskew 100 pass
>>> newpass 192.xx.xx.2/24"
>>>                 run "/sbin/ifconfig carp2 vhid 3 advskew 100 pass
>>> newpass 192.xx.xx.3/24"
>>>                 run "/usr/local/testup.sh"
>>>                 set-state one
>>>         }
>>> }
>>>
>>> In addition I had to configure devd.conf to have ifdown.sh and ifup.sh
>>> scripts executed when reboot is done on the master.
>>>
>>> notify 30 {
>>> match "system" "IFNET";
>>> match "subsystem" "carp0";
>>> match "type" "LINK_UP";
>>> action "/usr/local/etc/rc.d/ifdown.sh";
>>> };
>>>
>>> notify 30 {
>>> match "system" "IFNET";
>>> match "subsystem" "carp0";
>>> match "type" "LINK_DOWN";
>>> action "/usr/local/etc/rc.d/ifup.sh";
>>>
>>> Thanks for any suggestion in advance.
>>>
>>> Ardi
>>
>> I'm not sure I get what you're trying to do here.
>>
>> Is there a reason you do not set your carp interfaces' advskew, vhid and
>> pass in /etc/rc.conf ?
>>
>> Also, I notice in state 2 your password for carp0 is tnewpass, while the
>> other ones are newpass.
>>
>> _______________________________________________
>> freebsd-questions@freebsd.org mailing list
>> http://lists.freebsd.org/mailman/listinfo/freebsd-questions
>> To unsubscribe, send any mail to "freebsd-questions-unsubscribe@freebsd.org"
>>



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?4F2A6979.9090403>