Python boto3过滤RDS标记

时间:2017-09-26 12:19:54

标签: python amazon-web-services aws-lambda boto3

我创建了一个python脚本来获取我的AWS RDS实例Endpoint。

#!/usr/bin/env python
import boto3`
rds = boto3.client('rds')
try:
# get all of the db instances
    dbs = rds.describe_db_instances()
for db in dbs['DBInstances']:
print ("%s@%s:%s %s") % (
        db['MasterUsername'],
        db['Endpoint']['Address'],
        db['Endpoint']['Port'],
        db['DBInstanceStatus'])
except Exception as error:
print error

它连接到RDS,我看到dbs变量中的数据。

{u'DBInstances': [{u'PubliclyAccessible': False, u'MasterUsername':     'dbadmin', u'MonitoringInterval': 0, u'LicenseModel': 'general-public-license', ...

不幸的是,我收到了错误:

File "rds2.py", line 7
for db in dbs['DBInstances']:
  ^
SyntaxError: invalid syntax`
你告诉我什么错了吗?我的目标是使用TAG(名称= APP1)获取RDS的端点。

感谢。

2 个答案:

答案 0 :(得分:1)

就像helloV指出的那样,你的缩进是不正确的。如果要通过标记查找查找数据库,可能需要使用此选项:

#!/usr/bin/env python
import boto3

rds = boto3.client('rds')
dbs = rds.describe_db_instances()


def get_tags_for_db(db):
    instance_arn = db['DBInstanceArn']
    instance_tags = rds.list_tags_for_resource(ResourceName=instance_arn)
    return instance_tags['TagList']


target_db = None

for db in dbs['DBInstances']:
    print ("%s@%s:%s %s") % (
        db['MasterUsername'],
        db['Endpoint']['Address'],
        db['Endpoint']['Port'],
        db['DBInstanceStatus'])

    db_tags = get_tags_for_db(db)
    tag = next(iter(filter(lambda tag: tag['Key'] == 'Name' and tag['Value'] == 'APP1', db_tags)), None)
    if tag:
        target_db = db
        break

print(target_db)

您要查找的数据库实例将存储为target_db。 有关列出数据库实例的标记的详细信息,请参阅this

答案 1 :(得分:0)

这是你的Python缩进的问题。

import boto3
rds = boto3.client('rds')
try:
# get all of the db instances
    dbs = rds.describe_db_instances()
    for db in dbs['DBInstances']:
        print ("%s@%s:%s %s") % (
            db['MasterUsername'],
            db['Endpoint']['Address'],
            db['Endpoint']['Port'],
            db['DBInstanceStatus'])
except Exception as error:
    print error