Boto - python lib for AWS

Boto 是用 python 封装的一个操作 AWS 的函数库。用过几种语言操作 AWS 还是感觉 python 用起来最直观简洁。下面就对 boto 的使用进行一个简单总结,方便以后查阅(只涉及当前使用到的服务,以后会持续更新)。对 python 2 和 python 3 都有相应的 boto 库。这里以 python 2.7 为例进行说明。

EC2

S3


创建S3连接

  • 根据指定key和区域进行连接

    conn = boto.s3.connect_to_region(region, aws_access_key_id=accessKey, aws_secret_access_key=secretKey)

    Note:如果基于Role创建连接的话可以省略key。

bucket 相关

  • 查看指定 bucket 是否存在
    conn.lookup(bucketname)
    不存在则返回 None。

  • 创建bucket
    conn.create_bucket(bucket_name, None, self.__region, None)

  • 获取所有 bucket
    conn.get_all_buckets()

  • 获取指定 bucket
    bucket = conn.get_bucket(bucketname)

  • 获取 bucket Key
    key = bucket.get_key(keyname)

  • 列出指定bucket下某一前缀的所有对象
    bucket.list(prefix=prefix)

  • 配置 bucket 生命周期

        toglacier = Transition(days=days, storage_class='GLACIER')
         rule = Rule(ruleid, prefix, 'Enabled', transition=toglacier)
         lifecycle = Lifecycle()
         lifecycle.append(rule)
         bucket = self.__conn.get_bucket(bucketname)
         return bucket.configure_lifecycle(lifecycle)
  • 查看 bucket 生命周期配置
    for i in bucket.get_lifecycle_config():
        l.append(i.transition)

Object 相关

  • 从本地路径上传文件
    key.set_contents_from_filename(srcname)

  • 分片上传文件

        sourcesize = os.stat(srcname).st_size
          bucket = self.__conn.get_bucket(bucketname)

          mp = bucket.initiate_multipart_upload(keyname)
          chunkcount = int(math.ceil(sourcesize / float(chunksize)))
          for i in range(chunkcount):
              offset = chunksize * i
              bs = min(chunksize, sourcesize - offset)
              with FileChunkIO(srcname, 'r', offset=offset, bytes=bs) as fp:
                  mp.upload_part_from_file(fp, part_num=i + 1)

          return mp.complete_upload()
  • 下载对象到本地文件
    key.get_contents_to_filename(dstname)

  • 删除对象
    bucket.delete_key(keyname)

  • 批量删除对象
    bucket.delete_keys([key1,key2,...])

  • 查看分片上传情况
    bucket.list_multipart_uploads()

  • 从Glacier还原对象
    key.restore(days=retainday)

  • 查看对象还原状态
    key.ongoing_restore

Glacier

创建Glacier连接

  • 根据指定key和区域进行连接
    conn = boto.glacier.connect_to_region(region, aws_access_key_id=accessKey, aws_secret_access_key=secretKey)

vault相关

  • 查看所有vault
    conn.list_vaults()

  • 获取指定vault
    vault = conn.get_vault(vaultname)

  • 上传文件到vault
    vault.upload_archive(filename=filename)
    上传完成后会返回响应的archieveid。

  • 从vault中指定归档文件从离线还原到在线
    vault.retrieve_archive(archieveid)
    还原任务提交后会生成一个 jobid。

  • 获取指定vault下的还原任务
    vault.list_jobs(True|False) 或者 conn.list_all_jobs(vaultname, True|False)
    `

  • 下载vault中文件到本地
    vault.get_job(jobid).download_to_file(dstfile)

object相关

SQS

DynamoDB

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值