找回密码
 注册
查看: 3661|回复: 0

neutron 虚机网络无法访问外网

[复制链接]

1

主题

0

回帖

12

积分

管理员

积分
12
QQ
发表于 2018-11-9 11:11:10 | 显示全部楼层 |阅读模式
为了解决这个问题,我们需要了解L3 agent(L3代理)的工作原理。其主要职责是允许L3连接和路由,也提供NAT,并使用命名空间进行网络隔离。通常它将被安装在网络节点上,也是提供访问外部网络的代理。
- Z+ K0 Y0 \" g: Q- O+ e" a; k# }
官网教程 创建一个虚拟机 中写了如何创建 provider network 和 self-service network。在self-service netwrok中,创建的网络有一个内部IP和一个外部IP。创建self-service network时,需要有一个provider network,并创建一个路由,把self-service network的子网作为路由的一个接口,再把路由连接到provider网络上。这时运行以下命令,可以看到provider网络的两个网关:
8 x, R8 |1 o% h8 E$ neutron router-port-list router
8 Z* ^1 H  Z$ }, A* G2 d# ^
  W* ^  C9 x' o6 i' Z: W) g% r
' @/ d" L! D' J
2 }. i% d4 M1 s9 p0 p- q/ _如上图,其中 172.16.1.1 是self-service network的内部网关,是无法从外部ping通的,203.0.113.102 是外部网关,可以从外部ping通。如上所说,在创建self-service network时,会通过建立一个路由把该网络和一个provider network连接以保证self-service network可以访问外部网络。0 P2 q! X7 D5 }$ G
在self-service network中创建虚拟机,需要给虚拟机分配一个浮动IP,如果我们想ping通虚拟机,应当使用这个浮动IP。
1 A, K9 a5 }) C$ \上文的ping通private IP笔者略有疑惑,可能指的是从虚拟机内部ping 类似 172.16.1.1 的内部网关,也可能是从外部ping虚拟机绑定的浮动IP。
7 ?9 g3 ^  }8 w6 a接下来,从路由器命名空间尝试使用浮动IP来ping 虚拟机:% K5 p* ]$ |7 q9 G# t
$ sudo ip netns exec qrouter-xxx-xxx-xxx ping <vm_floating_ip>' O. b8 R7 x. L7 W2 W+ S
笔者注:上面命令的命名空间可以用如下指令获得:! Z4 N9 S3 v# U  L- T1 \
$ ip netns
/ n% y5 `2 A3 u8 I! X6 Y5 h5 ~, j用如下指令可以得到所有虚拟机的IP:! j. P0 X- _( y0 t& e+ J6 |
$ openstack server list: I' t. ^( V/ P& O0 L
这可能是个愚蠢的检查,因为浮动IP总是处于路由器命名空间内,但至少它会告诉我们情况有多糟糕。, w. [* l3 D, O( Q
你还应该检查网桥配置问题。 用下面的命令检查它:
, R4 N1 S/ o! z! S4 d$ ovs-vsctl show
: V# a. A# w6 C, a. S- O" k7 ?别忘了检查L3 agent的log文件:' m3 }0 ]+ q  R! f: J. B
$ sudo grep -E -i "error|trace" /var/log/neutron/l3-agent.log
2 y1 t" K0 I& q5 w3 l0 b- G用以下命令看虚拟机是否得到了IP:
- @7 C" O! n5 M$ ip a; D0 }  _5 _4 T
从虚拟机里ping网关看是否能到达:- g* W2 N1 Z: p2 _4 C: z
$ route -n, \% K; a5 R, ?0 @" T6 ?% o
$ ping <default_gateway_ip>* r7 i1 D' C( W+ l: t0 k
问题三: 虚拟机无法访问元数据服务器元数据服务器是为虚拟机提供元数据的服务。数据可以是ssh密钥,ip地址,主机名。8 p" }. j3 |0 C& o1 [
元数据代理负责将来自虚拟机的请求代理到元数据服务器或 nova。 有两种方法来配置它:
0 L1 q4 m( @+ j  [1 G
  • 路由网络 - 当你有一个连接到路由器的网络
  • 非路由网络 - 当你有没有连接到路由器的网络,所以它是隔离的。
    7 H' H" [) M  h" J
我们来看看路由网络的工作流:
. E, K5 j$ S" |- J) r! A' h/ @
) l8 @/ v7 ?# z+ f* |3 @* s" D1 P8 o
. G- ?7 o* q! s# d% I$ U9 D- U

, U, T! O% M" S$ \  |routed_networks_metadata.png+ x3 ?* l# z, t# M9 W

- N; G; @0 a, @注意:metdata代理由L3代理生成,并监听请求。当来自虚拟机的请求到达元数据代理时,它将一些信息添加到虚拟机和路由器id的头部IP中,并将其转发给元数据代理。
2 G4 `9 Y6 ~6 f! e3 g- `现在让我们更仔细地看看其他配置 - 隔离网络:
; k( c" f. ~7 n' z% G
# n+ C. Z% v( Z0 A" \5 [7 p/ C
/ B6 v* e, D" u: j( B) z# k% w0 h4 T, K$ t8 S8 E, B0 t% t: y

4 K# y% ?! ^7 ]$ |isolated_network_metadata.png# U/ e. Z% i2 x3 {! i

9 s* D4 y$ K" N注意:为了隔离网络能工作,必须在dhcp配置文件中进行配置:% N* n: C& T" B" L! `
enable_isolated_metadata = True& E5 b6 p  j  R/ a9 U
笔者注:在以下文件中配置:2 i6 V( j8 r% S6 r( [
/etc/neutron/dhcp_agent.ini
0 W* H7 F0 e* F4 h我们还使用DHCP的 option 121,在向DHCP请求IP地址时向虚拟机注入路由。 所以元数据代理是到达元数据服务器的下一个跃点。
% Y1 c6 x4 T- v7 c* [Debug步骤首先查看metadata agent是否正常运行:
$ o- o' C$ T) _' _2 N& M$ neutron agent-list) t, m3 K- m4 D4 @( R( i( w# F
在metadata agent 那行应当看到alive下面的微笑。$ }0 a- C# ^9 T. Y" @+ W5 h
接着,检查metadata proxy是否正常。请记住,它是由L3代理在路由器(或dhcp)命名空间中产生的,所以您应该检查它是否在命名空间的进程表中:5 L' Z* z/ E/ c0 o$ u
$ sudo ip netns exec qrouter-xxx-xxx-xxx ps -ef | grep metadata-proxy; b' D4 V) K5 a( |! I' B, A
问题会反映在metadata的log文件中,所以前去检查:
1 A. g: e. E' B8 W0 h# Q5 [$ sudo grep -E -i "error|trace" /var/log/neutron/metadata-agent.log /var/log/neutron/neutron-ns-metadata-proxy-xxx-xxx-xxx.log* A) T0 O* I$ j' x. A$ S
检查是否可以通过路由/DHCP到达元数据服务器:3 t) W# m+ r! N+ X6 s  u
$ sudo ip netns exec qrouter-xxx-xxx-xxx ping <metadata-server_IP>$ }# F+ B1 C, N) s$ G6 y2 t
检查创建虚拟机的镜像是否支持 option 121。如果不支持,那么虚拟机可能无法得到路由并且到达元数据服务器。
+ C- t8 s+ K; a; G如果所有都尝试了还没有发现问题,试着使用 tcpdump 来解决问题。
# z. K1 }* s. Q0 c$ L/ R问题四: VIF plugging timeout为了理解为什么会遇到timeout问题,我们需要介绍L2代理。
, z9 U& p( S" @; H2 AL2代理在计算主机上运行,其主要职责是配置节点上的本地交换机并连接新设备,它通过RPC与neutron服务器通信,还负责提供使用iptables和ip集合的安全组规则。$ k0 J% J) d4 s( r/ }- a
让我们更详细地看看VIF如何工作:
2 E' [* U7 K* K; T3 K  e' A
" q0 U( _. p$ Z8 Z4 q' H6 Q7 f  k9 j9 B
  J, m" `7 h$ h, [! X
0 S  L9 ?0 E' n6 t  K6 r* B
vif_plugging.png
6 L3 _$ J  r! B: `0 P" }( N; y" W9 Y3 T
当Nova发送allocate_network请求时,它将超时设置为5分钟。如果Nova在5分钟内没有得到Neutron的回复,你会得到VIF plugging timeout。
% s, |: M2 G9 D) u& i0 ^debug步骤检查日志。L2代理,neutron和nova日志可以帮助查找问题,在计算节点上输入:8 l: V. }2 [5 i  j
$ sudo grep -E -i "error|trace" /var/log/nova/nova-compute.log /var/log/neutron/openvswitch-agent.log' N2 b' f1 e! \( t+ e5 v7 q
在控制节点上:+ K; G: r# c0 P" G
$ sudo grep -E -i "error|trace" /var/log/neutron/server.log* X7 n4 r3 W  r
如果系统加载缓慢,或者你正在执行压力测试,则可能需要调整/etc/nova/nova.conf文件中的服务器配置:/ N  `& |% E, L# y
  • 尝试增加 vif_plugging_timeout 以提供更多的时间来插入接口
  • 尝试增加 rpc_thread_pool_size 和 rpc_conn_pool_size 以使处理速度更快
    5 U. r1 B. \! S* U; ?, |
一些好用的工具让我们回顾一下在对neutron进行debug过程中用到的工具。
& h  Y& w1 i2 {/ V; yip aip addr(ip a只是一个快捷方式)对于检查你的机器/命名空间中的设备非常有用。它允许你获取设备名称、查看设备是否启动、获取IP地址、MTU以及其他一些网络参数。$ X* m3 [+ f1 A6 C( l! W) \; M
route -n它会显示路由表。通过路由表,你可以知道你的数据包在流出时将采用哪个路径。: Y& _* `& R% c( a, X* r" `
iptables -L查看节点上存在哪些防火墙规则。如果你的数据包突然消失或没有到达最终目的地,防火墙的某些规则可能是原因。
9 U, w( {  F4 i& _8 q/ W; ]1 Parp查看主机上的arp表。利用它可以查看你的节点能不能找到其他节点的地址。
8 E% p3 f0 o1 y" Wtcpdump在这篇文章中多次提到过。这是一个很棒的数据包追踪工具,容易安装,也容易使用。我将在另一篇文章中介绍它,因为有很多方法可以使用,最好花时间专门学习。对于最基本的使用,只需运行:  @% H2 D1 j3 w' U' g+ M2 I6 }
$ tcpdump -i <device_name>3 M$ C1 y+ @9 l9 ~
ip netns查看namespace。为了列出你所在节点可用的namespaces,可以使用:
# O+ W- ^( S9 E9 t# z# ~% e3 ?. N$ ip netns list6 R- u  d% \2 e; b% W6 x
你可以使用 ip netns exec 查看更多。例如,要在命名空间中显示路由表,请使用:6 A+ i- Y1 Z% A: G# M
$ ip netns exec qrouter-xxx-xxx-xxx route -n" v" s1 Q' n/ W2 j% i* ]
OpenVSwich如果你在部署中使用openvswitch,则有几个用于调试和故障排除的工具:
: r0 D* _% b$ w* r: _ovs-vsctl show —— 显示机器上网桥的配置
6 E! ?0 b0 X* V  S5 Aovs-ofctl show —— 显示数据路径
) u  U8 C' f- W/ F! A/ oovs-ofctl dump-flows —— 转储安装在机器上的所有流
# d: _" Y0 \- O. i3 e0 covs-ofctl dump-flows br-tun —— 转储br-tun上的所有流
9 L+ o6 h* h$ c* w- x$ vovs-ofctl dump-flows br-tun table = 21 —— 在特定表中转储br-tun上的所有流
% T/ e( ?1 ?$ ~LinuxBridge对于linux网桥,请使用以下命令:! L1 }3 y8 F' d
brctl show  —— 显示机器上网桥的配置
: I% J# S; m$ |  a8 Vbrctl show <bridge name>  —— 显示特定网桥的配置
8 G% W4 {! K- E# V* c/ T补充再介绍一些你可能想要熟悉的几个重要的网络设备。
: c  Z( U6 u- ?6 C我们从TAP设备开始。TAP设备是一个虚拟网络接口,用于连接由虚拟机管理程序(KVM,Xen等)实现的虚拟机实例。流量到达TAP设备,由虚拟机实例接收。要记住TAP设备通常是流量的起点,可以从TAP设备开始跟踪流量。' f! T7 l& ?0 a6 I4 Y
要查看TAP设备,只需运行:$ ^9 @. @1 [% D) h+ c
$ ip a | grep -i tab
$ N5 R( C( K7 u: g: V1 N0 {更多关于TAP设备的信息,可以在 这里  找到。) m. Y* F0 @: G' E6 x/ p% p
TAP设备使用Linux bridge进行桥接。通常Linux桥名以qbr开头,这是qunaum bridge的简写(qunaum是neutron以前的名字)。你可以使用brctl列出系统上的linux bridge。5 v8 q7 ~: G* l6 }; E# T6 n2 f! x+ H
$ brctl show! v* ^1 n2 P3 {& X( X1 m: s1 [
你会在输出中看到TAP接口和qvb接口。: l: H$ D$ f9 G9 b9 r0 f
qvb(Quantum veth bridge)和另一end - qvo(Quantum veth openvswitch)构成一个虚拟以太网对(Virtual Ethernet Pair)。它用来连接Linux桥和OVS桥。可以把它们想象成一条管道,任何在一个设备上进入的东西都应该从这个设备上离开。
) z+ h! u% q; I% @( S( k如果你列出集成桥上的端口,你将看到其中一个端口是qvo,它将你连接到Linude Bridge。) c7 X3 d4 O) B  G& P; W
路由器和DHCP设备直连到br-int。在列出DHCP命名空间中的接口或列出集成网桥上的端口时,可以看到TAP设备条目。2 k- O( n3 R; c7 H9 O. }' ~
$ ip netns exec qdhcp-<network_id> ip address
4 z6 T- I5 Q; t( l& ]$ ovs-vsctl list-ports br-int
$ x( ^/ `5 x4 q7 b% c% Q1 h% v笔者总结在了解了neutron的基础概念,通过一些图表知道了数据流的走向后,对于我们debug最有用的还是查看log。Openstack的log都处于 /var/log 目录下,我们通过查看、解决log里的问题,并重启相应网络服务,基本可以解决问题。# O) C% f' J2 A) |) F9 F4 O5 l$ A
笔者翻译这篇博客的过程中,对Openstack的neutron模块有了更深的了解,也利用博客里梳理的思路解决了实验室Openstack环境遇到的问题,以后会多多学习这类博客,看到好的博客会争取翻译过来。2 e+ ]& {' `- \; ]9 n
- i* w+ |; g& T0 y/ \6 a
' t- K; B4 }4 N1 g7 p) M- d

4 M; Z2 @2 C7 L, G  \3 O% t$ q
: ~) {) d/ i: n4 ^) h
您需要登录后才可以回帖 登录 | 注册

本版积分规则

返回首页|Archiver|手机版|小黑屋|易陆发现技术论坛 ( 蜀ICP备2026014127号-1 )

GMT+8, 2026-6-12 02:06 , Processed in 0.017747 second(s), 23 queries .

Powered by Discuz! X5.0

© 2001-2026 Discuz! Team.

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