Hi Sami,

> On Fri, Jun 28, 2013 at 03:40:02PM +0300, Sami Kähkönen wrote:
> Hi,
> 
> Here is a small patch to enable multiple IP support for eDir88 RA. To
> summarize, eDirectory supports multiple IP numbers in config file separated
> by comma.
> Example line in nds.conf:
>   n4u.server.interfaces=168.0.0.1@524,10.0.0.1@524
> 
> Current resource agent is unable to cope with such configurations.
> 
> This patch creates an array of IP:port configurations and checks them
> individually. Tested in SLES 11 SP2 HA environment with one and multiple
> IP's. All comments and additional testing are welcome.
> 
> Patch also in github: https://github.com/skahkonen/resource-agents

Sorry for the delay and many thanks for the patch. It looks good
to me. If you can, it would be good to make a pull request at
github.

Cheers,

Dejan


> Regards,
>   Sami Kähkönen
> 
> --
> @@ -238,14 +238,34 @@ eDir_status() {  **         ocf_log err "Cannot
> retrieve interfaces from $NDSCONF. eDirectory may not be correctly
> configured."
>   **          exit $OCF_ERR_GENERIC   **      fi   **-
> NDSD_SOCKS=$(netstat -ntlp | grep -ce "$IFACE.*ndsd")
> **     ** -    if [ "$NDSD_SOCKS" -eq 1 ] ; then   **+    # In case of
> multiple IP's split into an array
> ** +    # and check all of them   **+    IFS=', ' read -a IFACE2 <<< "$IFACE"
> ** +    ocf_log debug "Found ${#IFACE2[@]} interfaces from $NDSCONF."   **+
> ** +    counter=${#IFACE2[@]}   ** +   ** +    for IFACE in ${IFACE2[@]}   *
> * +    do   ** +        ocf_log debug "Checking ndsd instance for $IFACE"
> ** +        NDSD_SOCKS=$(netstat -ntlp | grep -ce "$IFACE.*ndsd")   ** +   *
> * +        if [ "$NDSD_SOCKS" -eq 1 ] ; then   ** +
> let counter=counter-1   ** +
> ocf_log debug "Found ndsd instance for $IFACE"   ** +
>  elif [ "$NDSD_SOCKS" -gt 1 ] ; then   ** +
> ocf_log err "More than 1 ndsd listening socket matched. Likely
> misconfiguration of eDirectory."
>   ** +           exit $OCF_ERR_GENERIC   ** +        fi   ** +    done   **+
> ** +    if [ $counter -eq 0 ] ; then   **         # Correct ndsd
> instance is definitely running
> ** -        # Further checks are superfluous (I think...)   **-
> return 0
> ** -    elif [ "$NDSD_SOCKS" -gt 1 ] ; then   **-        ocf_log err
> "More than 1 ndsd listening socket matched. Likely misconfiguration of
> eDirectory."
>   ** +        ocf_log debug "All ndsd instances found."   **+
> return 0;
> ** +    elif [ $counter -lt ${#IFACE2[@]} ]; then   **+        ocf_log
> err "Only some ndsd listening sockets matched, something is very
> wrong."
>   **          exit $OCF_ERR_GENERIC   **      fi   **    @@ -270,7
> +290,7 @@ eDir_status() {
> **          exit $OCF_ERR_GENERIC   **      fi   **     ** -
> # Instance is not running, but no other error detected.   ** +
> ocf_log debug "ndsd instance is not running, but no other error detected."
> **      return 1   **  }

> _______________________________________________________
> Linux-HA-Dev: [email protected]
> http://lists.linux-ha.org/mailman/listinfo/linux-ha-dev
> Home Page: http://linux-ha.org/

_______________________________________________________
Linux-HA-Dev: [email protected]
http://lists.linux-ha.org/mailman/listinfo/linux-ha-dev
Home Page: http://linux-ha.org/

Reply via email to