Raspberry pi设置自动拨号,搭建无线路由环境

Raspberry pi设置自动拨号,搭建无线路由环境


  • 前言 

    raspberry pi(树莓派), 是一款针对电脑业余爱好者、教师、小学生以及小型企业等用户的迷你电脑,由于可以烧录Linux操作系统,因此可以衍生出各种各样的使用途径,诸如控制版,爬虫机器,个人vps,门禁系统…..本文主要介绍如何在raspberry pi上面完成pppoe拨号上网功能,以及如何利用raspberry pi完成路由转发功能,进而将其作为一个家用无线路由器来使用。


  • 准备环境

    1. raspberry pi 三代 b+版
    2. Kali Linux 镜像,点此链接下载最新镜像
    3. 一款Kali Linux支持的,拥有AP模式的USB网卡, 可以参考此链接
  • 烧录Kali Linux系统到SD卡片(此处略过)

    在windows上面,我们可以使用 Win32DiskImager工具进行镜像的烧录;在Linux宿主系统上面,可以利用dd命令直接将img镜像dump到sd卡里面,例如: 
    root@kali:~ dd if=kali-2.1.2-rpi.img of=/dev/sdb bs=512k

  • 安装必要软件 
    我们需要在Kali上面安装pppoe软件用来拨号,安装AP软件将Raspberry pi作为一个无线AP,安装dhcp软件用来给客户端分发IP地址,DNS等信息。

root@kali:~# apt-get install pppoe pppoeconf hostapd udhcpd 
  • 设置拨号 
    在这里,我们使用Raspberry pi的以太网网口接入网线进行拨号设置。在命令行输入如下指令:
root@kali:~# pppoeconf 

        在这里,会提示相应的配置文件将发生改变,点选Yes。

pppoe1

        下一步会提示在拨号的偏好设定,点选Yes。

pppoe2

        下一步会提示输入拨号的用户名,直接输入然后点击OK。

pppoe3

        下一步会提示输入拨号密码,直接输入然后点击OK。

pppoe4

        下一步会确认是否将ISP供应商提供的DNS信息写入配置,选Yes。

pppoe5

        下一步会提示修改ppp接口的MTU大小,选择Yes。

pppoe6

        下一步提示是否在开机启动的时候就进行ppp拨号,选择Yes。

pppoe7

        下一步提示是否现在进行拨号连接,选择Yes。

pppoe8

        拨号成功之后,利用ip命令查看ppp情况:

root@kali:~# ip a s ppp0
5: ppp0: <POINTOPOINT,MULTICAST,NOARP,UP,LOWER_UP> mtu 1488 qdisc pfifo_fast state UNKNOWN group default qlen 3
    link/ppp
    inet 10.12.6.137 peer 10.12.0.1/32 scope global ppp0
       valid_lft forever preferred_lft forever

root@kali:~# ip r s t main
default dev ppp0 scope link
10.12.0.1 dev ppp0 proto kernel scope link src 10.12.6.137
20.20.20.0/24 dev wlan1 proto kernel scope link src 20.20.20.1

        可以看到,已经拨号获取地址,ping一下 伟大的百度 试试……

root@kali:~# ping -c 3 www.baidu.com
PING www.a.shifen.com (119.75.217.109) 56(84) bytes of data.
64 bytes from 119.75.217.109 (119.75.217.109): icmp_seq=1 ttl=55 time=4.33 ms
64 bytes from 119.75.217.109 (119.75.217.109): icmp_seq=2 ttl=55 time=4.18 ms
64 bytes from 119.75.217.109 (119.75.217.109): icmp_seq=3 ttl=55 time=4.06 ms

--- www.a.shifen.com ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2002ms
rtt min/avg/max/mdev = 4.064/4.193/4.333/0.122 ms

        至此,pppoe拨号配置完毕。

  • 无线热点(AP)配置 
    首先查一下所用的无线网卡是否支持AP模式,我这里的无线网卡的标识为phy1, wlan1,可以看到,该网卡支持AP模式:
root@kali:~# iw phy1 info | grep -i ap
                 * AP
                 * AP/VLAN
                Capabilities: 0x172
                 * start_ap
                 * set_noack_map
                 * set_qos_map
                 * AP: 0x00 0x10 0x20 0x30 0x40 0x50 0x60 0x70 0x80 0x90 0xa0 0xb0 0xc0 0xd0 0xe0 0xf0
                 * AP/VLAN: 0x00 0x10 0x20 0x30 0x40 0x50 0x60 0x70 0x80 0x90 0xa0 0xb0 0xc0 0xd0 0xe0 0xf0
                 * AP: 0x00 0x20 0x40 0xa0 0xb0 0xc0 0xd0
                 * AP/VLAN: 0x00 0x20 0x40 0xa0 0xb0 0xc0 0xd0
                 * AP/VLAN
                 * #{ AP, mesh point } <= 8,
        HT Capability overrides:
        Device supports AP scan.

       下一步,编辑/etc/hostapd/hostapd.conf文件:

interface=wlan1 #使用的接口名称 
ssid=Raspberry_AP #AP的ssid名称 
hw_mode=g   #操作模式为IEEE 802.11g 
channel=11      #设置频段为11 
macaddr_acl=0 #启用mac地址白名单模式 
auth_algs=1 #定义802.11鉴权算法为Shared Key Authentication 
ignore_broadcast_ssid=0 #关闭broadcast_ssid功能 
wpa=2 #采用wpa2标准 
wpa_passphrase=raspberrypi  #密码 
wpa_key_mgmt=WPA-PSK #使用wpa2-psk类型进行加密 
wpa_pairwise=TKIP   #加密算法 
rsn_pairwise=CCMP #加密算法 

        编辑完毕之后,利用如下命令启动hostapd:

root@kali:~# /usr/sbin/hostapd -B -P /run/hostapd.pid \
 /etc/hostapd/hostapd.conf
  • 配置DHCP功能 
    编辑/etc/udhcpd.conf文件,修改如下内容:

# Sample udhcpd configuration file (/etc/udhcpd.conf)

# The start and end of the IP lease block

start           20.20.20.2      #default: 192.168.0.20
end             20.20.20.20     #default: 192.168.0.254


# The interface that udhcpd will use

interface       wlan1           #default: eth0

        配置完毕之后,启动udhcpd服务:

root@kali:~# udhcpd /etc/udhcpd.conf
  • 开启NAT转发功能 
    在Raspberry pi上面开启NAT功能,以实现路由转发。

root@kali:~# iptables -t nat -A POSTROUTING -o ppp0 -j MASQUERADE
root@kali:~# iptables -t filter -A FORWARD -i ppp0 -o wlan1 -m state --state RELATED,ESTABLISHED -j ACCEPT
root@kali:~# iptables -t filter -A FORWARD -i wlan1 -j ACCEPT
  • 连接测试 
    通过本地windows连接Raspberry_AP,并用本地cygwin尝试连接 伟大的百度……测试连通成功,至此Raspberry pi已经可以作为家庭路由器进行工作了!

pppoe9

[jiangche00.jiangche00-PC] ➤ ping www.baidu.com

正在 Ping www.a.shifen.com [119.75.217.109] 具有 32 字节的数据:
来自 119.75.217.109 的回复: 字节=32 时间=5ms TTL=54
来自 119.75.217.109 的回复: 字节=32 时间=6ms TTL=54
来自 119.75.217.109 的回复: 字节=32 时间=6ms TTL=54
来自 119.75.217.109 的回复: 字节=32 时间=11ms TTL=54

119.75.217.109 的 Ping 统计信息:
    数据包: 已发送 = 4,已接收 = 4,丢失 = 0 (0% 丢失),
往返行程的估计时间(以毫秒为单位):
    最短 = 5ms,最长 = 11ms,平均 = 7ms

原创文章,作者:jiangche00,如若转载,请注明出处:http://www.178linux.com/72057

(0)
jiangche00jiangche00
上一篇 2017-03-28 12:23
下一篇 2017-03-28 14:51

相关推荐

  • Linux磁盘及文件系统管理

    磁盘(Hard Disk Drive,简称HDD)是一种存储介质,传统的机械硬盘由一个或多个铝制或玻璃制的碟片组成,碟片外覆盖有铁磁性材料。 磁盘的物理结构一般由磁头与碟片、电动机、主控芯片与排线等部件组成;当主电动机带动碟片旋转时,副电动机带动一组(磁头)到相对应的碟片上并确定读取正面还是反面的碟面,磁头悬浮在碟面上画出一个与碟片同心的圆形轨道(磁轨或称柱…

    Linux干货 2015-04-20
  • 文件系统权限管理

    文件系统权限管理 文件及目录权限 文件系统上的权限是针对访问者的 访问者:     owner:属主,u     group:属组,g     other:其他,o 针对每个访问者有三种权限 r:readable w:writeable x…

    Linux干货 2016-11-05
  • DNS和BIND配置(第二部分)

    接第一部分课后练习 三、课后练习: 2、配置反向解析: 步骤一:写主配置文件:改成与上个实验相同,也可以自己写一个简单的配置文件,如下: [root@localhost tmp]# cat named.conf.new options { directory  "/var/named&qu…

    Linux干货 2016-10-17
  • Linux基础之安全加密及CA、证书实战应用

    一、建立私有CA并让客户端申请请求,需要两台虚拟机完成 1、建立私有CA,生成私钥 2、CA公司给自己,生成自签证书 3、为CA提供所需要的目录及文件(如果事先存在,此步骤可以跳过) 二、CA公司已建立,需要一台客户机配合CA签署证书 1、客户端用到证书,因此生成私钥 2、客户端生成证书签署请求 3、将请求通过可靠方式发送给CA主机,这里作为测试,因此使用s…

    Linux干货 2016-10-04
  • Redis基于keepalived的高可用实践

    接着上一章节来: Redis基于keepalived的高可用实现 方案拓扑图 测试方案 1.       手动关闭AppM keepalived进程确认keepalived主从变化,AppS1是否变更为主 2.       开启keepal…

    2015-03-05
  • mysql/mariadb基于ssl的主从复制

     当mysql/mariadb跨越互联网进行复制时别人可以窃取到mysql/mariadb的复制信息, 这些信息是明文的, 因此存在不安全性, 这里通过ssl对复制的信息进行加密      1. 创建证书中心 在主服务器上创建证书中心 cd /etc/pki/CA 生成私钥 (umask&…

    Linux干货 2016-12-05

评论列表(1条)

  • renjin
    renjin 2017-04-05 10:45

    刚刚开始就写这么高深的内容,挺不错,继续加油,排版也都很不错