FreeRadius
Установка
На все предупреждения ./configure кроме rlm_perl
и rlm_sql_mysql
можно не обращать внимания.
На удаленном сервере установите libmysqlclient и libmysqlclient-dev
Проверка PERL
Code Block |
---|
language | bash |
---|
title | Проверка версии Perl |
---|
|
apt-get install libperl-dev -yq
find /usr/lib/ | grep libperl.so
/usr/lib/x86_64-linux-gnu/libperl.so.5.22
/usr/lib/x86_64-linux-gnu/libperl.so.5.22.1 |
Делаем симлинк для того, чтобы библиотека подгрузилась во время компиляции
Code Block |
---|
|
ln -s /usr/lib/x86_64-linux-gnu/libperl-dev .so.5.22 /usr/lib/x86_64-linux-gnu/libperl.so |
Code Block |
---|
|
apt-get install -yq gcc make libtalloc-dev
cd /tmp
wget ftp://ftp.freeradius.org/pub/freeradius/freeradius-server-23.20.1017.tar.gz
tar zxvf freeradius-server-23.20.1017.tar.gz
cd freeradius-server-23.20.1017
./configure --prefix=/usr/local/freeradius --with-rlm-perl-lib-dir=/usr/lib/x86_64-linux-gnu/ \
--with-dhcp=yes --with-openssl=no > 1/dev/null
make
&& make install |
Настройка
Code Block |
---|
|
cprm /usr/abillslocal/misc/freeradius/v2/radiusd.conf /usr/localetc/raddb/sites-enabled/*
cp misc/freeradius/etcv3/raddb/radiusd.conf
rm -f mods-enabled/perl /usr/local/freeradius/etc/raddb/sitesmods-enabled/*perl
cp /usr/abills/misc/freeradius/v2/users_perlv3/mods-enabled/sql /usr/local/freeradius/etc/raddb/mods-enabled/userssql
cp /usr/abills/misc/freeradius/v3/v2sites-enabled/abills_default_rlm_perl /usr/local/freeradius/etc/raddb/sites-enabled/abills_default
cp /usr/abills/misc/freeradius/v2v3/perlusers /usr/local/freeradius/etc/raddb/modules/
users
ln -s /usr/local/freeradius/sbin/radiusd /usr/sbin/radiusd |
Файл для автозапуска ,- создаем и вставляем в него следующий текст
Code Block |
---|
|
nano /etc/init.d/radiusd |
Code Block |
---|
|
#!/bin/sh
# Start/stop the FreeRADIUS daemon.
### BEGIN INIT INFO
# Provides: radiusd
# Required-Start: $remote_fs $network $syslog
# Should-Start: $time mysql slapd postgresql samba krb5-kdc
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Radius Daemon
# Description: Extensible, configurable radius daemon
### END INIT INFO
set -e
. /lib/lsb/init-functions
PROG="radiusd"
PROGRAM="/usr/sbin/radiusd"
PIDFILE="/usr/local/freeradius/var/run/radiusd/radiusd.pid"
DESCR="FreeRADIUS daemon"
test -f $PROGRAM || exit 0
# /var/run may be a tmpfs
if [ ! -d /var/run/radiusd ]; then
mkdir -p /var/run/radiusd
chown freerad:freerad /var/run/radiusd
fi
export PATH="${PATH:+$PATH:}/usr/sbin:/sbin"
ret=0
case "$1" in
start)
log_daemon_msg "Starting $DESCR" "$PROG"
start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $PROGRAM || ret=$?
log_end_msg $ret
exit $ret
;;
stop)
log_daemon_msg "Stopping $DESCR" "$PROG"
if [ -f "$PIDFILE" ] ; then
start-stop-daemon --stop --retry=TERM/30/KILL/5 --quiet --pidfile $PIDFILE || ret=$?
log_end_msg $ret
else
log_action_cont_msg "$PIDFILE not found"
log_end_msg 0
fi
;;
restart|force-reload)
$0 stop
$0 start
;;
*)
echo "Usage: $0 start|stop|restart|force-reload"
exit 1
;;
esac
exit 0 |
Code Block |
---|
|
chmod +x /etc/init.d/radiusd
update-rc.d radiusd defaults
update-rc.d radiusd enable |
Меняем в конфиге радиуса /usr/local/freeradius/etc/raddb/radiusd.conf:
Code Block |
---|
|
nano /usr/local/freeradius/etc/raddb/radiusd.conf
prefix = /usr/local/freeradius
libdir = /usr/local/freeradius/lib
user = freerad
group = freerad |
Благодаря модулю sql
, можно хранить сервера доступа в базе данных (всё равно необходим перезапуск радиуса после добавления/изменения серверов, но не надо править clients.conf).
Очищаем список серверов доступа из /usr/local/freeradius/etc/raddb/clients.conf (чтоб не было дубликатов из-за записей в базе)
Code Block |
---|
|
echo '' > /usr/local/freeradius/etc/raddb/clients.conf
cp /usr/abills/misc/freeradius/v2/sql.conf /usr/local/freeradius/etc/raddb/ |
Заполняем нужные нам параметры соединения с БД
Code Block |
---|
|
nano /usr/local/freeradius/etc/raddb/sql.conf |
Code Block |
---|
|
sql {
database = "mysql"
driver = "rlm_sql_${database}"
server = "localhost"
#port = 3306
login = "abills"
password = "sqlpassword"
radius_db = "abills"
# В самом конце файла
'%secretkey%' меняем на 'test12345678901234567890' |
Создаём user и group. (если freeradius ранее не был установлен то без этого не стартует)
Code Block |
---|
|
groupadd freerad
useradd -g freerad -s /bash/bash freerad
chown -R freerad:freerad /usr/local/freeradius/etc/raddb |
Запуск radius в режиме отладки
Code Block |
---|
|
/usr/sbin/radiusd -X |
или
На всякий случай оставлю здесь: Кажется настроил, но никто не может подключиться
Если ошибок нет, запускаем
Code Block |
---|
|
service radiusd start |