AWS Lambda 自动化和 Python - 自动创建S3 Bucket lifecycle
admin
2023-03-28 11:01:28
0

最近经常需要创建一些S3 Bucket用于备份。每个新建的Bucket都应该配置lifecycle,自动删除旧的数据,以便节约空间和开支。

豆子写了一个简单的Lambda函数来自动实现。每次当我们创建一个Bucket的时候,他会调用对应的API,Cloudtrail监测到这个事件后,会发送给Cloudwatch, 然后Cloudwatch会自动调用我的函数来创建lifecycle policy。

下面是简单的截图说明。

创建一个新的Cloudwatch Rule

AWS Lambda 自动化和 Python - 自动创建S3 Bucket lifecycle

对应的Lambda函数

AWS Lambda 自动化和 Python - 自动创建S3 Bucket lifecycle

他默认的IAM已经有权限访问Cloudwatch, 我新建了一个S3的Policy,然后分配给他的IAM role,这样这个lambda函数可以访问Cloudwatch和S3 的权限。

AWS Lambda 自动化和 Python - 自动创建S3 Bucket lifecycle

下面是Python代码


import logging
import boto3
from botocore.exceptions import ClientError

lifecycle_config_settings = {
    'Rules': [
        {'ID': 'Delete Rule',
         'Filter': {'Prefix': ''},
         'Status': 'Enabled',
         'Expiration': { 'Days':100 }}
    ]}

def put_bucket_lifecycle_configuration(bucket_name, lifecycle_config):
    """Set the lifecycle configuration of an Amazon S3 bucket

    :param bucket_name: string
    :param lifecycle_config: dict of lifecycle configuration settings
    :return: True if lifecycle configuration was set, otherwise False
    """

    # Set the configuration
    s3 = boto3.client('s3')
    try:
        s3.put_bucket_lifecycle_configuration(Bucket=bucket_name,
                                              LifecycleConfiguration=lifecycle_config)
    except ClientError as e:

        return False
    return True

def lambda_handler111(event, context):
    # TODO implement
    test_bucket_name = event.get('detail').get('requestParameters').get('bucketName')
    print(event)
    print(event.get('detail').get('requestParameters').get('bucketName'))

    success = put_bucket_lifecycle_configuration(test_bucket_name,lifecycle_config_settings)

    if success:
    #  logging.info('The lifecycle configuration was set for {test_bucket_name}')
        print('The lifecycle configuration was set for {test_bucket_name}')

实际运行的效果,但我创建了一个新的Bucket的时候,他会自动调用这个函数,添加policy。

下面是Cloudwatch的日志

AWS Lambda 自动化和 Python - 自动创建S3 Bucket lifecycle

这个是新建的Bucket的lifecycle policy

AWS Lambda 自动化和 Python - 自动创建S3 Bucket lifecycle

相关内容

热门资讯

为什么美国社会这么相信有外星人... 【文/观察者网专栏作者 白玉京】2026年5月8日,美国国防部一次性释放了约160份与“不明异常现象...
巴基斯坦自杀式爆炸袭击致至少1... 【环球网报道 记者 张江平】综合巴基斯坦联合通讯社、《黎明报》等媒体10日报道,对于巴基斯坦开伯尔-...
美伊谈判陷入僵局,内塔尼亚胡:... 美伊谈判陷入僵局,美国总统特朗普5月10日表示对伊朗的回复十分不满。与此同时,以色列总理内塔尼亚胡暗...
干部明知对方是间谍,还提供22... 一个看似普通的职业社交网络平台,一份令人心动的“课题撰稿”邀请,一笔笔不断加码的“丰厚稿费”……这看...
空调挂机插头安装方法 安装空调挂机插头并不是一项难以完成的任务,我们需要先了解一下安装步骤和需要的材料和工具。下面就来详细...
客厅安装中央空调好吗 在如今的生活中,中央空调已经成为一种常见的家居设备。由于中央空调具有美观、安全、高效、舒适等特点,因...
手机进水放在大米里面真的有用吗 将进水的手机放在大米里是一种常见的应急处理方法,但它并不能保证完全解决问题。大米具有一定的吸水性,可...
光触媒与二氧化氯除甲醛那个比较... 最佳回答 08年前,除甲醛的二氧化氯,但常用的行业,因为两污染,08年后,随着催化剂的发明,纳米二...
广东星艺装饰怎么样? 最佳回答 广东星艺装饰有限公司是一家非常不错的有限公司哦。这家装饰有限公司所做的业务还是比较全面的,...
天舟十号货运飞船点火发射 今天上午,搭载天舟十号货运飞船的长征七号遥十一运载火箭,在我国文昌航天发射场点火发射。