Date: Mon, 28 Sep 2009 14:10:00 GMT From: Sergey Bondarev <bond@techno-r.ru> To: freebsd-gnats-submit@FreeBSD.org Subject: misc/139214: libradius and 3 auth radius-servers Message-ID: <200909281410.n8SEA0EQ001117@www.freebsd.org> Resent-Message-ID: <200909281420.n8SEK3NT065152@freefall.freebsd.org>
next in thread | raw e-mail | index | archive | help
>Number: 139214 >Category: misc >Synopsis: libradius and 3 auth radius-servers >Confidential: no >Severity: serious >Priority: medium >Responsible: freebsd-bugs >State: open >Quarter: >Keywords: >Date-Required: >Class: sw-bug >Submitter-Id: current-users >Arrival-Date: Mon Sep 28 14:20:03 UTC 2009 >Closed-Date: >Last-Modified: >Originator: Sergey Bondarev >Release: 6.4 >Organization: >Environment: FreeBSD r5.ru 6.4-RELEASE-p3 FreeBSD 6.4-RELEASE-p3 #1: Sun Feb 1 16:19:33 MSK 2009 bond@r5.ru:/usr/obj/usr/src/sys/YADROPU i386 >Description: radius.conf acct 10.255.1.1 radius_password auth 10.250.1.100 radius_password auth 10.250.1.250 radius_password auth 10.255.1.1 radius_password Situation: 1. Freeradius on host 10.250.1.100 is not started, mpd4.4.1 try to auth user on radius-server. libradius try 10.250.1.100 - wait timeout, then try 10.250.1.250 and succefully authentificate user. 2. HOST 10.205.1.100 is DOWN. mpd4.4.1 try to auth user on radius-server. libradius try 10.250.1.100, get error -1 and exit. libradius do not try other auth-radius-servers !!! mpd.log Sep 28 15:06:25 r5 mpd: [pptp14] AUTH: Auth-Thread started Sep 28 15:06:25 r5 mpd: [pptp14] AUTH: Trying RADIUS Sep 28 15:06:25 r5 mpd: [pptp14] RADIUS: RadiusAuthenticate for: user_login Sep 28 15:06:25 r5 mpd: [pptp14] RADIUS: rad_init_send_request failed: -1 sendto: Host is down Sep 28 15:06:25 r5 mpd: [pptp14] AUTH: RADIUS returned undefined Sep 28 15:06:25 r5 mpd: [pptp14] AUTH: Trying INTERNAL I see to radlib.c source: /* Send the request */ n = sendto(h->fd, h->request, h->req_len, 0, (const struct sockaddr *)&h->servers[h->srv].addr, sizeof h->servers[h->srv].addr); if (n != h->req_len) { if (n == -1) generr(h, "sendto: %s", strerror(errno)); else generr(h, "sendto: short write"); return -1; } Maybe remove "return -1;" ? Backup (round-robin) radius server configuration is no work ! >How-To-Repeat: >Fix: >Release-Note: >Audit-Trail: >Unformatted:
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200909281410.n8SEA0EQ001117>