1

我没有任何选项可以使用 boto3 设置自定义配置文件位置。我可以使用默认位置的凭据。

我的用例是,有不同的 IAM 用户并拥有不同的凭证集,因此每个人都应该能够使用自己的凭证而无需更改默认配置。

有任何想法吗?

4

3 回答 3

1

只需您可以使用python模块configparser

示例将显示检查 RDS 实例的状态并将您的 aws 凭证文件存储在它可以工作的任何地方。

import configparser
import boto3

class CheckStatus():

    rds_instance_name = 'rds_instnace_name'
    aws_config_file = 'aws_config.ini'

    def __init__(self, aws_config):

        self.aws_config = aws_config
        self.client = boto3.client('rds', region_name=self.aws_config['default']['region'],
                                   aws_access_key_id=self.aws_config['default']['aws_access_key_id'],
                                   aws_secret_access_key=self.aws_config['default']['aws_secret_access_key'])

    def check_rds_status(self):
        current_status = None

        response = self.client.describe_db_instances(
            DBInstanceIdentifier=self.rds_instance_name)
        current_status = response['DBInstances'][0]['DBInstanceStatus']
        print(current_status)


def get_config():
    aws_config = configparser.ConfigParser()
    aws_config.read(CheckStatus.aws_config_file)
    return aws_config

obj = CheckStatus(get_config())

obj.check_rds_status()
于 2019-03-27T13:04:10.820 回答
1

这是非常可行的。您可以通过分配一些通过boto3.Session对象传递的关键字参数来实现这一点,例如,

import boto3
session = boto3.Session(
    aws_access_key_id="AAAA",
    aws_secret_access_key="BBBBB",
    region_name="mordor"
)

然后像往常一样使用你的会话对象:

s3_object = session.resource('s3') # or whatever

因此,您需要做的就是用您想要的凭据(从您的自定义配置文件填充)填充一些 python 数据结构,并将它们传递给该boto3.Session对象。

于 2015-11-13T10:00:27.750 回答
1

我相信这会有所帮助: http ://boto.cloudhackers.com/en/latest/boto_config_tut.html#credentials

您可以为不同的用户设置不同的凭据。

于 2016-10-31T06:59:41.107 回答