嵌入式Linux系统OpenWRT路由的基本配置

摘要:OpenWRT是一个嵌入式Linux系统,想要了解嵌入式Linux系统的朋友有福了,今天小编要给大家介绍下OpenWRT路由的基本配置,感兴趣的朋友可不要错过了哈......

详情:

  OpenWRT是一个嵌入式Linux系统,想要了解嵌入式Linux系统的朋友有福了,今天小编要给大家介绍下OpenWRT路由的基本配置,一起来学习下吧。

  chnroutes 路由表

嵌入式Linux系统OpenWRT路由的基本配置

  这个路由表集中了所有分配到中国大陆的 IP 段,根据 http://ftp.apnic.net/apnic/stats/apnic/delegated-apnic-latest 每天自动更新,可使得在访问国内地址时不经过 VPN。

  想想如果能够让家里的路由直接连接 VPN,在家连接 WiFi 的所有设备直接达到Fan墙的效果,应该很 Cool,所以最近在某宝整了一个 Netgear WNDR3800 二手路由回来,先后分别在 DD-WRT 和 OpenWRT 成功配置 VPN + chnroutes,最后还是选择了 OpenWRT。

  DD-WRT vs OpenWRT

  关于 DD-WRT 和 OpenWRT,我选择 OpenWRT 主要因为 DD-WRT ROM 中集成的软件太多,绝大多数用不到,要配置 jffs2 来保存脚本文件,一般配置则保存在nvram中,而且无线较不稳定,5G频段常搜索不到(当然可能是我这个路由器型号的支持问题)。OpenWRT 的配置文件语法统一,配置都存储在文件系统中,且 ROM 本身仅集成了必备组件,非常小,可以只安装需要的东西,WEB管理界面也是可选安装,简洁强大,经过若干天的使用一直比较稳定。

  配置

  已配置好 OpenWRT 上网的童鞋们可以直接跳过 1.刷 ROM 和 2.初始配置

  1.刷 ROM

  a.首先确定你的设备可以被 OpenWRT 所支持(到这里查看支持的设备列表:http://wiki.openwrt.org/toh/start),然后到这里下载编译好的 ROM:http://downloads.openwrt.org/ 。最新的 stable 版本是 attitude_adjustment(12.09),我下载的是 trunk 版本。

  b.在 OpenWRT 官网找相应设备的 Wiki 页面查看刷机方法,一般都是在路由器官方Web固件升级页面直接刷入(我的 WNDR3800 Wiki页面是:http://wiki.openwrt.org/toh/netgear/wndr3800)

  2.初始配置

  a.路由器启动后,有的型号没有安装 Wifi 模块,需要先用网线连接到 LAN 口,本机 IP 配置为静态 192.168.1.x,然后 telnet 到 192.168.1.1,更改 root 密码,然后 ssh 连入,参考:http://wiki.openwrt.org/doc/start#configuring.openwrt

 配置OpenWRT路由的方法详解

  b.配置 WAN 口,让路由连上 Internet,参考:http://wiki.openwrt.org/doc/howto/internet.connection 。

  比如要配置 PPPoE:

  代码如下:

  uci set network.wan.proto=pppoe

  uci set network.wan.username=‘yougotthisfromyour@isp.su’

  uci set network.wan.password=‘yourpassword’

  uci commit network

  ifup wan

  c.安装 LuCI Web 管理界面并设置开机自动启动,参考:http://wiki.openwrt.org/doc/howto/luci.essentials

  代码如下:

  opkg update

  opkg install luci

  /etc/init.d/uhttpd start

  /etc/init.d/uhttpd enable

  d.浏览器输入路由器 LAN 侧 IP(多为192.168.1.1),进行 Wifi 等配置

 配置OpenWRT路由的方法详解

 配置OpenWRT路由的方法详解

  3.配置 DNS

  a.创建 /etc/config/sec_resolv.conf

  vim /etc/config/sec_resolv.conf  填入以下 DNS Servers:

  代码如下:

  nameserver 8.8.8.8

  nameserver 8.8.4.4

  nameserver 208.67.222.222

  b.编辑 /etc/config/dhcp

  vim /etc/config/dhcp  找到 option resolvfile 选项,替换为:

  option resolvfile ‘/etc/config/sec_resolv.conf’

  4.配置 PPTP

  a.安装 ppp-mod-pptp

  代码如下:

  opkg update

  opkg install ppp-mod-pptp

  如果需要 LuCI 支持(推荐):

  opkg install luci-proto-ppp

  b.配置 vpn 接口,编辑 /etc/config/network 文件,应该已经有以下内容(如果没有,需要插入),并配置里面的 server、username 和 password:

  代码如下:

  config ‘interface’ ‘vpn’

  option ‘ifname’ ‘pptp-vpn’

  option ‘proto’ ‘pptp’

  option ‘username’ ‘vpnusername’

  option ‘password’ ‘vpnpassword’

  option ‘server’ ‘vpn.example.org or ipaddress’

  option ‘buffering’ ‘1’

  c.进入 Network -》 Firewall ,把 vpn 加入 wan zone,效果如图:

 配置OpenWRT路由的方法详解

  d.进入 Network -》 Interfaces ,此时应该已经可以看到 VPN Interface 并可以连接,效果如图:

 配置OpenWRT路由的方法详解

  e.此时在本机 traceroute www.google.com,应该能得到类似以下的结果:

  代码如下:

  FL-MBP:~ fatlyz$ traceroute www.google.com

  traceroute: Warning: www.google.com has multiple addresses; using 74.125.239.113

  traceroute to www.google.com (74.125.239.113), 64 hops max, 52 byte packets

  fc_r0.lan (192.168.7.1) 2.266 ms 0.999 ms 0.946 ms

  10.7.0.1 (10.7.0.1) 189.259 ms 187.813 ms 188.368 ms

  23.92.24.2 (23.92.24.2) 189.847 ms 190.489 ms 188.939 ms

  10ge7-6.core3.fmt2.he.net (65.49.10.217) 188.508 ms 192.216 ms 202.863 ms

  10ge10-1.core1.sjc2.he.net (184.105.222.14) 195.695 ms 195.691 ms 284.242 ms

  72.14.219.161 (72.14.219.161) 189.196 ms 192.287 ms 193.220 ms

  216.239.49.170 (216.239.49.170) 192.496 ms 188.547 ms 189.881 ms

  66.249.95.29 (66.249.95.29) 190.125 ms 190.335 ms 190.026 ms

  nuq05s01-in-f17.1e100.net (74.125.239.113) 189.804 ms 190.556 ms 190.242 ms

  可以看出,其中第二跳是 VPN 的网关,而 traceroute www.baidu.com 的话第二跳应该也是同样的结果。

  这时已经可以访问 Google, Baidu 等国内外的站点了。

  5.配置 chnroutes

  a.到 chnroutes 项目的下载页面:http://chnroutes-dl.appspot.com/ 下载 linux.zip,解压

  b.把 ip-pre-up 重命名为 chnroutes.sh,打开编辑,在 if [ ! -e /tmp/vpn_oldgw ]; then 前插入以下代码,以避免 ppp 连接脚本重复执行导致重复添加路由表项:

  代码如下:

  if [ $OLDGW == ‘x.x.x.x’ ]; then

  exit 0

  fi

  其中 x.x.x.x 是 VPN 的网关,可以先本机连接上去之后查看一下网关地址。

  c.ssh 连接到路由器,执行以下命令:

  代码如下:

  cd /etc/config/

  mkdir pptp-vpncd pptp-vpnvim chnroutes.sh

  在 vim 中把编辑好的 chnroutes.sh 粘贴进去(当然也可以通过 ssh 直接把 chnroutes.sh 文件传过去,或者上传到某个地方再 wget 下载)

  执行以下命令,设置权限为可执行:

  chmod a+x chnroutes.sh

  d.用 vim 编辑 /lib/netifd/ppp-up 文件:

  vim /lib/netifd/ppp-up

  在 [ -d /etc/ppp/ip-up.d ] && { 这一行前插入以下内容,确保 ppp 连接脚本能够被执行:

  sh /etc/config/pptp-vpn/chnroutes.sh

  e.重启路由,启动好之后,进入 LuCI 查看接口状态,等 WAN 和 VPN 都连接成功后,ssh进去,执行 route -n | head -n 10 ,效果应该类似这样:

  代码如下:

  root@FC_R0:/etc/config# route -n | head -n 10

  Kernel IP routing table

  Destination Gateway Genmask Flags Metric Ref Use Iface

  0.0.0.0 10.7.0.1 0.0.0.0 UG 0 0 0 pptp-vpn

  1.0.1.0 58.111.43.1 255.255.255.0 UG 0 0 0 pppoe-wan

  1.0.2.0 58.111.43.1 255.255.254.0 UG 0 0 0 pppoe-wan

  1.0.8.0 58.111.43.1 255.255.248.0 UG 0 0 0 pppoe-wan

  1.0.32.0 58.111.43.1 255.255.224.0 UG 0 0 0 pppoe-wan

  1.1.0.0 58.111.43.1 255.255.255.0 UG 0 0 0 pppoe-wan

  1.1.2.0 58.111.43.1 255.255.254.0 UG 0 0 0 pppoe-wan

  1.1.4.0 58.111.43.1 255.255.252.0 UG 0 0 0 pppoe-wan

  其中 Destination 为 0.0.0.0 的是默认路由,网关为 VPN 网关,意味着默认流量都经过 VPN,而以下的条目则把目的为国内的网段都指向了 ISP 提供的网关。

  至此 PPTP VPN 和 chnroutes 已经配置完毕。

  6.配置 VPN 断线自动重连

  a.创建 /etc/config/pptp-vpn/status-check.sh:

  vim /etc/config/pptp-vpn/status-check.sh

  在 vim 中粘贴以下内容(此脚本检测 VPN 连接状态,并在断线后会断开 WAN 和 VPN 接口,10秒后重新连接 WAN,并在 30 秒后重连 VPN):

  代码如下:

  #!/bin/sh《/p》 《p》if [ -f “/tmp/vpn_status_check.lock” ]

  then

  exit 0

  fi《/p》 《p》VPN_CONN=`ifconfig | grep pptp-vpn`《/p》 《p》if [ -z “$VPN_CONN” ]

  then

  touch /tmp/vpn_status_check.lock

  echo WAN_VPN_RECONNECT at: 》》 /tmp/vpn_status_check_reconn.log

  date 》》 /tmp/vpn_status_check_reconn.log《/p》 《p》 ifdown vpn

  ifdown wan

  sleep 10

  ifup wan

  sleep 30

  ifdown vpn

  sleep 10

  ifup vpn

  sleep 40

  rm /tmp/vpn_status_check.lock《/p》 《p》else

  date 》 /tmp/vpn_status_check.log

  fi

  执行以下命令,设置权限为可执行:

  chmod a+x /etc/config/pptp-vpn/status-check.sh

  b.进入LuCI 的 System -》 Scheduled Tasks 填入以下内容,并保存:

  */1 * * * * /etc/config/pptp-vpn/status-check.sh

  以上实际上是编辑了 cron 配置,cron 每分钟运行检测 / 重连脚本,重启 cron:

  /etc/init.d/cron restart

  c.静待几分钟,查看 /tmp 目录,应该能看到 vpn_oldgw 和 vpn_status_check.log 文件,查看 vpn_status_check.log 文件,可以看到最近一次检测 VPN 连接状态的时间。

  代码如下:

  root@FC_R0:/tmp# ls vpn*

  vpn_oldgw vpn_status_check.log

  root@FC_R0:/tmp# cat vpn_status_check.log

  Tue Jul 15 00:04:02 HKT 2014

  root@FC_R0:/tmp#

  你可以在 LuCI 中断开 VPN 接口,在接下来的4-5分钟,观察 WAN 和 VPN 的重连情况。

  d.分别 traceroute www.google.com 和 www.baidu.com ,观察第二跳的地址:

  代码如下:

  FL-MBP:~ fatlyz$ traceroute www.google.com | head -n 3

  traceroute: Warning: www.google.com has multiple addresses; using 74.125.239.115

  traceroute to www.google.com (74.125.239.115), 64 hops max, 52 byte packets

  fc_r0.lan (192.168.7.1) 2.161 ms 0.912 ms 0.895 ms

  10.7.0.1 (10.7.0.1) 193.747 ms 187.789 ms 289.744 ms

  23.92.24.2 (23.92.24.2) 259.323 ms 354.625 ms 408.535 ms

  代码如下:

  FL-MBP:~ fatlyz$ traceroute www.baidu.com | head -n 3

  traceroute to www.a.shifen.com (180.76.3.151), 64 hops max, 52 byte packets

  1 fc_r0.lan (192.168.7.1) 1.190 ms 0.984 ms 0.731 ms

  2 58.111.43.1 (58.111.43.1) 20.616 ms 38.822 ms 18.484 ms

  3 183.56.35.133 (183.56.35.133) 20.056 ms 52.353 ms 87.841 ms

  可以看出,已成功对国内外的目标地址进行了路由选择。

  至此,OpenWRT 路由的基本配置、PPTP VPN、chnroutes 和自动重连已经配置完成。

  上面就是OpenWRT 路由配置的方法介绍了,如果你要给OpenWRT 配置路由的话,不妨试试本文介绍的方法,希望对你有所帮助。

以上内容由WiFi之家网整理收藏!

原创文章,作者:路由器,如若转载,请注明出处:https://www.224m.com/228442.html

(0)
路由器路由器
腾达 FH451 无线路由器设置自动获取IP(DHCP)上网
上一篇 2023年1月14日 10:12
168.1.1-为什么我登陆192.168.1.1进入的是中国电信宽带的界面.
下一篇 2023年1月14日 10:23

相关推荐

  • 普联路由器设置网址打不开怎么办?

    问:普联路由器的设置网址打不开怎么办?答:设置普联路由器的时候,如果设置网址打不开,多半是你操作有问题引起的,极少数情况下是路由器自身有问题,具体的解决办法如下。1、检查你的普联路由器上网线连接是否正确,tplink路由器、光猫(入户宽带网线)、电脑 三者之间的正确连接方式如下:从光猫上接出来的网线

    2021年5月28日
    4.8K
  • 如何防止别人连接自己的WiFi(如何防止别人连接自己的WiFi)

    生活中WiFi依然成为我们的必需品,不管是上网浏览,还是娱乐看电影都会连着WiFi,一个WiFi的快慢往往也影响着我们上网的体验,三五个人连接着WiFi,并不会感觉WiFi质量的高低,可是当我们的WiFi被很多人连接着时,我们上网的网速就会受到影响,那么如何查看有谁连接着我

    2022年2月19日
    21.7K
  • 耳机路由器设置dns(网件路由器设置)

    今天我们来讲一下如何在网件路由器上设置DNS,以便更顺畅地使用互联网。 首先,我们需要登录网件路由器的后台管理页面。打开浏览器,输入路由器的IP地址,并输入登录密码。一般来说,路由…

    网络 2025年12月8日
    1.8K
  • 迅捷FAST FWR310路由器无线wifi密码设置方法

    迅捷(FAST)FWR310路由器上,无线wifi密码设置与修改。为无线网络设置一个合理、安全的wifi密码,可以有效的保护无线网络的安全,避免wifi被蹭网软件破解密码。

    2021年3月16日
    23.6K
  • 我2个路由器怎么设置(二级路由器怎么设置)

    我2个路由器怎么设置(二级路由器怎么设置) 如果您想在家中或办公室中拥有更好的网络覆盖范围,那么使用多个路由器或者扩展器就是一个不错的选择。这篇文章将向您介绍如何设置两个路由器,其…

    网络 2024年9月27日
    137
  • TP-Link新版路由器修改无线wifi密码方法

    新版TP-Link路由器,修改wifi密码和名称的方法。一直觉得修改路由器中的无线wifi密码或者名称,其实是一件非常简单的事情。只需要登录到这台路由器的设置页面,找到“无线设置”选项,就可以进行设

    2021年4月7日
    11.4K
  • 联通路由器定制版设置密码(联通华盛路由器怎么设置密码)

    联通路由器定制版设置密码 联通路由器定制版是一款集路由器、交换机、WIFI AP为一体的智能网络设备,采用强大的双核处理器,支持2.4GHz和5GHz双频无线信号,为用户提供了极佳…

    网络 2024年9月15日
    9.5K
  • 在网上买的路由器怎样设置(网上买的路由器怎么设置)

    在网上买的路由器怎样设置 在网上买的路由器,需要进行一些设置才能使用。以下是一些基本的设置步骤: 1. 连接路由器 首先,将路由器与电脑或者笔记本电脑进行连接。通常情况下,路由器的…

    2023年12月12日
    5.2K
  • 直播无线路由器的设置(怎么设置无线路由器)

    直播无线路由器的设置 无线路由器是一种重要的网络设备,它可以让多个设备同时连接到互联网。下面是设置直播无线路由器的步骤: 步骤1:连接路由器 首先,将无线路由器连接到电源并插入网线…

    网络 2025年3月22日
    548
  • tplink路由器手机怎么设置密码(tplink路由器连接)

    tplink路由器手机怎么设置密码(tplink路由器连接) 如果你购买了一个TPLINK路由器,你需要为它设置一个安全密码,以保护你的网络免受未经授权的访问。在本文中,我们将为你…

    网络 2023年12月20日
    2