• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

利用openvpn建立桥接vpn

发布: 2007-7-04 12:06 | 作者: admin | 来源:  网友评论 | 查看: 19次 | 进入软件测试论坛讨论

领测软件测试网

本文介绍利用openvpn建立桥接vpn的一种简单方法,使用的服务器为debian GNU/Linux sarge,使用apt-get dist-upgrade更新到最新,内核2.4.27-1-686,未重新编译内核,openvpn版本1.6.0+2.beta14-1(使用apt-get install openvpn安装),客户机一为debian GNU/Linux sid,内核2.6.8-1-k7,未重新编译内核,openvpn版本1.99+2.beta17-1(使用apt-get install openvpn安装),客户机二为windows 2k adv ser sp4,openvpn安装在C:\Program Files\OpenVPN\下,版本为1.6(从http://openvpn.sourceforge.net/ 下载openvpn-1.6.0-install.exe (http://umn.dl.sourceforge.net/sourceforge/openvpn/openvpn-1.6.0-install.exe)后直接安装)

本文介绍利用openvpn建立桥接vpn的一种简单方法,使用的服务器为debian GNU/Linux
sarge,使用apt-get dist-upgrade更新到最新,内核2.4.27-1-686,未重新编译内核,
openvpn版本1.6.0+2.beta14-1(使用apt-get install openvpn安装),客户机一为
debian GNU/Linux sid,内核2.6.8-1-k7,未重新编译内核,openvpn版本1.99+2.beta17-1
(使用apt-get install openvpn安装),客户机二为windows 2k adv ser sp4,openvpn安装
在C:\Program Files\OpenVPN\下,版本为1.6(从http://openvpn.sourceforge.net/ 下
载openvpn-1.6.0-install.exe
(http://umn.dl.sourceforge.net/sourceforge/openvpn/openvpn-1.6.0-install.exe)
后直接安装)


1 网络拓扑图如下:

|
|      br0(eth1) |------|eth0         tap0,ip:192.168.0.101|------|
|----------------|server|----------------------------------|client|
|  ip:192.168.0.3|------|ip:1.2.3.4         eth0,ip:5.6.7.8|------|
|
|intranet
|192.168.0.0/24


当server的openvpn停止时,server使用eth1和intranet通讯,eth1的ip地址为192.168.0.3/24,
当server的openvpn启动后,server使用br0和intranet通讯,br0的ip地址为192.168.0.3/24,
client的ip地址为5.6.7.8,建立vpn后,client通过tap0使用192.168.0.101/24和intranet通讯

2 软件安装

服务器及客户机一需要额外安装的软件有bridge-utils,liblzo1,可使用apt-get 进行安装。
客户机2上不需要安装其他特别的软件。


3 建立vpn

3.1 在服务器上运行openvpn --genkey --secret static.key生成建立vpn时使用的密钥,
static.key为保存密钥的文件,将这个文件复制到server和client 1的/etc/openvpn/目录
下,以及client 2的openvpn安装目录下的config目录下.

3.2 将下列文件复制到/etc/openvpn/下,/etc/init.d/openvpn启动时会读取该目录下的*.conf
====================server's bridge-up====================
#!/bin/bash

##################################
# Set up Ethernet bridge on Linux#
##################################

# Define Bridge Interface
br="br0"

# Define list of TAP interfaces to be bridged together
tap="tap0"

# Define physical ethernet interface to be bridged
# with TAP interface(s) above.
eth="eth1"
eth_ip="192.168.0.3"
eth_netmask="255.255.255.0"
eth_broadcast="192.168.0.255"

for t in $tap; do
openvpn --mktun --dev $t
echo "add tun $t "
done

brctl addbr $br
echo "add bridge $br"
brctl addif $br $eth
echo "add $eth to bridge $br"

for t in $tap; do
brctl addif $br $t
echo "add $t to bridge $br"
done

for t in $tap; do
ifconfig $t 0.0.0.0 promisc up
echo "set $t promisc mode"
done

ifconfig $eth 0.0.0.0 promisc up
echo "set $eth promisc mode"

ifconfig $br $eth_ip netmask $eth_netmask broadcast $eth_broadcast
echo "config $br with ip $eth_ip netmask $eth_netmask broadcast $eth_broadcast"
======================end of bridge-up========================

====================server's bridge-down======================
#!/bin/bash

####################################
# Tear Down Ethernet bridge on Linux
####################################

# Define Bridge Interface
br="br0"

# Define list of TAP interfaces to be bridged together
tap="tap0"

ifconfig $br down
echo "bridge $br down"

brctl delbr $br
echo "delete bridge $br"

for t in $tap; do
openvpn --rmtun --dev $t
echo "delete tun $t"
done
======================end of bridge-down========================

====================server's openvpn.conf=======================
# Linux VPN server config file
port 1194
dev tap0
secret static.key
log-append /var/log/openvpn.log
fragment 1400
ping 10
ping-restart 35
ping-timer-rem
persist-tun
persist-key
comp-lzo
comp-noadapt
user nobody
group nogroup
verb 4
====================end of openvpn.conf========================

====================client 1's bridge-up========================
#!/bin/bash

#################################
# Set up Ethernet bridge on Linux
#################################

# Define Bridge Interface
br="br0"

# Define list of TAP interfaces to be bridged together
tap="tap0"

#Client 1 use 192.168.0.101/24 to communicate with intranet
eth_ip="192.168.0.101"
eth_netmask="255.255.255.0"
eth_broadcast="192.168.0.255"

for t in $tap; do
openvpn --mktun --dev $t
echo "add tun $t "
done

brctl addbr $br
echo "add bridge $br"

for t in $tap; do
brctl addif $br $t
echo "add $t to bridge $br"
done

for t in $tap; do
ifconfig $t 0.0.0.0 promisc up
echo "set $t promisc mode"
done

ifconfig $br $eth_ip netmask $eth_netmask broadcast $eth_broadcast
echo "config $br with ip $eth_ip netmask $eth_netmask broadcast $eth_broadcast"


======================end of bridge-up==========================

====================client 1's bridge-down======================
#!/bin/bash

#####################################
# Tear Down Ethernet bridge on Linux#
#####################################

# Define Bridge Interface
br="br0"

# Define list of TAP interfaces to be bridged together
tap="tap0"

ifconfig $br down
echo "bridge $br down"

brctl delbr $br
echo "delete bridge $br"

for t in $tap; do
openvpn --rmtun --dev $t
echo "delete tun $t"
done
======================end of bridge-down========================

====================client 1's openvpn.conf=====================
# Linux VPN Client config file
#This file should be put into /etc/openvpn/
#local and remote port used by openvpn
#You can specify local port with "lport" option,remote port with "rport"
#By default,Debian's openvpn use port 5000
port 1194
#Tap device used by openvpn
dev tap0
#Enable Static Key encryption mode (non-TLS).Use shared secret file static.key
#this file is generated with "openvpn --genkey --secret static.key"
secret static.key
#append log to /var/log/openvpn.log ,if this file is not exist, it will be
#created.
log-append /var/log/openvpn.log
#VPN server's address
remote 1.2.3.4
fragment 1400
#Ping remote once every 10 seconds over TCP/UDP port
ping 10
#Restart if 35 seconds pass without reception of remote ping
ping-restart 35
# Run the --ping-exit/--ping-restart timer only if we have a remote address
#Only client have a remote address
ping-timer-rem
#Keep tun/tap device open across SIGUSR1 or --ping-restart
persist-tun
#Don't re-read key files across SIGUSR1 or --ping-restart
persist-key
#Use fast LZO compression -- may add up to 1 byte per packet for uncompressible
#data.
comp-lzo
#Don't use adaptive compression when --comp-lzo is specified
comp-noadapt
#Set UID to nobody after initialization.
user nobody
#Set GID to nogroup after initialization
group nogroup
#Set output verbosity to 4
#4 means "show parameters"
verb 4

====================end of openvpn.conf========================

====================client 2's openvpn.ovpn=====================
#Windows VPN Client config file
#This file should be put into C:\Program Files\OpenVPN\config\
#if you install OpenVPN in C:\Program Files\OpenVPN\
port 1194
dev tap
secret static.key
#Client 2 use 192.168.0.101/24 to communicate with intranet
ifconfig 192.168.0.101 255.255.255.0
log-append /var/log/openvpn.log
remote 1.2.3.4
fragment 1400
tap-sleep 1
ifconfig-nowarn
ip-win32 dynamic
ping 10
comp-lzo
comp-noadapt
verb 4
====================end of openvpn.conf========================


3.3 启动vpn

启动时因先启动vpnserver,然后启动vpnclient.

3.3.1 启动vpnserver,运行/etc/openvpn/bridge-up,然后运行/etc/init.d/openvpn start,
如果先启动/etc/init.d/openvpn start将出错.

3.3.2 启动vpnclient,运行/etc/openvpn/bridge-up,然后运行/etc/init.d/openvpn start

3.3.3 当vpnclient为windows时,运行 net start openvpnservice.

3.4 关闭vpn

关闭时因先关闭vpnclient,然后关闭vpnserver

3.4.1 关闭vpnclient,运行/etc/init.d/openvpn stop,然后运行/etc/openvpn/bridge-down

3.4.2 当vpnclient为windows时,运行net stop openvpnservice.

3.4.3 关闭vpnserver,运行/etc/init.d/openvpn stop,然后运行/etc/openvpn/bridge-down

4 参考资料

4.1 openvpn的老家
http://openvpn.sourceforge.net/

4.2 Ethernet Bridging
http://openvpn.sourceforge.net/bridge.html

4.3 Implementing OpenVPN
http://fedoranews.org/contributors/florin_andrei/openvpn/

4.4 利用openvpn+linux快速建立企业VPN
http://www.linuxaid.com.cn/articles/1/0/1052518204.shtml

欢迎和我交流 联系方式blue_stone@xinhuanet.com

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网