栏目列表
 
 
首页 > 操作系统 > Linux > Linux上应用isdn的解决方案
 

Linux上应用isdn的解决方案

日期:2006-06-12 00:41:24  来源:网络转载
请您记住思索网的网址: http://www.4so.net  [加入收藏夹]


    
目的: 
  在一台Linux机器上,通过ISDN拨号上网,同时可以作代理用!

配置:
    Redhat Linux 7.3、2.4.18-3custom、isdn4k-utils-3.1-53、isdn4k-utils-devel-3.1-53,上海贝尔生产的ISDN内置卡,型号为SBT6021。

内核支持:
  上海贝尔SBT6021型ISDN内置卡,使用的芯片为Winbond W6692,这是一种与西门子“HiSax”驱动程序兼容的芯片,该卡是即插即用的,无需手工设置中断请求和I/O地址。但需要Linux内核支持这种内置卡,在编译内核时,必须选中下列选项:

    ISDN Support

    Support synchronous PPP

    (多数ISDN设备拨号上网都是使用同步PPP方式)

    Hisax SiemensChipset driver support

    Hisax Support for DSS1

    (绝大多数ISDN设备使用的协议都是DSS1)

    Hisax Support for Winbond W6692

     大家不必急于编译内核,如果现有的内核已经包含这些选项了,那么就不必再重复一遍了。那怎么知道现有内核是否已经包含这些选项了呢?看内核编译配置文件 “/usr/src/linux/.config”(注意:文件名以“.”开头的文件是隐藏文件,要用“ls -a”才可看到)。大家若看到其中有下面这 5行内容,对应于刚才的5个选项:

    CONFIG_ISDN=m

    CONFIG_ISDN_PPP=y

    CONFIG_ISDN_DRV_HISAX=m

    CONFIG_HISAX_EURO=y

    CONFIG_HISAX_W6692=y

    “=y”是表示内核直接支持(代码已链入内核中),“=m”表示模块支持(代码在另外的内核中,可由内核载入)。这就表明,蓝点Linux 2.0的原有内核已包含这些选项,大家就不用重新编译这些内核了。

isdn4linux安装:
  [wind@NetShare isdn]$ rpm -qa|grep isdn
  isdn4k-utils-3.1-53
  isdn4k-utils-devel-3.1-53
 确认这两包已经安装!这是isdn在Linux下工作所必要的。

isdn基本配置的一些简要说明:
  对于isdn的概念,相信大家都应该比较了解,现在偶想在说的一点就是在linux下应用过程中所要涉及的几个文件,所应该的设置是:/dev/ippp0  /dev/ippp1,这是因为一般的isdn都有两个通道,所用的几个文件分别为:
  
  /etc/isdn下面的所有文件:
  这里面基本上不用动,主要是isdn的一些基本硬件信息及配置信息,对于偶们来说可不去管他
  
  /etc/ppp/isdn.conf:这个文件手动编辑的,主要是为isdn指定一些变量,如电话号码等
  /etc/ppp/pap-secrets:用来存储拨号的用户名和口令
  /etc/ppp/ioptions:用来设置isdn拨号过程中一些高级设置
  /etc/init.d/isdn:这是偶在应用过程中写出的一个用来拨号的脚本,会附给大家!
  /usr/local/etc/routemon.pl:这是偶写的一个应用脚本,用来守护isdn拨号后,默认网关的添加用的,必须用crontab让他时时去执行用的!

isdn拨号的原理:
    echo 1 > /proc/sys/net/ipv4/ip_ dynaddr

    拨号上网大部分都是使用动态IP地址,我们不知道远程拨号服务器的IP地址是多少,也不可能知道它会给电脑分配什么IP地址。在“/proc/sys/net/ipv4/ip_dynaddr”中写入“1”,就是告诉内核要使用动态IP地址。

    modprobe hisax type=36 protocol=2

     安装ISDN卡的驱动程序。前面已经说过,上海贝尔SBT6021型ISDN内置卡中使用的芯片W6692是由HiSax驱动程序驱动的,type=36 是指使用W6692芯片,protocol=2指ISDN协议是用“DSS1”,详细内容可参看 “/usr/src/linux/ Documentation/isdn/README.HiSax”文件。

    isdnctrl addif ippp0

    ISDN 通过同步“PPP”方式上网,其对应的接口(Interface)会是“/dev/ippp0”、“/dev/ippp1” 等。这条命令告诉内核,加入 “ippp0”这个Interface,换句话说,告诉内核有个ISDN设备,准备通过同步PPP方式上网。从此以后,“ippp0”就代表了笔者的 ISDN设备。

    isdnctrl addphone ippp0 out 163

    指拨叫的电话号码,这里是163,通过中国电信拨号上网的大部分也都是163。

    isdnctrl eaz ippp0 2024245

    指自己这台ISDN的电话号码为2024245。

    isdnctrl l2_prot ippp0 hdlc

    第2层协议用的是“hdlc”。

    isdnctrl l3_prot ippp0 trans

    第3层协议用的是“trans”。

    isdnctrl encap ippp0 syncppp

    用同步PPP方式。

    isdnctrl dialmode ippp0 manual

    手工拨号方式,在此方式下,拨号时用“isdnctrl dial ippp0”命令,挂断时用“isdnctrl hangup ippp0”命令。另外还有“auto”(自动方式),不过,还是先用手工方式比较直观稳定。

    isdnctrl dialmax ippp0 3

    1次拨号有可能连不通,不要紧,程序会自动重拨的,这里规定了最多重拨3次。

    isdnctrl huptimeout ippp0 500

    线路空闲一段时间后,会自动挂断,缺省是空闲10秒后挂断。

    普通网络配置

    Linux 的普通网络配置主要包含两个方面:1)对各接口本身的配置,Interface是指以太网卡、Modem、ISDN等设备;配置信息包括网络地址、子网掩码、网关等;相应的配置工具为ifconfig程序。2)对路由表的配置。路由表规定了到各个目的地的数据包应走哪个网关,使用哪个Interface 等,相应的配置工具为route程序。

    在进行配置之前,先看一下目前的配置情况是什么样的。笔者的Linux机器在一个局域网上,局域网的域名为server.net,地址为203.0.0.111,这台机器的主机名为admin,地址为203.0.0.1。

    用ifconfig命令查看Interface配置,显示信息如下:

    eth0 Link encap:Ethernet HWaddr 00:20:AF:F1:0A:4A
    inet addr:203.0.0.1 Bcast:203.0.0.255 Mask:255.255.255.0
    ...

    lo Link encap:Local Loopback
    inet addr:127.0.0.1 Mask:255.0.0.0
    ...

    显示信息表明:有2个Interface,“eth0”代表以太网卡;“lo”是个虚拟的“loopback”设备。

    接着用route命令看路由表配置,显示信息如下:

    Kernel IP routing table
    Destination adminway Genmask Flags Metric Ref Use Iface
    admin.server.net * 255.255.255.255 UH 0 0 0 eth0
    203.0.0.111 * 255.255.255.0 U 0 0 0 eth0
    127.0.0.0 * 255.0.0.0 U 0 0 0 lo

    信息表明,有3条路由信息。要用上ISDN(ippp0),必须用“ifconfig”对“ippp0”进行配置,并用“route”增加1条使用它的路由。配置ippp0:

    ifconfig ippp0 0.0.0.0 pointopoint 0.0.0.0 netmask 0.0.0.0

     使用PPP(pointopoint)协议,“point to point”前面是本机地址,后面是远程服务器地址,这里全是0.0.0.0,行吗?行,因为前面已经作了配置“echo 1 > /proc/sys/net/ipv4/ip_ dynaddr”,告诉内核将使用动态IP地址,因此在这里用0.0.0.0并无所谓,当这个PPP连接建立起来后,它会自动用真正的IP地址代替这些0.0.0.0的。

    此时再用ifconfig查看,得到如下类似信息:

    eth0 Link encap:Ethernet HWaddr 00:20:AF:F1:0A:4A
    inet addr:203.0.0.1 Bcast:203.0.0.255 Mask:255.255.255.0
    ...
    ippp0 Link encapoint-to-Point Protocol
    UP POINTOPOINT RUNNING NOARP MTU:1500 Metric:1
    RX packets:0 errors:0 dropped:0 overruns:0 frame:0
    TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
    collisions:0 txqueuelen:30
   
  lo Link encap:Local Loopback
    inet addr:127.0.0.1 Mask:255.0.0.0
    ...

    发现多了1个“ippp0 Interface”,但由于未曾建立真正的连接,它的本机地址和远程服务器地址都未给出。于是增加1条使用ippp0的路由:

    route add default ippp0

     这里指定缺省(default)的数据包都经过“ippp0”传送。缺省的数据包?什么意思?前面,笔者用route查看时有3条路由信息,这些信息指定了发往3个目的地(Destination)的数据包该怎么走,其他没有指定怎么走的数据包(在这里,就是除了那3种数据包之外的所有数据包),即为缺省数据包,比如要到168.160.224.103(新浪网sina.com.cn)的数据包,就属于缺省数据包。于是这条命令就做到了这一点:如果要上新浪网看新闻,就得经过“ippp0(ISDN)”,这正是笔者所希望的。这时候再用route查看一下情况如何:

    Kernel IP routing table

    Destination adminway Genmask Flags Metric Ref Use Iface
    admin.server.net

 
 
热门信息
 
相关文章