FreeRadius crashed on accounting load tests with 1000 concurrent clients

Alan DeKok aland at deployingradius.com
Tue Nov 10 11:35:50 CET 2009


Dinh Pham Cong wrote:
> start_servers = 1024
> max_servers = 3000
> max_spare_servers = 3000

  That's a little high.

> My sql.conf
> 
> # number of sql connections to make to server
> num_sql_socks = 1000

  Remember: 1000 packets/s does *not* mean 1000 threads or 1000 SQL
sockets.  The server should be able to do 1000 packets/s with a much
smaller number of threads && sockets.  i.e. 50/50.

> I developed a Java client that can create 1000 concurrent threads that
> connect and send accounting requests (start and stop) to Radius server.

  See also "radperf" (http://networkradius.com/radperf.html).  It can do
load testing and user login simulations.

> However, after sending for 20 or 30 seconds, radius server generated a
> lot of error messages and crashed
> 
> Error messages
> 
> Tue Nov 10 16:14:34 2009 : Error: Discarding duplicate request from
> client tester1 port 41442 - ID: 134 due to unfinished request 2436

  This is likely because your SQL database is too slow.

  Have you checked to see if the SQL database can handle 1000 inserts/s?

> Crashed
> 
> Nov 10 15:55:35 Mobile6 kernel: radiusd[22242]: segfault at
> 00000000000000c8 rip 0000003daee5306b rsp 00002aae5d82a780 error 4

  See doc/bugs for instructions on producing useful crash reports.  We
can then use these to fix bugs.

> Nov 10 15:57:29 Mobile6 kernel: radiusd[30941]: segfault at
> 00000000000000c8 rip 0000003daee5306b rsp 00002aaee56de180 error 4
> Nov 10 16:14:36 Mobile kernel: radiusd[10788]: segfault at
> 00000000000000c8 rip 0000003daee5306b rsp 00002aac913de780 error 4
> 
> What do I need to do to enable FreeRadius server to meet more than 1000
> accounting request (INSERT AND DELETE) for a second?

  Use a database that can handle 1000 requests/s.

  Alan DeKok.



More information about the Freeradius-Users mailing list