English 中文(简体)
Bto3在资源、客户和届会之间的差别?
原标题:Difference in Boto3 between resource, client, and session?
  • 时间:2017-03-15 11:57:32
  •  标签:
  • python
  • boto3

I m learning how to use AWS SDK for Python (Boto3) from the following resource:
https://boto3.readthedocs.io/en/latest/guide/quickstart.html#using-boto-3.

我怀疑何时使用<代码>资源、<代码>client或session及其各自的功能。


I 正在Utu 16.04 LTS使用2.7.12。

最佳回答

<>Client和Resource是作为AWS服务请求在Boto3 SDK内部的两个不同的摘要。 如果你想向AWS服务提供boto3,那么你通过客户或资源这样做。

你通常选择使用客户摘要或资源摘要,但可以视需要使用这两种方法。 我概述了以下差异,以帮助读者决定哪些用途。

<>>>基本上与客户和资源概念有关(但两者都使用)。

这里有更详细的资料,说明:,,https://boto3.amazonaws.com/v1/documentation/api/latest/guide/resources.html” rel=“nofollow norerelferer”>Resource,


Client

在客户一级接触S3bucket物体的例子中:

import boto3

client = boto3.client( s3 )

response = client.list_objects_v2(Bucket= mybucket )

for content in response[ Contents ]:
    obj_dict = client.get_object(Bucket= mybucket , Key=content[ Key ])
    print(content[ Key ], obj_dict[ LastModified ])

<>说明:这一客户级代码限于在最多1,000个物体上列名。 您必须使用paginator ,或执行自己的座右铭:-objects_v2(),若有1,000多个物体,则再用连续标记。

缩略语 现在进入较高层次(更抽象)资源接口。


Resource

  • this is the newer boto3 API abstraction
  • it provides a high-level, object-oriented API
  • it does not provide 100% API coverage of AWS services
  • it uses identifiers and attributes
  • it has actions (operations on resources)
  • it exposes sub-resources and collections of AWS resources
  • typically yields marshalled data, not primitive AWS data (e.g. DynamoDB attributes are native Python values representing primitive DynamoDB values)
  • does result pagination for you
  • it is generated from an AWS resource description

资源水平获取S3bucket物体:

import boto3

s3 = boto3.resource( s3 )

bucket = s3.Bucket( mybucket )

for obj in bucket.objects.all():
    print(obj.key, obj.last_modified)

注:在这种情况下,你不必再发出第二次APIC号通知,以获取物体;它们作为 collection子的收集材料重新提供给你。 这些次资源的收集工作用得很满。

你们可以看到,《守则》的<代码>Resource版本更为简单、更精干,而且具有更大的能力(例如,它给你带来了想象力,它暴露了财产而不是原始字典)。 如果你想包括图谋,那么该守则的<编码>Client文本实际上会比上所示更为复杂。

最后,会议对于客户和资源以及两者如何获得社保证书都至关重要。


Session

  • stores configuration information (primarily credentials and selected region)
  • allows you to create service clients and resources
  • boto3 creates a default session for you when needed

A useful resource to learn more about these boto3 concepts is the introductory re:Invent video.


Update January 2023

Per the Resources page in the boto3 documentation:

AWSpill SDK小组不打算在boto3资源接口中增加新的特征。 现有的接口将继续在生物周期中运行。 客户可以通过客户接口找到新的服务功能。

可在boto3/discussions/3563上读更多关于资源分配的计划。

问题回答

我尝试并尽可能简单地加以解释。 因此,无法保证实际术语的准确性。


<>Session 系指与AWS服务建立联系的地点。 例如,以下是采用缺省成像特征的缺席会议(例如:~/.aws/credentials,或根据IAM案例简介假设EC2)。

sqs = boto3.client( sqs )
s3 = boto3.resource( s3 )

由于缺席会议仅限于所采用的简介或案例简介,有时你需要利用习俗会议来推翻缺席会议组合(例如,区域——名称、终点——等等)。 e.g.

# custom resource session must use boto3.Session to do the override
my_west_session = boto3.Session(region_name =  us-west-2 )
my_east_session = boto3.Session(region_name =  us-east-1 )
backup_s3 = my_west_session.resource( s3 )
video_s3 = my_east_session.resource( s3 )

# you have two choices of create custom client session. 
backup_s3c = my_west_session.client( s3 )
video_s3c = boto3.client("s3", region_name =  us-east-1 )

Resource : This is the high-level service class recommended to be used. This allows you to tied particular AWS resources and passes it along, so you just use this abstraction than worry which target services are pointed to. As you notice from the session part, if you have a custom session, you just pass this abstract object than worrying about all custom regions,etc to pass along. Following is a complicated example E.g.

import boto3 
my_west_session = boto3.Session(region_name =  us-west-2 )
my_east_session = boto3.Session(region_name =  us-east-1 )
backup_s3 = my_west_session.resource("s3")
video_s3 = my_east_session.resource("s3")
backup_bucket = backup_s3.Bucket( backupbucket ) 
video_bucket = video_s3.Bucket( videobucket )

# just pass the instantiated bucket object
def list_bucket_contents(bucket):
   for object in bucket.objects.all():
      print(object.key)

list_bucket_contents(backup_bucket)
list_bucket_contents(video_bucket)

<Client 是低级物体。 对于每个客户的要求,你需要明确指明目标资源,指定服务对象的名字必须很长。 你们将失去抽象的能力。

例如,如果你只处理拖欠会议,则与资源相似。

import boto3 
s3 = boto3.client( s3 )

def list_bucket_contents(bucket_name):
   for object in s3.list_objects_v2(Bucket=bucket_name) :
      print(object.key)

list_bucket_contents( Mybucket ) 

然而,如果你想要从不同区域的桶子中排出物体,那么你需要具体说明客户所需的明确桶价。

import boto3 
backup_s3 = my_west_session.client( s3 ,region_name =  us-west-2 )
video_s3 = my_east_session.client( s3 ,region_name =  us-east-1 )

# you must pass boto3.Session.client and the bucket name 
def list_bucket_contents(s3session, bucket_name):
   response = s3session.list_objects_v2(Bucket=bucket_name)
   if  Contents  in response:
     for obj in response[ Contents ]:
        print(obj[ key ])

list_bucket_contents(backup_s3,  backupbucket )
list_bucket_contents(video_s3 ,  videobucket ) 




相关问题
Can Django models use MySQL functions?

Is there a way to force Django models to pass a field to a MySQL function every time the model data is read or loaded? To clarify what I mean in SQL, I want the Django model to produce something like ...

An enterprise scheduler for python (like quartz)

I am looking for an enterprise tasks scheduler for python, like quartz is for Java. Requirements: Persistent: if the process restarts or the machine restarts, then all the jobs must stay there and ...

How to remove unique, then duplicate dictionaries in a list?

Given the following list that contains some duplicate and some unique dictionaries, what is the best method to remove unique dictionaries first, then reduce the duplicate dictionaries to single ...

What is suggested seed value to use with random.seed()?

Simple enough question: I m using python random module to generate random integers. I want to know what is the suggested value to use with the random.seed() function? Currently I am letting this ...

How can I make the PyDev editor selectively ignore errors?

I m using PyDev under Eclipse to write some Jython code. I ve got numerous instances where I need to do something like this: import com.work.project.component.client.Interface.ISubInterface as ...

How do I profile `paster serve` s startup time?

Python s paster serve app.ini is taking longer than I would like to be ready for the first request. I know how to profile requests with middleware, but how do I profile the initialization time? I ...

Pragmatically adding give-aways/freebies to an online store

Our business currently has an online store and recently we ve been offering free specials to our customers. Right now, we simply display the special and give the buyer a notice stating we will add the ...

Converting Dictionary to List? [duplicate]

I m trying to convert a Python dictionary into a Python list, in order to perform some calculations. #My dictionary dict = {} dict[ Capital ]="London" dict[ Food ]="Fish&Chips" dict[ 2012 ]="...