找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 15594|回复: 0

openvpn中server.conf和client.conf配置文件详解

[复制链接]
发表于 2015-10-25 10:02:35 | 显示全部楼层 |阅读模式
Server使用的配置文件server.conf
; {# J* E* K! ?—————————–$ i8 Y: G8 t5 `' G% q: }
#申明本机使用的IP地址,也可以不说明
7 N: T. u* a7 B" w;local a.b.c.d
8 j6 E0 p, Z" T" }+ I, t! e#申明使用的端口,默认1194
: j- E& {& c/ a2 F1 Cport 1194
6 \' L7 T" t/ ~) \; g3 Y5 `#申明使用的协议,默认使用UDP,如果使用HTTP proxy,必须使用TCP协议
& e- `9 E; }5 `. H! X! l4 ]#如果使用ipv6应改为proto tcp6或proto udp6
3 y6 r6 U5 k6 c. T. k;proto tcp 1 D! t6 r+ Z0 I- q4 T
proto udp
. V1 e7 f. A/ O" B3 R#申明使用的设备可选tap和tun,tap是二层设备,支持链路层协议。8 p, K0 k3 c5 b% ?1 V% Z2 r' n$ L9 S
#tun是ip层的点对点协议,限制稍微多一些,本人习惯使用TAP设备
' ~& k) G' \* J% i. hdev tap
5 M$ A2 C* K3 p( i" E& g;dev tun# r0 l8 W6 Y9 k7 @) x% \
#OpenVPN使用的ROOT CA,使用build-ca生成的,用于验证客户是证书是否合法
  `5 t0 J2 T8 s; x! n  V" g7 Xca ca.crt
2 \  _5 T/ U( }, w#Server使用的证书文件
' ~: a, ^  k8 K$ X  Z7 Pcert server.crt
  f1 S3 i2 V% Q5 R0 A2 O: L#Server使用的证书对应的key,注意文件的权限,防止被盗
$ P% o8 c6 U( |( m! R" U  z! zkey server.key # This file should be kept secret2 M! G" R3 P' n; [9 }9 D1 B
#CRL文件的申明,被吊销的证书链,这些证书将无法登录
5 E# I0 @0 T5 X" ?+ ncrl-verify vpncrl.pem
$ F9 @5 Q/ Z! h: |9 z- D#上面提到的生成的Diffie-Hellman文件* z  h2 P$ W: B' U" V+ @& b4 Z
dh dh1024.pem: ?$ k2 E+ m: O
#这是一条命令的合集,如果你是OpenVPN的老用户,就知道这条命令的来由/ `$ I" }  |7 i4 n  f
#这条命令等效于:
8 M& b. I) T% F% v! n# mode server #OpenVPN工作在Server模式,可以支持多client同时动态接入
) T6 Y: F) M3 h- Z/ g# tls-server #使用TLS加密传输,本端为Server,Client端为tls-client7 B/ Y+ q' N4 t9 ]
#6 i7 X7 i3 N5 s5 n2 K
# if dev tun: #如果使用tun设备,等效于以下配置2 o; B6 K0 R! m0 h1 c: r
# ifconfig 10.8.0.1 10.8.0.2 #设置本地tun设备的地址
5 t6 Q! c# J8 y9 d4 [# ifconfig-pool 10.8.0.4 10.8.0.251 #说明OpenVPN使用的地址池(用于分配给客户),分别是起始地址、结束地址! h" S( j8 w& \3 m' p3 c
# route 10.8.0.0 255.255.255.0 #增加一条静态路由,省略下一跳地址,下一跳为对端地址,这里是: 10.8.0.2" J0 |: @3 v- X
# if client-to-client: #如果使用client-to-client这个选项9 O8 c. m  ~: x7 Z" Y+ W$ Y
# push “route 10.8.0.0 255.255.255.0″ #把这条路由发送给客户端,客户连接成功后自动加入路由表,省略了下一跳地址: 10.8.0.1
6 u# |6 A  N8 }0 }6 X9 @3 c# else7 a, }8 ?1 {4 t; o
# push “route 10.8.0.1″ #否则发送本条路由,这是一个主机路由,省略了子网掩码和下一跳地址,分别为: 255.255.255.255 10.8.0.12 q& y7 ?6 Q+ F/ f3 C1 o
#
  O; l& V7 z) `# if dev tap: #如果使用tap设备,则等效于以下命令( x* ]) v; e) I% |4 @8 |
# ifconfig 10.8.0.1 255.255.255.0 #配置tap设备的地址- {: x6 G* }) Z0 v( \
# ifconfig-pool 10.8.0.2 10.8.0.254 255.255.255.0 #客户端使用的地址池,分别是起始地址、结束地址、子网掩码
- ^9 J0 }: {* {- s# push “route-gateway 10.8.0.1″ #把环境变量route-gateway传递给客户机
4 W/ N7 S( r, }/ T: j2 c/ ^2 |#
* K% i8 U+ o* w% d: eserver 10.8.0.0 255.255.255.0 #等效于以上命令
9 o: c* @- V9 E1 `#用于记录某个Client获得的IP地址,类似于dhcpd.lease文件,. c9 o. P. z! {# S, k4 y" B
#防止openvpn重新启动后“忘记”Client曾经使用过的IP地址$ [+ H1 |, Q) `# T
ifconfig-pool-persist ipp.txt
* P2 t' a* i% N1 i0 w#Bridge状态下类似DHCPD的配置,为客户分配地址,由于这里工作在路由模式,所以不使用. O2 S" V9 O, C. G# W
;server-bridge 10.8.0.4 255.255.255.0 10.8.0.50 10.8.0.100# B/ M/ D+ v. v3 b: R
#通过VPN Server往Client push路由,client通过pull指令获得Server push的所有选项并应用; f- Z, G6 a# q7 B" d3 e
;push “route 192.168.10.0 255.255.255.0″6 x: t/ |; a/ ^/ c6 s2 n
;push “route 192.168.20.0 255.255.255.0″
/ a1 @8 {  Q7 w5 m1 A#VPN启动后,在VPN Server上增加的路由,VPN停止后自动删除; ]6 g7 G2 S! U! d
;route 10.9.0.0 255.255.255.252
8 L9 @; O0 V, ?( g8 u# _" C  y#Run script or shell command cmd to validate client! L: _6 u7 x; X3 s
#virtual addresses or routes. 具体查看manual( s! |* N6 Y7 s
;learn-address ./script
" E7 X6 G. |. \8 @; t! L#其他的一些需要PUSH给Client的选项
" x' l! o/ E3 B- H( i) |$ D& [5 {#4 c  F! c2 C! {
#使Client的默认网关指向VPN,让Client的所有Traffic都通过VPN走
; U) z% `/ a1 F  J  V;push “redirect-gateway”6 J# U: x# i3 ^: k- Q
#DHCP的一些选项,具体查看Manual2 p+ {* J- [( {, `& ?" E
;push “dhcp-option DNS 10.8.0.1″/ |7 c4 _) I) `
;push “dhcp-option WINS 10.8.0.1″/ y. }  |, @: b$ l
#如果可以让VPN Client之间相互访问直接通过openvpn程序转发,
+ r% @; D- A6 V+ h! v( h#不用发送到tun或者tap设备后重新转发,优化Client to Client的访问效率
# H$ K8 s9 u' C4 p) K* U! Zclient-to-client
/ |6 r  o$ G# {" o( L6 m#如果Client使用的CA的Common Name有重复了,或者说客户都使用相同的CA! S; u7 L7 q  O* N) e
#和keys连接VPN,一定要打开这个选项,否则只允许一个人连接VPN
; I) Z6 h( x# h% d* }- ?' V;duplicate-cn9 u1 M5 O/ c3 U* g0 o  d+ b
#NAT后面使用VPN,如果VPN长时间不通信,NAT Session可能会失效,: X; K/ I: m. ?0 T5 `) Y
#导致VPN连接丢失,为防止之类事情的发生,keepalive提供一个类似于ping的机制,
7 t% R. |+ X0 |% g" Q- S#下面表示每10秒通过VPN的Control通道ping对方,如果连续120秒无法ping通,
' L% m. w- W: j+ `1 Z/ J+ z4 Q#认为连接丢失,并重新启动VPN,重新连接" ~0 E2 q! J7 ~. ?& l* r
#(对于mode server模式下的openvpn不会重新连接)。
% w/ t4 q) t/ c2 E, i2 Bkeepalive 10 1200 q7 ~. l9 [0 B/ ?
#上面提到的HMAC防火墙,防止DOS攻击,对于所有的控制信息,都使用HMAC signature,
  Y0 u+ k9 @  P4 ^#没有HMAC signature的控制信息不予处理,注意server端后面的数字肯定使用0,client使用1% M$ F: g+ V+ o3 Y
tls-auth ta.key 0 # This file is secret: U) a* O0 C5 K' [
#对数据进行压缩,注意Server和Client一致
( k' g  {6 x+ p2 b  [$ c$ pcomp-lzo
$ u7 X' U6 P6 m! B7 M#定义最大连接数
& W. t3 ~; B9 e# P9 a;max-clients 1003 u  c$ L6 M2 V$ A! i
#定义运行openvpn的用户
/ I$ d. r. e& u8 I4 K0 H6 tuser nobody, H- r. }6 \7 W# g1 o/ S
group nobody  M1 m6 k7 r9 t' }, c; b! g
#通过keepalive检测超时后,重新启动VPN,不重新读取keys,保留第一次使用的keys( R1 D0 Y  [" }* F' v# ]4 r  O, j# B
persist-key& X+ g  T7 [  }  q- o0 ?7 V
#通过keepalive检测超时后,重新启动VPN,一直保持tun或者tap设备是linkup的,4 l+ j& o5 `0 e7 u2 N
#否则网络连接会先linkdown然后linkup
% Q  i1 l0 M4 ~6 ppersist-tun
: l6 \0 J& Y3 r) x7 \3 n4 m- j#定期把openvpn的一些状态信息写到文件中,以便自己写程序计费或者进行其他操作
; P/ j7 v7 g5 X9 xstatus openvpn-status.log' C; [: T. h$ `! F5 ~/ ^$ O; d, I
#记录日志,每次重新启动openvpn后删除原有的log信息
# i8 ]# K' y" c* c' H  n6 N; zlog /var/log/openvpn.log
0 V3 B: u1 i9 ^& m1 \#和log一致,每次重新启动openvpn后保留原有的log信息,新信息追加到文件最后
& m3 ], O( F2 s, G;log-append openvpn.log
" h  S6 L. A- C5 u# j; ?2 |#相当于debug level,具体查看manual! }  y4 b: ^! o- @! ^4 _
verb 3
( R( v0 P$ ]! e& ?& S5 a——————————-6 B& I! Q7 H" j1 u
把server.conf文件保存到/etc/opennvpn目录中,并把使用easy-rsa下的脚本什成的key都复制到/etc/openvpn目录下,命令如下:
: X2 @* H3 J3 _8 c  Q6 E* B' c& Z' x% N#cd /etc/openvpn# ^6 m0 l6 u' z* x
#cp easy-rsa/keys/ca.crt ., N6 B7 c# P5 i, K
#cp easy-rsa/keys/server.crt .
' \+ U& Z9 q  j3 z6 Q#cp easy-rsa/keys/server.key .
2 U. k1 o6 x/ X1 M8 r" b#cp easy-rsa/keys/dh1024.pem .8 Y2 ]/ T: x. r0 U6 V
#cp easy-rsa/keys/ta.key .& Q( j2 ~3 [" t% Q2 K
#cp easy-rsa/keys/vpncrl.pem .
! l9 L8 q( O' B; [( u( q2 z7 ^' v创建OpenVPN启动脚本,可以在源代码目录中找到,在sample-scripts目录下的openvpn.init文件,将其复制到/etc/init.d/目录中,改名为openvpn2 e: `0 f8 L0 L+ i2 u. f
然后运行:
* v4 B7 g. W+ E( Q6 }2 p5 `) e#chkconfig –add openvpn8 Z7 F1 J( H- V9 N; B9 b" n; \  g( w
#chkconfig openvpn on
! Q2 r3 }- k6 l- c# N8 z立即启动openenvpn, e: I2 S2 I: t5 @: e. v
#/etc/init.d/openvpn start3 p. B4 l; ]. M% N
# P3 y. F0 t, t& H" k: A- N6 W, x
接下来配置客户端的配置文件client.conf:
7 K5 o9 V" Q( @. m( {7 ^! GLinux或Unix下使用扩展名为.conf Windows下使用的是.ovpn,并把需要使用的keys复制到配置文件所在目录ca.crt elm.crt elm.key ta.key
7 D/ K+ Q2 p7 s  ^! L———————————-
3 T( T% C; p% I: U+ i# 申明我们是一个client,配置从server端pull过来,如IP地址,路由信息之类“Server使用push指令push过来的”  P: b, r4 L7 g2 e
client+ v( K( m0 {2 T$ C& W% K% T

7 q1 W/ G1 I7 ^  T#指定接口的类型,严格和Server端一致, Z+ X% l2 ?1 G$ _9 N; x
dev tap2 R' v0 f! S7 I1 v, L+ A* i' k8 Y6 z
;dev tun5 \* v& \/ L1 w7 q0 G
# S' e/ @' ~& K% J% F
# Windows needs the TAP-Win32 adapter name' u7 O; L" K7 R! d& E0 A' x
# from the Network Connections panel
! j8 F) g3 U) m( s, ]  _# if you have more than one. On XP SP2,5 q7 S: G, p0 v; J. a! A4 w" w
# you may need to disable the firewall0 `$ x$ G, L+ k( K
# for the TAP adapter.
: A$ @8 B/ K* F/ X;dev-node MyTap
" r" n4 f7 \3 O5 P! ]& W1 q' F$ A7 E3 M' o6 [5 t
# 使用的协议,与Server严格一致
% o+ t5 D& Y3 E/ P# S/ `;proto tcp
, z8 G. \0 E  I- \proto udp
3 G& J( R& ~( k/ ~! F8 J+ h; X# p) F# Z3 l. o$ C' _( q* @
#设置Server的IP地址和端口,如果有多台机器做负载均衡,可以多次出现remote关键字
6 z. }7 e+ F1 ]% c: X- k' ]; S: b# z# B. c9 E1 d3 n* i" B
remote 61.1.1.2 1194
! t; S$ X2 H4 J7 ^2 P9 `;remote my-server-2 1194" I7 `, a0 }8 l1 e/ @6 _3 W
( n4 j% `* h6 G
# 随机选择一个Server连接,否则按照顺序从上到下依次连接; @" R8 h, M! _% z$ Z& F
;remote-random% M( z5 z2 o7 r/ e/ e8 J

; v3 y8 e9 R, c# 始终重新解析Server的IP地址(如果remote后面跟的是域名),
- f" Q8 N2 J# Q% Q/ J$ a# 保证Server IP地址是动态的使用DDNS动态更新DNS后,Client在自动重新连接时重新解析Server的IP地址/ Q8 G( q9 l& \: H
# 这样无需人为重新启动,即可重新接入VPN
3 W' w( B5 R- V6 U3 W3 dresolv-retry infinite
4 _' Z2 B+ r5 m; o' M6 z/ D/ `
& y% ]* N* U% H8 T! p, M6 `# 在本机不邦定任何端口监听incoming数据,Client无需此操作,除非一对一的VPN有必要9 R% y& ]. s' A5 E5 H5 O6 m. _
nobind
1 _3 E- M# e3 F. h. u2 q% ~+ F* K9 g* `5 z& n6 ?
# 运行openvpn用户的身份,旧版本在win下需要把这两行注释掉,新版本无需此操作4 @2 R5 p$ o  l% I
user nobody1 S: P( p8 G6 f5 h: I: s; L
group nobody, U0 L; n1 p1 S2 `

# s4 C/ r1 J$ g% W  B. g#在Client端增加路由,使得所有访问内网的流量都经过VPN出去1 P% B# J1 l. ~; U9 l
#当然也可以在Server的配置文件里头设置,Server配置里头使用的命令是/ R/ S/ N% L7 D: ]5 Q' w( I
# push “route 192.168.0.0 255.255.255.0″5 J% \( C5 s' z8 t
route 192.168.0.0 255.255.0.0! n" N* `' q3 e' I, g; w; {( @( i
/ d( {7 n" M! O+ A* u3 T
# 和Server配置上的功能一样如果使用了chroot或者su功能,最好打开下面2个选项,防止重新启动后找不到keys文件,或者nobody用户没有权限启动tun设备
  t; t* ?  L5 jpersist-key
. L& H9 E- u# I$ i3 cpersist-tun* h2 c+ t4 c/ \) v* u% Q# X
$ s( @; T7 P. d2 f) Z
# 如果你使用HTTP代理连接VPN Server,把Proxy的IP地址和端口写到下面
9 R) n8 G& w8 y6 D+ W% V+ v# 如果代理需要验证,使用http-proxy server port [authfile] [auth-method]4 v0 T+ f" y9 x: K
# 其中authfile是一个2行的文本文件,用户名和密码各占一行,auth-method可以省略,详细信息查看Manual
  }3 T* `8 }" _! f& P3 y% W;http-proxy-retry # retry on connection failures  E' O' N# ~* b; N8 Z" ^
;http-proxy [proxy server] [proxy port #]
# `1 q$ f, y0 i' s" Z6 W7 a" w) n/ h% V! S8 G' H
# 对于无线设备使用VPN的配置,看看就明白了
6 f' @% A& o6 a7 \) E# Wireless networks often produce a lot5 I: f# b. [4 A4 d. c# ]
# of duplicate packets. Set this flag
$ `' @- c6 M  l: t: }1 a8 t. I& w# to silence duplicate packet warnings.
  P4 B0 q- \: y  P! ?: D;mute-replay-warnings
% b; I- C  v1 i# D2 a! i) q1 J" ~( F
" y3 \, W$ n+ O* }2 W3 |+ E# Root CA 文件的文件名,用于验证Server CA证书合法性,通过easy-rsa/build-ca生成的ca.crt,和Server配置里的ca.crt是同一个文件/ K9 v9 _  j" y5 t
ca ca.crt* L" m& n' ^- [: h6 S$ o5 q3 k
# easy-rsa/build-key生成的key pair文件,上面生成key部分中有提到,不同客户使用不同的keys修改以下两行配置并使用他们的keys即可。" ?2 y# L* B1 r( K
cert elm.crt
: J" j4 x' B" ]6 O# z! {key elm.key
8 n  U+ n! G- O3 M# X
0 }+ p/ ]0 n6 r& t& q3 @# Server使用build-key-server脚本什成的,在x509 v3扩展中加入了ns-cert-type选项0 E! O) i9 `3 C# T
# 防止VPN client使用他们的keys + DNS hack欺骗vpn client连接他们假冒的VPN Server
0 I# h4 p+ K$ y. \- i' @# 因为他们的CA里没有这个扩展  k0 u' C1 ]" r4 m- X) L2 ~) j) x1 ^: t
ns-cert-type server
* F( g: K* @1 A6 |: z  f/ b3 Q/ }( Y5 r+ k+ _  Q$ n
# 和Server配置里一致,ta.key也一致,注意最后参数使用的是1
! y! i' t) X! L: l  _, rtls-auth ta.key 1
2 [3 L1 Y1 p1 R; A& G5 I- z5 \" Q6 C6 y$ |" ~5 W
# 压缩选项,和Server严格一致
% ~! N9 X0 P. {2 f: C' lcomp-lzo7 \: w3 |. L" U
3 k4 W1 F; G0 Q: w2 l% G: {1 W0 R
# Set log file verbosity.! \7 c( ?3 Q+ r0 ?
verb 4
1 h: u; t2 O$ v8 d, z4 i) A+ l( q1 V
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|第一站论坛 ( 蜀ICP备06004864号-6 )

GMT+8, 2026-6-25 11:12 , Processed in 0.067996 second(s), 23 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表