|
|
Server使用的配置文件server.conf
x) o3 h$ z6 B' H$ y' k4 N—————————–2 T; b6 u m- v3 q# q
#申明本机使用的IP地址,也可以不说明
4 C$ L) Q! I- e$ n) j% o/ [0 D;local a.b.c.d
6 K$ B5 W. v, ~ h' J! X#申明使用的端口,默认1194
; B. _% |$ G2 f: _port 1194
/ y) y& M, V$ o" f#申明使用的协议,默认使用UDP,如果使用HTTP proxy,必须使用TCP协议. M, `( h. G8 _( h2 [
#如果使用ipv6应改为proto tcp6或proto udp6( d- T2 K0 v/ a7 ]" R/ D- a# b( B( l
;proto tcp & n0 F2 F; x: a) T& e$ X
proto udp5 }+ }4 T! Q4 D) H8 c" j' I2 m8 F
#申明使用的设备可选tap和tun,tap是二层设备,支持链路层协议。, M: j& W! }; A( K" d
#tun是ip层的点对点协议,限制稍微多一些,本人习惯使用TAP设备2 c$ I/ r% U* P- ]3 W
dev tap
" i Y2 ^1 k8 @3 v" A* G$ F;dev tun
: Q: T* k; g+ a#OpenVPN使用的ROOT CA,使用build-ca生成的,用于验证客户是证书是否合法
' d# |/ C2 W8 E! T; [ca ca.crt4 p0 ~9 |# p8 O# C% i
#Server使用的证书文件
/ D8 }# ~# e, k" r. Ncert server.crt, g' g0 r* y" |( W- I* h
#Server使用的证书对应的key,注意文件的权限,防止被盗! e$ A. k3 R8 q5 O/ p2 S/ F
key server.key # This file should be kept secret, f6 X" P4 A* Q* }1 S
#CRL文件的申明,被吊销的证书链,这些证书将无法登录
& g" E, |: s" k8 scrl-verify vpncrl.pem
7 O+ f; U9 J0 F; u#上面提到的生成的Diffie-Hellman文件
( Q: b$ m' @ P7 Y# p8 |% e1 Edh dh1024.pem
; @, v; y! ?! d1 q. j" ^#这是一条命令的合集,如果你是OpenVPN的老用户,就知道这条命令的来由
) |( F3 m" l. E% z#这条命令等效于:% K. h( U; G" ~+ d. X7 k! z: M& ?
# mode server #OpenVPN工作在Server模式,可以支持多client同时动态接入
1 u: b% V: o$ f1 G8 c* R" U" `# tls-server #使用TLS加密传输,本端为Server,Client端为tls-client
. ?2 S/ I/ {. P8 j9 Y4 s3 {0 ?#" E$ m0 @% [8 c. j. R1 m. E
# if dev tun: #如果使用tun设备,等效于以下配置4 E2 I7 Z/ x, P( h& e
# ifconfig 10.8.0.1 10.8.0.2 #设置本地tun设备的地址* `2 b5 I, a* v* K5 P
# ifconfig-pool 10.8.0.4 10.8.0.251 #说明OpenVPN使用的地址池(用于分配给客户),分别是起始地址、结束地址5 q; j+ T$ y. d0 t, z' A, H0 W
# route 10.8.0.0 255.255.255.0 #增加一条静态路由,省略下一跳地址,下一跳为对端地址,这里是: 10.8.0.2 ^8 H) b& i2 o2 Q
# if client-to-client: #如果使用client-to-client这个选项
+ \4 g5 z" |5 i# push “route 10.8.0.0 255.255.255.0″ #把这条路由发送给客户端,客户连接成功后自动加入路由表,省略了下一跳地址: 10.8.0.1: c8 E `8 y3 [
# else: Q$ v9 ^* Q s1 t f
# push “route 10.8.0.1″ #否则发送本条路由,这是一个主机路由,省略了子网掩码和下一跳地址,分别为: 255.255.255.255 10.8.0.1
2 R6 U2 c0 m! `9 m#6 b$ I& _5 N ?" C0 U) h
# if dev tap: #如果使用tap设备,则等效于以下命令
- Y& H6 H7 a/ ?4 i# M$ K, N$ c# k# ifconfig 10.8.0.1 255.255.255.0 #配置tap设备的地址
, J3 [, T- g2 I) m" Z4 L- r% C# ifconfig-pool 10.8.0.2 10.8.0.254 255.255.255.0 #客户端使用的地址池,分别是起始地址、结束地址、子网掩码
- h. J0 I$ Z* M+ s! ]' O/ p# push “route-gateway 10.8.0.1″ #把环境变量route-gateway传递给客户机
4 I1 F) e" f6 G+ E: z+ q* }+ n#
* G3 Z2 e% {1 e2 w5 r% ~server 10.8.0.0 255.255.255.0 #等效于以上命令
7 d7 q4 f% ?! S7 p: F E3 [#用于记录某个Client获得的IP地址,类似于dhcpd.lease文件,; P" r( ?( a8 R6 I- |, b" D" y
#防止openvpn重新启动后“忘记”Client曾经使用过的IP地址; [* B' l" ?- q- k
ifconfig-pool-persist ipp.txt8 V8 R7 a3 f9 a) U. o; D. P
#Bridge状态下类似DHCPD的配置,为客户分配地址,由于这里工作在路由模式,所以不使用
1 x0 l- U# W2 C% m;server-bridge 10.8.0.4 255.255.255.0 10.8.0.50 10.8.0.100
/ m4 e9 S, F ^! n#通过VPN Server往Client push路由,client通过pull指令获得Server push的所有选项并应用
7 n- i6 ` S$ [; ~ ?, \;push “route 192.168.10.0 255.255.255.0″
S/ P3 S% l6 b2 J;push “route 192.168.20.0 255.255.255.0″$ r& ~2 q( e5 ~, f9 {' w
#VPN启动后,在VPN Server上增加的路由,VPN停止后自动删除, W. N. t6 N: K/ i" y% Z" o4 L
;route 10.9.0.0 255.255.255.252
/ I0 N5 j% A6 Q#Run script or shell command cmd to validate client
! i# e3 ~0 t: c4 B4 I# u- ~1 [#virtual addresses or routes. 具体查看manual1 n& r/ T3 _9 r1 q$ z
;learn-address ./script
3 |, L/ B5 I" N7 T" S$ x#其他的一些需要PUSH给Client的选项
' |7 W( D& C3 }; r#& F# w2 o8 u! t5 c8 U
#使Client的默认网关指向VPN,让Client的所有Traffic都通过VPN走
* r4 P; v3 f' H;push “redirect-gateway”
- H! T) ]. E; w6 N6 ?+ O: [#DHCP的一些选项,具体查看Manual0 X2 r; r0 V2 X- G
;push “dhcp-option DNS 10.8.0.1″
$ z# n1 }/ [9 `8 p;push “dhcp-option WINS 10.8.0.1″, S; P0 u/ y' n6 T. e- n
#如果可以让VPN Client之间相互访问直接通过openvpn程序转发,
; G% p, y6 Q! H/ Z#不用发送到tun或者tap设备后重新转发,优化Client to Client的访问效率) e; x) X. Z+ ~- p# L
client-to-client
. g+ s S) r% W# q8 P#如果Client使用的CA的Common Name有重复了,或者说客户都使用相同的CA
+ Y8 e; M' C; U3 a8 n" d#和keys连接VPN,一定要打开这个选项,否则只允许一个人连接VPN Q8 i+ B, @5 ]6 i3 S P F, @# w
;duplicate-cn
( f, u. N# k) p O0 G9 x& m( T5 A#NAT后面使用VPN,如果VPN长时间不通信,NAT Session可能会失效,
# ~, j' ?$ P( h2 S8 E#导致VPN连接丢失,为防止之类事情的发生,keepalive提供一个类似于ping的机制,6 O }6 e3 P2 `2 C
#下面表示每10秒通过VPN的Control通道ping对方,如果连续120秒无法ping通,
8 G/ f6 ~0 r8 |% x5 m! F2 t2 n#认为连接丢失,并重新启动VPN,重新连接' ^7 u* k( D+ _$ y1 s. e
#(对于mode server模式下的openvpn不会重新连接)。- V1 V- Y7 S7 A) s
keepalive 10 120
4 _' F* d4 |6 `. v. Q6 W) z9 Q0 Z4 w- d#上面提到的HMAC防火墙,防止DOS攻击,对于所有的控制信息,都使用HMAC signature,
+ Y0 ^: \9 s2 D/ `# l% ~# O7 l#没有HMAC signature的控制信息不予处理,注意server端后面的数字肯定使用0,client使用1
' N! ^5 B1 L2 j+ d/ x: wtls-auth ta.key 0 # This file is secret
6 Z7 L7 P z& }# M#对数据进行压缩,注意Server和Client一致$ |) u" Z5 a0 x7 H2 A- k- P) J" C
comp-lzo: a% |7 A8 y* W8 U# `9 {
#定义最大连接数
5 C3 O ^9 B7 ~ F;max-clients 100/ w) L0 M" o) p1 z" `" e7 ^
#定义运行openvpn的用户9 |( V5 Q' \3 O& K" ~# _1 v
user nobody& ]1 o M* I1 K8 L% t' @0 [
group nobody
5 s* ], |3 e$ f$ I& g- l6 P% {7 B2 a- a#通过keepalive检测超时后,重新启动VPN,不重新读取keys,保留第一次使用的keys
# Z2 A. O2 T6 Wpersist-key+ _3 p5 a- d4 ]4 P! S$ V% ^
#通过keepalive检测超时后,重新启动VPN,一直保持tun或者tap设备是linkup的,
& n6 f& }, g" \& k#否则网络连接会先linkdown然后linkup" Y W! [& k/ q5 g1 i6 x/ X0 s
persist-tun6 N# ^+ ?/ Y# K3 g# l0 i1 b9 H
#定期把openvpn的一些状态信息写到文件中,以便自己写程序计费或者进行其他操作; _( k2 f* j! y X- J4 j- U& t
status openvpn-status.log4 Q) t) f- _4 m7 P
#记录日志,每次重新启动openvpn后删除原有的log信息4 V2 w* L$ B# a" l' H! e" p
log /var/log/openvpn.log
6 t* ^6 }, R1 u3 ]. G. y5 P: F! J#和log一致,每次重新启动openvpn后保留原有的log信息,新信息追加到文件最后
5 Q* w% D1 h, \; o" S" f6 Q;log-append openvpn.log
5 b6 r T# q# ?; S#相当于debug level,具体查看manual3 z, q7 F7 w/ x! `! R) u4 T% {
verb 3
' _: X ?8 U1 B- B( z" ]$ L——————————-" B- c$ O& c/ }4 C1 u# y* A
把server.conf文件保存到/etc/opennvpn目录中,并把使用easy-rsa下的脚本什成的key都复制到/etc/openvpn目录下,命令如下:9 @- D/ l1 b' l: B; r& V% r' e* [
#cd /etc/openvpn, b( Y+ K. x) [* s- }0 I2 S
#cp easy-rsa/keys/ca.crt .: {% o0 M3 i7 X
#cp easy-rsa/keys/server.crt .9 |* O9 o2 ]! S( `8 \$ U: h2 X/ ]
#cp easy-rsa/keys/server.key .) [( Z/ S/ I# Y8 f/ V( r
#cp easy-rsa/keys/dh1024.pem .
8 [* D, l1 y5 @#cp easy-rsa/keys/ta.key .. {0 u3 D, V$ w w
#cp easy-rsa/keys/vpncrl.pem .
1 Y" ^8 S! y. `, ^$ {# b5 z" n& r; @创建OpenVPN启动脚本,可以在源代码目录中找到,在sample-scripts目录下的openvpn.init文件,将其复制到/etc/init.d/目录中,改名为openvpn, z$ X6 U* }, h- x, \$ ~, @
然后运行:7 l2 C+ G4 O, M n; ~( K8 f
#chkconfig –add openvpn
# h0 K8 ^# ?$ a6 X+ n* N#chkconfig openvpn on! @( `/ E8 V% p1 G1 B, u- @
立即启动openenvpn3 |. i" @8 J. l9 ~7 \$ J
#/etc/init.d/openvpn start) W T& ]" [! F5 E0 c2 V. E
* @; l, c# P3 V! P接下来配置客户端的配置文件client.conf:
5 e, o, T' l: T) { ^Linux或Unix下使用扩展名为.conf Windows下使用的是.ovpn,并把需要使用的keys复制到配置文件所在目录ca.crt elm.crt elm.key ta.key
2 o, T/ M( {2 ^8 z) k———————————-
/ l* K2 B' ~2 X- `' c, c# 申明我们是一个client,配置从server端pull过来,如IP地址,路由信息之类“Server使用push指令push过来的”
$ v1 u/ q, u; S; r5 W8 G; b' Iclient
. U% E( E" H0 O I- y. G/ |- }" U; }, z7 T U0 N9 b
#指定接口的类型,严格和Server端一致
( p5 L+ |% P; {& kdev tap$ K% ], q! Q9 e. i6 |1 ?0 h
;dev tun% \6 D. ?' l" e
" [4 ^ y/ v. A# Windows needs the TAP-Win32 adapter name, }( W- D8 U% \6 Z8 H% f
# from the Network Connections panel8 r. g9 I* u( y/ O5 }3 O8 ?1 M
# if you have more than one. On XP SP2,5 x# X { A$ k! x* e1 c
# you may need to disable the firewall8 b: s; ~9 u. B
# for the TAP adapter.
. |5 P- z, y5 I, l1 w# C/ u;dev-node MyTap
( ~4 q5 B9 N8 h1 T O
# M$ K, x$ n7 W/ o. |. m# 使用的协议,与Server严格一致
5 a% U& ?6 @2 ?& ?; I& Q;proto tcp2 |; E% g- ^+ e h" f5 s
proto udp
w5 m3 q @2 b3 S0 _- Y. H6 a& e a$ }5 A9 q
#设置Server的IP地址和端口,如果有多台机器做负载均衡,可以多次出现remote关键字" M2 W9 ^6 T4 W# P# c J$ `6 X6 @+ e
* c) Y' N6 B! T5 G& g2 h; t! D
remote 61.1.1.2 11947 G4 W1 Y- K% r. r1 j. M* o! ?: Q
;remote my-server-2 1194
) {3 D: `6 @2 H8 m" y
. Z) e% `# g' Z9 \! Y {7 g1 ]5 l# 随机选择一个Server连接,否则按照顺序从上到下依次连接
: a: j# G/ G) C0 J5 F" X+ E;remote-random" u- B, o/ Z* M6 j, V9 e
' a4 W7 E9 x0 c; v9 r: `" V
# 始终重新解析Server的IP地址(如果remote后面跟的是域名),
; ]2 t" b/ V$ b6 I) Q7 o# 保证Server IP地址是动态的使用DDNS动态更新DNS后,Client在自动重新连接时重新解析Server的IP地址9 x5 f. Q7 g! ?, m0 w
# 这样无需人为重新启动,即可重新接入VPN
& N Q: g9 {$ H! P, @resolv-retry infinite i% F" ]2 {9 I2 R( u$ O9 s! ^0 |
" Y! m ~- `3 O" P4 ~& T# 在本机不邦定任何端口监听incoming数据,Client无需此操作,除非一对一的VPN有必要% ^8 v: v% ~8 ~ M1 K) K" N' Z
nobind2 i: T+ e! g0 h! s
1 q& Y* e1 g/ Z: d0 R1 H
# 运行openvpn用户的身份,旧版本在win下需要把这两行注释掉,新版本无需此操作
% Z8 Y3 b% W. \2 p2 Puser nobody
$ s; l) {( y) V) M. r- b J$ Zgroup nobody
; z) {+ {8 H5 k2 Q7 i5 x+ G. Z
' c8 z0 Z! W! V" W) f; l#在Client端增加路由,使得所有访问内网的流量都经过VPN出去' B$ B0 S; x3 { |! ^
#当然也可以在Server的配置文件里头设置,Server配置里头使用的命令是
; H, [' D8 r7 Q0 N6 K6 |# push “route 192.168.0.0 255.255.255.0″
* y. c' S& W4 R$ yroute 192.168.0.0 255.255.0.0
7 v5 J* ` z; Q) g
0 |, `) g5 \* p+ Y1 b5 b2 O1 a# 和Server配置上的功能一样如果使用了chroot或者su功能,最好打开下面2个选项,防止重新启动后找不到keys文件,或者nobody用户没有权限启动tun设备1 C" v8 ^! |1 S$ G: M. `2 r4 `; U
persist-key
5 K0 Q. V) @ lpersist-tun7 q2 c& p) F% @5 v
% F7 k6 X6 [% W& C# 如果你使用HTTP代理连接VPN Server,把Proxy的IP地址和端口写到下面* Y+ {5 R) L# L/ d& n. f
# 如果代理需要验证,使用http-proxy server port [authfile] [auth-method]
3 d$ L' d) ^6 W! i. @% k0 M# 其中authfile是一个2行的文本文件,用户名和密码各占一行,auth-method可以省略,详细信息查看Manual
4 P+ u/ A8 p; w( ^% B7 ?;http-proxy-retry # retry on connection failures, @6 e& a% N- b( I
;http-proxy [proxy server] [proxy port #]
+ p j' V; _ R
5 H( q3 } l4 S! {5 d: M# 对于无线设备使用VPN的配置,看看就明白了
# Q# T. L0 i3 x" u: J) q/ v1 l# Wireless networks often produce a lot9 |- R! G1 N' d
# of duplicate packets. Set this flag
! T0 Z! R/ Y. n8 _ a2 l+ j0 N# to silence duplicate packet warnings.) H1 L1 ^, Y* v3 Y9 f- V8 h, e; m
;mute-replay-warnings; }3 [& o* u' j
/ D }/ T$ Q' I6 B# U: Q
# Root CA 文件的文件名,用于验证Server CA证书合法性,通过easy-rsa/build-ca生成的ca.crt,和Server配置里的ca.crt是同一个文件
8 N) P! x% m3 |! q! S! f4 Hca ca.crt- k9 r5 a+ S& w; x. v* W; v* g
# easy-rsa/build-key生成的key pair文件,上面生成key部分中有提到,不同客户使用不同的keys修改以下两行配置并使用他们的keys即可。
6 A* l; Z; Y/ k) }9 t& I2 gcert elm.crt# ] E: s* Z b$ }2 k4 z; J, _9 A! D
key elm.key
9 z+ I' v9 Y# G5 x( Z* Z3 z
- C; q. w" T% {# Server使用build-key-server脚本什成的,在x509 v3扩展中加入了ns-cert-type选项
; B& W* z( M+ e! Z- O# 防止VPN client使用他们的keys + DNS hack欺骗vpn client连接他们假冒的VPN Server7 d8 e2 W8 @8 S* B K
# 因为他们的CA里没有这个扩展; ?4 L; S- R, g( w6 _# `& I0 F
ns-cert-type server/ M1 R, f$ ?6 E4 E& V
- b6 T' G' _% p) _
# 和Server配置里一致,ta.key也一致,注意最后参数使用的是1
1 }& F% ^, J! f& G( X) H1 ], Htls-auth ta.key 1
]" y2 m. @* f
( C0 J+ W. ^( ^8 w# 压缩选项,和Server严格一致
4 x% t' z: i D' X* [, `% P& lcomp-lzo
: |5 [% [% S- z$ X. k% o8 Q' o6 R2 E4 ^ e8 C' n, q
# Set log file verbosity.
( b- X/ H: w' p! n8 p/ Uverb 4
S( C1 I4 ?. ^4 y0 { |
|