本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
虚拟服务
重要
终止支持通知:2026 年 9 月 30 日, Amazon 将停止对的支持。 Amazon App Mesh 2026 年 9 月 30 日之后,您将无法再访问 Amazon App Mesh 控制台或 Amazon App Mesh 资源。如需了解更多信息,请访问此博客文章从迁移 Amazon App Mesh 到 Amazon S ECS ervice Connect
虚拟服务是一种抽象的实际服务,由虚拟节点直接提供或通过虚拟路由器的方式间接提供。相关服务通过其 virtualServiceName
调用您的虚拟服务,然后这些请求将路由至指定为虚拟服务的提供商的虚拟节点或虚拟路由器。
创建虚拟服务。
- Amazon Web Services Management Console
-
要使用创建虚拟服务 Amazon Web Services Management Console
-
打开 App Mesh 控制台,网址为https://console.aws.amazon.com/appmesh/
。 -
选择要在其中创建虚拟服务的网格。列出了您拥有的所有网格以及已与您共享的所有网格。
-
在左侧导航中,选择虚拟服务。
-
选择创建虚拟服务。
-
对于虚拟服务名称,为您的虚拟服务选择一个名称。您可以选择任何名称,但建议使用您要定位的真实服务的服务发现名称,如
my-service.default.svc.cluster.local
,这样可以更轻松地将您的虚拟服务与真实服务关联起来。通过这种方式,您无需更改代码以引用与代码当前引用名称不同的名称。您指定的名称必须解析为非环回 IP 地址,因为在将请求发送到 Envoy 代理之前,应用程序容器必须能够成功解析该名称。您可以使用任何非环回 IP 地址,因为应用程序或代理容器都不会与此 IP 地址通信。代理通过您在 App Mesh 中为其配置的名称与其他虚拟服务进行通信,而不是通过名称解析到的 IP 地址进行通信。 -
对于提供商,选择您的虚拟服务的提供商类型:
-
如果您希望虚拟服务跨多个虚拟节点分布流量,则选择虚拟路由器,然后从下拉菜单中选择要使用的虚拟路由器。
-
如果您希望虚拟服务直接到达虚拟节点,而不使用虚拟路由器,则选择虚拟节点,然后从下拉菜单中选择要使用的虚拟节点。
注意
App Mesh 可能会自动为你在 2020 年 7 月 29 日当天或之后定义的每个虚拟节点提供商创建默认 Envoy 路由重试策略,即使你无法通过 App Mesh API 定义这样的策略。有关更多信息,请参阅 默认路由重试策略。
-
如果您此时不希望虚拟服务路由流量(例如,如果您的虚拟节点或虚拟路由器不存在),则选择无。您可以稍后更新此虚拟服务的提供商。
-
-
选择创建虚拟服务以完成。
-
- Amazon CLI
-
使用 Amazon CLI创建虚拟服务。
使用以下命令和输入JSON文件使用虚拟节点提供者创建虚拟服务(替换
red
用你自己的价值观):-
aws appmesh create-virtual-service \ --cli-input-json file://create-virtual-service-virtual-node.json
-
示例 create-virtual-service-virtual-node.json 的内容:
{ "meshName": "meshName", "spec": { "provider": { "virtualNode": { "virtualNodeName": "nodeName" } } }, "virtualServiceName": "serviceA.svc.cluster.local" }
-
输出示例:
{ "virtualService": { "meshName": "meshName", "metadata": { "arn": "arn:aws:appmesh:
us-west-2
:210987654321:mesh/meshName/virtualService/serviceA.svc.cluster.local", "createdAt": "2022-04-06T09:45:35.890000-05:00", "lastUpdatedAt": "2022-04-06T09:45:35.890000-05:00", "meshOwner": "123456789012", "resourceOwner": "210987654321", "uid": "a1b2c3d4-5678-90ab-cdef-11111EXAMPLE", "version": 1 }, "spec": { "provider": { "virtualNode": { "virtualNodeName": "nodeName" } } }, "status": { "status": "ACTIVE" }, "virtualServiceName": "serviceA.svc.cluster.local" } }
有关使用 for App Mesh 创建虚拟服务的更多信息,请参阅 Amazon CLI 参考中的create-virtual-service命令。 Amazon CLI
-
删除虚拟服务
注意
您无法删除网关路由引用的虚拟服务。您需要先删除网关路由。
- Amazon Web Services Management Console
-
要删除虚拟服务,请使用 Amazon Web Services Management Console
-
打开 App Mesh 控制台,网址为https://console.aws.amazon.com/appmesh/
。 -
选择要从中删除虚拟服务的网格。列出了您拥有的所有网格以及已与您共享的所有网格。
-
在左侧导航中,选择虚拟服务。
-
选择要删除的虚拟服务,然后单击右上角的删除。您只能删除您的账户被列为资源所有者的虚拟网关。
-
在确认框中,键入
delete
,然后单击删除。
-
- Amazon CLI
-
要删除虚拟服务,请使用 Amazon CLI
-
使用以下命令删除您的虚拟服务(替换
red
用你自己的价值观):aws appmesh delete-virtual-service \ --mesh-name
meshName
\ --virtual-service-nameserviceA.svc.cluster.local
-
输出示例:
{ "virtualService": { "meshName": "meshName", "metadata": { "arn": "arn:aws:appmesh:
us-west-2
:210987654321:mesh/meshName/virtualService/serviceA.svc.cluster.local", "createdAt": "2022-04-06T09:45:35.890000-05:00", "lastUpdatedAt": "2022-04-07T10:39:42.772000-05:00", "meshOwner": "123456789012", "resourceOwner": "210987654321", "uid": "a1b2c3d4-5678-90ab-cdef-11111EXAMPLE", "version": 2 }, "spec": { "provider": { "virtualNode": { "virtualNodeName": "nodeName" } } }, "status": { "status": "DELETED" }, "virtualServiceName": "serviceA.svc.cluster.local" } }
有关使用 for App Mesh 删除虚拟服务的更多信息,请参阅 Amazon CLI 参考中的delete-virtual-service命令。 Amazon CLI
-