【freeradius2.x】 安装和学习
虚拟机中centos 安装和学习 radius2 版本是2.2.x 的使用等知识
安装
为了测试方面,yum安装
yum -y install freeradius*
配置文件的位置是 /etc/raddb/
编译安装可能在 /usr/local/etc/raddb
# /etc/init.d/radiusd
用法:/etc/init.d/radiusd {start|stop|status|restart|condrestart|try-restart|reload|force-reload}
yum会自动生成服务脚本,然后可以把radius当做服务直接使用了
配置文件
[root@orangleliu raddb]# tree -L 1
.
├── acct_users
├── attrs
├── attrs.access_challenge
├── attrs.access_reject
├── attrs.accounting_response
├── attrs.pre-proxy
├── certs
├── clients.conf
├── dictionary
├── eap.conf
├── example.pl
├── hints
├── huntgroups
├── ldap.attrmap
├── modules
├── panic.gdb
├── policy.conf
├── policy.txt
├── preproxy_users
├── proxy.conf
├── radiusd.conf
├── sites-available
├── sites-enabled
├── sql
├── sql.conf
├── sqlippool.conf
├── templates.conf
└── users
5 directories, 23 files
配置文件结构大概这样子,大部分的功能都是通过配置文件来完成的,对于配置文件的熟悉非常重要,每个配置文件中都有大量的说明,仔细阅读一遍基本也知道如何操作。
radtest 是用来测试的工具,检查和测试非常有用。
radiusd.conf
主配置文件clients.conf
用来配置客户端 里面应该对应 NAS设备(例如BRAS),自带了一个本地测试clientusers
配置了用户信息,针对某些用户设置认证规则,只能使用pap的模式,可以设置密码加密sql.conf
配置使用哪种数据库等,以及sql规则等site-available site-enabled
是存放 virtual server的目录,类似Apache的配置策略
概念
NAS 设备: 网络接入设备,这里一般是 Radius Client
认证和权鉴 使用 UDP 1812端口
计费 使用 UDP 1813端口
命令
radiusd
freeradius主程序,一般调试调试模式 使用radiusd -Xx
来启动radlast
用来查询用户通过NAS登录的情况radtest
用来模拟NAS设备发送请求radwho
查看当前在线的用户,可能因为配置编译等原因不好使radrap
关闭某个NAS的所有session
功能
认证
3个常用的认证协议,这三种协议都需要有用户名和密码,算是文本协议,所以还挺容易观察和测试
PAP
redtest
命令默认就是使用这个协议,使用最广泛的协议。NAS会使用 用户名和加密之后的密码 和Radius服务器交互
密码明文存储
测试, 用户信息在user文件中配置
radtest alice passme 127.0.0.1 100 testing123
Sending Access-Request of id 41 to 127.0.0.1 port 1812
User-Name = "alice"
User-Password = "passme"
NAS-IP-Address = 127.0.0.1
NAS-Port = 100
Message-Authenticator = 0x00000000000000000000000000000000
rad_recv: Access-Accept packet from host 127.0.0.1 port 1812, id=41, length=40
Framed-IP-Address = 192.168.59.103
Reply-Message = "Hello, alice"
CHAP
PAP 的升级版本
增加握手
密码明文存储 密码交互使用密文
MS-CHAP
- 微软版本的 CHAP 协议
EAP 拓展协议
用户存储
头两个种方式都不推荐
文件方式 使用配置文件 users 文件来存储用户和密码
Unix 系统用户 其实是使用
/etc/shadow
来存储的用户信息(但是要注意权限问题,需要再 site-enable 中authorize 中打开unix配置)数据库方式 例如Mysql。
安装mysql插件
yum install freeradius2-mysql
创建数据库,导入初始化输入(根据文档就好了)
编辑
radius.conf
中# $INCLUDE sql.conf
行的注释编辑
sql.conf
中 msql 的认证信息编辑
sites-enabled/default
中authorize
部分 去掉 sql 的选项注释
计费过程
计费和认证相对独立的,需要NAS来控制整个过程。
可以用来统计用户上网时间,以及流量数据等。
计费开始发送
Accounting-Request
请求, 开始一个session,分配一个session-id计费请求中状态字段 Acct-Status-Type 为
Start, Interim-Update, Stop
来操作session的生命周期
问题
配置多个数据库
参考freeradius-checking-account-on-multiple
首先要编辑 数据库配置文件 sql.conf 增加一个sql配置块, sql dbname {} dbname类似别名,配置项照着原来的配置写就好了
然后把
site-enable/default
原来的配置项sql 注释掉 增加 dbname,就会使用 dbname中配置的数据库了
学习资料
【freeradius2.x】 安装和学习的更多相关文章
- 20165226 预备作业3 Linux安装及学习
20165226 预备作业3 Linux安装及学习 Linux安装 一.下载安装VirtualBox 1.首先在官网下载,点开基于VirtualBox虚拟机安装Ubuntu图文教程 找到版本进行下载安 ...
- 20165230 预备作业3 Linux安装及学习
20165230 预备作业3 Linux安装及学习 安装Linux操作系统 通过学习实践基于VirtualBox虚拟机安装Ubuntu图文教程,开始了虚拟机的安装,根据教程按着步骤一步一步的完成. 遇 ...
- Torch的安装和学习
Long long ago, 就已经安装好Torch,这里再记录一下.Torch是Facebook开发的用于AI的科学计算框架,可广泛运用于机器学习的很多算法.相比Caffe,其接口运用更加方便,使用 ...
- 20165237 预备作业3 Linux安装及学习
Linux安装及学习 安装 对操作系统略知一二的我,按照老师发的基于VirtualBox虚拟机安装Ubuntu图文教程慢慢一步步往下做,虽然中间有些小困难,但最终都得以解决,安装成功. 遇到的小困难: ...
- 20165325 预备作业3 Linux安装及学习
Linux安装及学习 一.VirtualBox和Ubuntu安装 问题一:虚拟机中Ubuntu的版本 在设置虚拟机的操作系统的版本时,我发现我的电脑只能设置32-bit的Ubuntu版本.教程上选用了 ...
- 20165206 预备作业3 Linux安装及学习
Linux的安装与学习 - 在自己笔记本上安装Linux操作系统 在安装虚拟机的过程中遇到了不少问题,但也都进行了尝试并得到了解决.首先是在安装VirtulBox的安装上,按照老师给的链接下载安装,不 ...
- redis 安装配置学习笔记
redis 安装配置学习笔记 //wget http://download.redis.io/releases/redis-2.8.17.tar.gz 下载最新版本 wget http://downl ...
- 20165317 Linux安装及学习
Linux安装及学习 一.Linux的安装 我通过virtualbox和ubuntu官网下载了virtualbox5.2.6和ubuntu17.04版本. 在操作过程中,我基本是按照老师的步骤进行的, ...
- 20165336 预备作业3 Linux安装及学习
Linux 安装及学习 一.VirtualBox和Ubuntu的安装 依照老师所给的步骤下载了VirtualBox 5.2.6和Ubuntu 16.04.3. 按照步骤一步一步进行了安装,出现的问题有 ...
随机推荐
- Programming In Scala笔记-第十七章、Scala中的集合类型
本章主要介绍Scala中的集合类型,主要包括:Array, ListBuffer, Arraybuffer, Set, Map和Tuple. 一.序列 序列类型的对象中包含多个按顺序排列好的元素,可以 ...
- 在做自动化测试之前你需要知道的,转自:http://www.cnblogs.com/fnng/p/3653793.html
什么是自动化测? 做测试好几年了,真正学习和实践自动化测试一年,自我感觉这一个年中收获许多.一直想动笔写一篇文章分享自动化测试实践中的一些经验.终于决定花点时间来做这件事儿. 首先理清自动化测试的概念 ...
- iOS 滚动视图的复用问题解决方案
LazyScroll是什么 LazyScrollView 继承自ScrollView,目标是解决异构(与TableView的同构对比)滚动视图的复用回收问题.它可以支持跨View层的复用,用易用方式来 ...
- Unity UGUI图文混排(七) -- 下划线
之前更新超链接的时候,忘了搭配实现一个下划线的功能,这篇文章就是来补上这一个功能,时间有点长,一方面没有很好的思路,一方面也没多少时间. 先在网上收集了一下下划线的实现操作,一种是在文本下再创建一个文 ...
- npm管理工具介绍
概述 Npm是NodeJS包管理工具,在最新版本中Nodejs集成了npm,可以通过输入 "npm -v" 来测试是否成功安装.如果你安装的是旧版本的 npm,可以通过 npm 命 ...
- CVS简介
CVS - Concurrent Versions System(并发版本管理系统)是一个版本控制管理系统,它是SVN出现之前最为广泛使用的一个版本控制系统. CVS的优点就不多说了,总之没有它,早期 ...
- Microsoft Dynamics CRM 2013/2015 选项集的多选
CRM中的选项集多选一直是客户需求中的必选项,但从CRM进国内的3.0时代开始到目前的2015版本均没有提供该功能,但既然客户要了就得想办法满足,既然CRM本身的功能上不支持,那我们只有使用非官方支持 ...
- 直接内存访问(DMA)
1. 什么是DMA 直接内存访问是一种硬件机制,它允许外围设备和主内存之间直接传输它们的I/O数据,而不需要系统处理器的参与.使用这种机制可以大大提高与设备通信的吞吐量. 2. DMA数据传输 有 ...
- Android之Notification-android学习之旅(二)
notification常用于下拉式的消息推送. Notification的构成 Nitification的实例 1.新建一个Builder,要选Notification.compat包. 2.然后用 ...
- app如何更换用户头像信息呢?不妨这样做
对于现在的手机应用而言,要想获得更多的人的使用,就需要给用户更多的自由功能才行,这也是基于用户体验开发软件的核心思想,一切以用户为中心,想用户之所想,做用户之所需.今天我就来谈一谈刚学到的一个关于设置 ...