配置对等 VPN 网关后,请检查以下组件,确保它们与 Cloud VPN 正常通信:
- 检查已配置的高可用性 VPN 隧道或传统 VPN 隧道的状态,包括操作状态。
- 检查高可用性 VPN 网关上隧道的高可用性状态。
- 查看 Cloud Router 边界网关协议 (BGP) 会话的状态或 Cloud Router 所通告的路由。
如需详细了解 Cloud VPN,请参阅以下资源:
如需了解在设置 Cloud VPN 之前需要考虑的最佳实践,请参阅最佳实践。
如需详细了解 Cloud VPN,请参阅 Cloud VPN 概览。
如需了解本页面中所用术语的定义,请参阅关键术语。
检查高可用性 VPN 隧道
此过程用于检查高可用性 VPN 网关的两个接口上的隧道状态。
控制台
gcloud
要查看隧道状态,需要执行两个步骤。首先,确定隧道名称和区域,然后使用 describe
命令选项查看隧道详细信息。
在以下命令中,替换以下选项:
PROJECT_ID
:您的项目的 IDGW_NAME
:网关的名称REGION
:网关或隧道所在的区域NAME
:隧道的名称
如需查看隧道状态,请完成以下步骤:
找到您要检查其状态的 VPN 隧道的名称和区域。您可使用以下任一方法来识别隧道:
选项 1:如需列出您项目中的所有 VPN 隧道,请运行以下命令:
gcloud compute vpn-tunnels list --project=PROJECT_ID
命令输出应类似于以下示例:
NAME REGION GATEWAY VPN_INTERFACE PEER_ADDRESS tunnel-a-to-b-if-0 us-central1 ha-vpn-gw-a 0 10.242.123.165 tunnel-a-to-b-if-1 us-central1 ha-vpn-gw-a 1 10.220.75.213 tunnel-b-to-a-if-0 us-central1 ha-vpn-gw-b 0 10.242.127.148 tunnel-b-to-a-if-1 us-central1 ha-vpn-gw-b 1 10.220.66.156
选项 2:如果您知道包含隧道的 VPN 网关的名称,要检索该网关的关联隧道的列表,请运行以下命令:
gcloud compute vpn-gateways describe GW_NAME \ --region=REGION \ --project=PROJECT_ID \ --format='flattened(tunnels)'
获知隧道的名称和区域后,使用
vpn-tunnels
命令的describe
选项确定隧道的状态:gcloud compute vpn-tunnels describe NAME \ --region=REGION \ --project=PROJECT_ID \ --format='flattened(status,detailedStatus)'
此时将返回基本状态消息和更详细的消息。命令输出应类似于以下示例。如需完整列表,请省略
--format
选项。detailedStatus: Tunnel is up and running.
下面四个命令输出示例显示了相互连接的每个高可用性 VPN 网关(共两个)上的隧道对的完整列表。也就是说,在
ha-vpn-gw-a
上,interface 0
和interface 1
上的隧道连接到ha-vpn-gw-b
的相应接口上的隧道。示例 1:
tunnel-a-to-b-if-0
creationTimestamp: '2018-10-11T13:12:33.851-07:00' description: '' detailedStatus: Tunnel is up and running. id: '2919847494518181982' ikeVersion: 2 kind: compute#vpnTunnel labelFingerprint: LABEL_FINGERPRINT localTrafficSelector: — 0.0.0.0/0 name: tunnel-a-to-b-if-0 peerIp: GW_A_IF_0_IP region: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1 remoteTrafficSelector: — 0.0.0.0/0 router: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/routers/router-a selfLink: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/vpnTunnels/tunnel-a-to-b-if-0 sharedSecret: '*************' sharedSecretHash: SECRET_HASH vpnGateway: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/vpnGateways/ha-vpn-gw-a vpnGatewayInterface: 0
示例 2:
tunnel-a-to-b-if-1
creationTimestamp: '2018-10-11T13:14:21.630-07:00' description: '' detailedStatus: Tunnel is up and running. id: '178016642781024754' ikeVersion: 2 kind: compute#vpnTunnel labelFingerprint: LABEL_FINGERPRINT localTrafficSelector: —0.0.0.0/0 name: tunnel-a-to-b-if-1 peerIp: GW_B_IF_1_IP region: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1 remoteTrafficSelector: — 0.0.0.0/0 router: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/routers/router-a selfLink: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/vpnTunnels/tunnel-a-to-b-if-1 sharedSecret: '*************' sharedSecretHash: SECRET_HASH vpnGateway: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/vpnGateways/ha-vpn-gw-a vpnGatewayInterface: 1
示例 3:
tunnel-b-to-a-if-0
creationTimestamp: '2018-10-11T13:16:19.345-07:00' description: '' detailedStatus: Tunnel is up and running. id: '1183416925692236156' ikeVersion: 2 kind: compute#vpnTunnel labelFingerprint: LABEL_FINGERPRINT localTrafficSelector: — 0.0.0.0/0 name: tunnel-b-to-a-if-0 peerIp: GW_A_IF_0_IP region: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1 remoteTrafficSelector: — 0.0.0.0/0 router: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/routers/router-b selfLink: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/vpnTunnels/tunnel-b-to-a-if-0 sharedSecret: '*************' sharedSecretHash: SECRET_HASH vpnGateway: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/vpnGateways/ha-vpn-gw-b vpnGatewayInterface: 0
示例 4:
tunnel-b-to-a-if-1
creationTimestamp: '2018-10-11T13:19:01.562-07:00' description: '' detailedStatus: Tunnel is up and running. id: '8199247227773914842' ikeVersion: 2 kind: compute#vpnTunnel labelFingerprint: LABEL_FINGERPRINT localTrafficSelector: — 0.0.0.0/0 name: tunnel-b-to-a-if-1 peerIp: GW_A_IF_1_IP region: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1 remoteTrafficSelector: — 0.0.0.0/0 router: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/routers/router-b selfLink: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/vpnTunnels/tunnel-b-to-a-if-1 sharedSecret: '*************' sharedSecretHash: SECRET_HASH vpnGateway: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/regions/us-central1/vpnGateways/ha-vpn-gw-b vpnGatewayInterface: 1
API
如需查看隧道详情,您可以使用以下任一 API 调用:
要列出特定项目和区域中所有 VPN 隧道的特性和状态,请使用
vpnTunnels.list
方法发出 GET 请求:GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/vpnTunnels
如需列出特定项目和区域中特定隧道的特性和状态,请使用
vpnTunnels.get
方法发出 GET 请求:GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/vpnTunnels/TUNNEL_NAME
检查传统 VPN 隧道
此过程可用于检查传统 VPN 网关上隧道的状态。
控制台
gcloud
检查传统 VPN 隧道状态的过程与检查高可用性 VPN 的类似。
在以下命令中,替换以下选项:
PROJECT_ID
:您的项目的 IDGW_NAME
:网关的名称REGION
:网关或隧道所在的区域NAME
:隧道的名称
如需查看隧道状态,请完成以下步骤:
找到您要检查其状态的 VPN 隧道的名称和区域。您可使用以下任一方法来识别隧道:
选项 1:如需列出您项目中的所有 VPN 隧道,请运行以下命令:
gcloud compute vpn-tunnels list --project=PROJECT_ID
选项 2:如果您知道包含隧道的 VPN 网关的名称,要检索该网关的关联隧道的列表,请运行以下命令:
gcloud compute target-vpn-gateways describe GW_NAME \ --region=REGION \ --project=PROJECT_ID \ --format='flattened(tunnels)'
通过运行以下命令描述隧道以确定其状态。此时将返回基本状态消息和更详细的消息。如需完整列表,请省略
--format
选项。gcloud compute vpn-tunnels describe NAME \ --region=REGION \ --project=PROJECT_ID \ --format='flattened(status,detailedStatus)'
API
如需查看隧道详情,您可以使用以下任一 API 调用:
要列出特定项目和区域中所有 VPN 隧道的特性和状态,请使用
vpnTunnels.list
方法发出 GET 请求:GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/vpnTunnels
如需列出特定项目和区域中特定隧道的特性和状态,请使用
vpnTunnels.get
方法发出 GET 请求:GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/vpnTunnels/TUNNEL_NAME
检查传统 VPN 转发规则
此过程用于检查您为传统 VPN 网关创建的转发规则。
控制台
在 Google Cloud 控制台中,前往 VPN 页面。
点击网关名称。
在 VPN 详细信息页面上,查看您创建的转发规则。
gcloud
如需查看特定区域中传统 VPN 网关的转发规则,请运行以下命令:
gcloud compute target-vpn-gateways describe GW_NAME --region=REGION \ --project=PROJECT_ID
API
如需查看特定区域中传统 VPN 网关的转发规则,请使用 targetVpnGateways.get
方法。将 RESOURCE_ID
替换为网关的名称。
GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/targetVpnGateways/RESOURCE_ID
解读隧道状态消息
如需从 Google Cloud 控制台或 Google Cloud CLI 解读隧道状态消息,请使用下表。
状态 | 详细状态消息 | 备注 |
---|---|---|
正在分配资源 | 正在分配资源。VPN 隧道即将启动。 | 新创建的 Cloud VPN 隧道的初始状态。 |
正在等待完整配置 | 正在等待路由配置。 | 正在准备路由或路由配置。 |
首次握手 | 对等互连握手断开,原因未知。即将重试。 | 与对等 VPN 的第 1 阶段 (IKE SA) 协商正在进行中。此协商可能已失败了至少一次。 |
已建立 | 隧道已启动并正在运行。 | 隧道已启动,并且已配置了路由。 |
无传入数据包 | 没有来自对等体的传入数据包。 | 未从对等 VPN 网关接收到流量。 |
检查高可用性 VPN 网关的高可用性状态
如需检查高可用性 VPN 网关上隧道的高可用性配置状态,请使用 Google Cloud 控制台、compute vpn-gateways get-status
命令或 vpnGateways.getStatus
方法。
输出显示了与高可用性 VPN 网关相连的每个对等网关关联的 VPN 隧道的高可用性冗余要求状态。
对等网关可以是另一个高可用性 VPN 网关,也可以是外部 VPN 网关。如果高可用性 VPN 网关连接了多个对等网关,则会显示多个高可用性配置状态,每个状态对应一个对等网关。
命令输出通过以下方式显示了正确的隧道数量和覆盖范围:
- 配置了足够冗余(覆盖范围)的 VPN 网关会显示以下状态:
HighAvailabilityRedundancyRequirementState: CONNECTION_REDUNDANCY_MET
。 - 未配置足够冗余的 VPN 网关会显示以下状态:
HighAvailabilityRedundancyRequirementState: CONNECTION_REDUNDANCY_NOT_MET
。 - 如果您的高可用性 VPN 网关与其他高可用性 VPN 网关或对等网关之间未配置足够的隧道,则命令输出会显示以下状态:
redundancyUnsatisfiedReason: INCOMPLETE_TUNNELS_COVERAGE
。
如需了解其他信息,请参阅查看日志和指标。
控制台
在 Google Cloud 控制台中,前往 VPN 页面。
如需查看网关及其隧道的详情,请点击网关名称。对于高可用性 VPN 网关,您还可以查看其高可用性状态。
gcloud
如需显示高可用性 VPN 网关的隧道状态,请运行以下命令。替换以下内容:
GW_NAME
:高可用性 VPN 网关的名称REGION
:网关所在的区域
gcloud compute vpn-gateways get-status GW_NAME \ --region=REGION
以下命令输出示例显示了连接到具有两个接口的对等网关的高可用性 VPN 网关的信息:
peerGateways: — peerExternalGateway: peer-gw tunnels: — localGatewayInterface: 0 peerGatewayInterface: 0 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-a-to-on-prem-if-0 — localGatewayInterface: 1 peerGatewayInterface:1 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-a-to-on-prem-if-1 HighAvailabilityRedundancyRequirementState: state: CONNECTION_REDUNDANCY_MET
以下命令输出示例针对的是相互连接的两个高可用性 VPN 网关。对于此类配置,请为每个高可用性 VPN 网关名称运行该命令:
获取
ha-vpn-gw-a
的状态会显示它与ha-vpn-gw-b
的连接:peerGateways: — peerGcpGateway: ha-vpn-gw-b tunnels: — localGatewayInterface: 0 peerGatewayInterface: 0 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-a-to-b-if-0 — localGatewayInterface: 1 peerGatewayInterface: 1 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-a-to-b-if-1 HighAvailabilityRedundancyRequirementState: state: CONNECTION_REDUNDANCY_MET
获取
ha-vpn-gw-b
的状态会显示它与ha-vpn-gw-a
的连接:peerGateways: — peerGcpGateway: ha-vpn-gw-a tunnels: — localGatewayInterface: 0 peerGatewayInterface: 0 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-b-to-a-if-0 — localGatewayInterface: 1 peerGatewayInterface: 1 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-b-to-a-if-1 HighAvailabilityRedundancyRequirementState: state: CONNECTION_REDUNDANCY_MET
以下命令输出示例针对的是一个连接到具有 2 个接口和 4 个 IP 地址的 AWS 虚拟网关的高可用性 VPN 网关:
peerGateways: - peerExternalGateway: peer-gw tunnels: - localGatewayInterface: 0 peerGatewayInterface: 0 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-a-to-aws-connection-0-ip0 - localGatewayInterface: 0 peerGatewayInterface: 1 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-a-to-aws-connection-0-ip1 - localGatewayInterface: 1 peerGatewayInterface: 2 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-a-to-aws-connection-1-ip0 - localGatewayInterface: 1 peerGatewayInterface: 3 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-a-to-aws-connection-1-ip1 HighAvailabilityRedundancyRequirementState: state: CONNECTION_REDUNDANCY_MET
以下命令输出示例针对的是通过一个隧道相互连接的两个高可用性 VPN 网关。此配置不满足 99.99% 的可用性 SLA 要求:
peerGateways: - peerGcpGateway: ha-vpn-gw-a tunnels: - localGatewayInterface: 0 peerGatewayInterface: 0 tunnelUrl: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/ regions/us-central1/vpnTunnels/tunnel-b-to-a-if-0 HighAvailabilityRedundancyRequirementState: state: CONNECTION_REDUNDANCY_NOT_MET detailedStatus: redundancyUnsatisfiedReason: INCOMPLETE_TUNNELS_COVERAGE
API
如需获取特定项目和区域中特定高可用性 VPN 网关的状态,请使用 vpnGateways.getStatus
方法发出 GET 请求:
GET https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/vpnGateways/GATEWAY_NAME/getStatus
检查 BGP 状态
对于将动态路由与 BGP 结合使用的隧道,您可检查 Cloud Router 路由器状态,查看路由器 BGP 会话的状态或 Cloud Router 路由器所通告的路由等详细信息。