amazon-web-services - 使用 Boto3 客户端与资源时的约定是什么?
问题描述
所以我有一个 API 可以调用 AWS 服务,我正在使用 Boto3 来在我的 python 应用程序中执行此操作。我遇到的问题涉及 Boto3 的客户端与资源访问级别。我想我理解它们之间的区别(一个是低级访问,另一个是高级面向对象的服务访问)但我的问题是是否可以同时实例化客户端和资源?例如,通过客户端使用资源更容易访问某些资源功能,但有些功能只有客户端才有。实例化两者并在需要时使用最简单的访问级别是不好的,还是在连接到同一资源时使用两个单独的访问级别时会出现某种断开连接?
我的代码连接到如下所示的 SQS 时没有遇到任何错误,但是我想确保我不会通过任意选择相同 aws 连接的客户端/资源来确保自己不会陷入困境。
import boto3
REGION = 'us-east-1'
sqs_r = boto3.resource('sqs', REGION)
sqs_c = boto3.client('sqs', REGION)
def create_queue(queue_name):
queue_attributes = {
'FifoQueue': 'true',
'DelaySeconds': '0',
'MessageRetentionPeriod': '900', # 15 minutes to complete a command, else deleted.
'ContentBasedDeduplication': 'true'
}
try:
queue = sqs_r.get_queue_by_name(QueueName=queue_name)
except:
queue = sqs_r.create_queue(QueueName=queue_name, Attributes=queue_attributes)
def list_all_queues(queue_name_prefix=''):
all_queues = sqs_c.list_queues(QueueNamePrefix=queue_name_prefix)
print(all_queues['QueueUrls'])
print(type(all_queues))
上述两个函数都可以正常工作,一个创建一个队列,另一个列出 sqs 的所有队列。但是,一个函数使用资源,而另一个函数使用客户端。这个可以吗?
解决方案
您当然可以同时使用两者。
资源方法实际上在幕后使用了客户端方法,因此 AWS 只看到类似客户端的调用。
事实上,资源甚至包含一个客户端。您可以像这样访问它:
import boto3
s3 = boto3.resource('s3')
copy_source = {
'Bucket': 'mybucket',
'Key': 'mykey'
}
s3.meta.client.copy(copy_source, 'otherbucket', 'otherkey')
此示例来自 boto3 文档。它显示了如何client
从 a 中提取 aresource
并进行client
调用,实际上与s3_client.copy()
.
客户端和资源都只是创建一个本地对象。不涉及后端活动。
推荐阅读
- java - 如何使用 Spring 事务管理将当前用户更新到数据库?
- reactjs - 为什么我的反应数据表同时呈现所有数据搜索栏也不起作用?
- typescript - 使用泛型函数中的参数类型创建一个新实例
- javascript - 总结nodejs上http回报的最佳方式
- c# - LINQ to SQL 和 LINQ to Entity Join 与静态 AND 条件
- python-3.x - gColab 如何访问 gDrive 目录(不是文件)
- vb.net - 如何让加载项相互通信?
- javascript - 如何使用 AJAX 和 jQuery 高效显示数组元素
- sql - 来自结果集的每一行的 UNION ALL
- php - 如何在 Laravel 5.x 中选择性地向电子邮件标题添加文本?