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

相关内容

热门资讯

澳大利亚西部一地圣诞节当天发生... 【环球网报道】据澳大利亚广播公司(ABC)、澳大利亚新闻网等媒体报道,澳大利亚西部博丁顿地区圣诞节当...
玩家最新攻略“阳光巴厘岛怎么开... 网上科普关于“阳光巴厘岛有没有挂”话题很是火热,小编也是针对阳光巴厘岛作*弊开挂的方法以及开挂对应的...
玩家分享攻略“衢州都莱是不是有... 网上科普关于“衢州都莱有没有挂”话题很是火热,小编也是针对衢州都莱作*弊开挂的方法以及开挂对应的知识...
玩家攻略科普“人民棋牌到底有挂... 有 亲,根据资深记者爆料人民棋牌是可以开挂的,确实有挂(咨询软件无需打开...
终于明白“棋乐碰胡是不是有挂?... 您好:棋乐碰胡这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏...
珠海科技产业集团“陆海空”齐发... 创新篇 推动8家投资企业成功上市,全力打造国家级RISC-V生态创新中心,吸引智元机器人、智谱华章等...
我来教教您“新众亿牛牛可以开挂... 有 亲,根据资深记者爆料新众亿牛牛是可以开挂的,确实有挂(咨询软件无需打...
终于懂了“湘乐究竟有挂吗?”(... 终于懂了“湘乐究竟有挂吗?”(确实真的有挂)您好,湘乐这个游戏其实有挂的,确实是有挂的,需要了解加客...
玩家最新攻略“杭麻圈怎么装挂?... 有 亲,根据资深记者爆料杭麻圈是可以开挂的,确实有挂(咨询软件无需打开直...
【第一资讯】“北部麻将怎么装挂... 家人们!今天小编来为大家解答北部麻将透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买很...