aws(学习笔记第三十二课) 深入使用cdk(API Gateway + event bridge)

server/2025/3/10 18:11:32/

文章目录

  • aws(学习笔记第三十二课) 深入使用cdk
  • 学习内容:
    • 1. 使用`aws API Gateway`+`lambda`
      • 1.1. 以前的练习
      • 1.2. 使用`cdk`创建`API Gateway` + `lambda`
      • 1.3. 确认`cdk`创建`API Gateway` + `lambda`
    • 2. 使用`event bridge`练习`producer`和`consumer`
      • 2.1. 代码链接
      • 2.2. 开始练习
      • 2.3. 代码部署的确认
      • 2.4. 对部署进行测试

aws_cdk_1">aws(学习笔记第三十二课) 深入使用cdk

  • 使用cdk生成aws API Gateway+lambda以及eventbridge等等

学习内容:

  • 使用aws API Gateway+lambda
  • 使用event bridge练习producerconsumer

aws_API_Gatewaylambda_7">1. 使用aws API Gateway+lambda

1.1. 以前的练习

  • 以前的例子
    API Gateway + lambda这个例子中已经使用了手动创建,使用练习了aws API Gateway+lambda
  • 使用cdk来创建
    这里,采用cdk的方式来创建API Gateway + lambda
    代码链接 api-cors-lambda

1.2. 使用cdk创建API Gateway + lambda

  • 整体架构
    在这里插入图片描述
  • 代码解析
    • 创建lambda函数
      	   base_lambda = _lambda.Function(self, 'ApiCorsLambda',handler='lambda-handler.handler',runtime=_lambda.Runtime.PYTHON_3_12,code=_lambda.Code.from_asset('lambda'))
      
      注意,这里没有创建VPC,因为这里不需要显示的创建VPC
      在这里插入图片描述
      • 创建API并且添加resource

                base_api = _apigw.RestApi(self, 'ApiGatewayWithCors',rest_api_name='ApiGatewayWithCors')example_entity = base_api.root.add_resource('example',default_cors_preflight_options=_apigw.CorsOptions(allow_methods=['GET', 'OPTIONS'],allow_origins=_apigw.Cors.ALL_ORIGINS)
        

        在这里插入图片描述

      • 创建LambdaIntegrationAPIlambda进行绑定

              example_entity_lambda_integration = _apigw.LambdaIntegration(base_lambda,proxy=False,integration_responses=[_apigw.IntegrationResponse(status_code="200",response_parameters={'method.response.header.Access-Control-Allow-Origin': "'*'"})])
        

        在这里插入图片描述

      • API加入method

              example_entity.add_method('GET', example_entity_lambda_integration,method_responses=[_apigw.MethodResponse(status_code="200",response_parameters={'method.response.header.Access-Control-Allow-Origin': True})])
        

        在这里插入图片描述

1.3. 确认cdk创建API Gateway + lambda

  • 执行创建的cdk
    	cdk --require-approval never deploy
    
  • 查看创建的结果
    • lambda创建结果
      在这里插入图片描述

    • API创建结果
      在这里插入图片描述

    • 确认API的调用URL
      在这里插入图片描述

    • 访问API的调用URL
      之后不要忘记cdk destroy
      在这里插入图片描述

2. 使用event bridge练习producerconsumer

2.1. 代码链接

api-eventbridge-lambda的代码链接
这里主要练习使用eventbridge,进行producerconsumer的练习。

2.2. 开始练习

  • 整体架构
    在这里插入图片描述
  • 代码解析
    • 生成producer

      			        ## Producer Lambda#event_producer_lambda = _lambda.Function(self, "eventProducerLambda",runtime=_lambda.Runtime.PYTHON_3_12,handler="event_producer_lambda.lambda_handler",code=_lambda.Code.from_asset("lambda"))event_policy = iam.PolicyStatement(effect=iam.Effect.ALLOW, resources=['*'], actions=['events:PutEvents'])event_producer_lambda.add_to_role_policy(event_policy)
      

      这里,producer被赋予权限putEvents,因为之后要向eventbridge进行putEvents操作。
      在这里插入图片描述

    • producer的处理代码

      	def lambda_handler(event, context):eventbridge_client = boto3.client('events')request_body = event["body"]if request_body is None:request_body = ""# Structure of EventBridge Eventeventbridge_event = {'Time': datetime.datetime.now(),'Source': 'com.mycompany.myapp','Detail': request_body,'DetailType': 'service_status'}logger.info(eventbridge_event)# Send event to EventBridgeresponse = eventbridge_client.put_events(Entries=[eventbridge_event])logger.info(response)# Returns success reponse to API Gatewayreturn {"statusCode": 200,"body": json.dumps({"result": "from Producer"}),}
      

      这里,使用了boto3这个python package,AWS ‌Boto3‌ 是亚马逊云服务(AWS)官方提供的 Python SDK,主要用于通过代码与 AWS 服务进行交互和管理。这里使用boto3eventbridge进行putEvents

    • consumer1consumer2

      			        ## Approved Consumer1#event_consumer1_lambda = _lambda.Function(self, "eventConsumer1Lambda",runtime=_lambda.Runtime.PYTHON_3_8,handler="event_consumer_lambda.lambda_handler",code=_lambda.Code.from_asset("lambda"))event_consumer1_rule = events.Rule(self, 'eventConsumer1LambdaRule',description='Approved Transactions',event_pattern=events.EventPattern(source=['com.mycompany.myapp']))event_consumer1_rule.add_target(targets.LambdaFunction(handler=event_consumer1_lambda))## Approved Consumer2#event_consumer2_lambda = _lambda.Function(self, "eventConsumer2Lambda",runtime=_lambda.Runtime.PYTHON_3_8,handler="event_consumer_lambda.lambda_handler",code=_lambda.Code.from_asset("lambda"))event_consumer2_rule = events.Rule(self, 'eventConsumer2LambdaRule',description='Approved Transactions',event_pattern=events.EventPattern(source=['com.mycompany.myapp']))event_consumer2_rule.add_target(targets.LambdaFunction(handler=event_consumer2_lambda))
      

      consumer1consumer2类似,就是接受到了eventbridgeevent之后,进行log输出。

      			def lambda_handler(event, context):logger.info(event)return {"statusCode": 200,"body": json.dumps({"result": "testing..."}),}
      

      在这里插入图片描述

    • consumer3使用kinesisfirehoseevent进行接受,并保存到S3 bucket

      	        ## Approved Consumer3## Create S3 bucket for KinesisFirehose destinationingest_bucket = s3.Bucket(self, 'test-ngest-bucket')# Create a Role for KinesisFirehosefirehose_role = iam.Role(self, 'myRole',assumed_by=iam.ServicePrincipal('firehose.amazonaws.com'))# Create and attach policy that gives permissions to write in to the S3 bucket.iam.Policy(self, 's3_attr',policy_name='s3kinesis',statements=[iam.PolicyStatement(actions=['s3:*'],resources=['arn:aws:s3:::' + ingest_bucket.bucket_name + '/*'])],# resources=['*'])],roles=[firehose_role],)event_consumer3_kinesisfirehose = _firehose.CfnDeliveryStream(self, "consumer3-firehose",s3_destination_configuration=_firehose.CfnDeliveryStream.S3DestinationConfigurationProperty(bucket_arn=ingest_bucket.bucket_arn,buffering_hints=_firehose.CfnDeliveryStream.BufferingHintsProperty(interval_in_seconds=60),compression_format="UNCOMPRESSED",role_arn=firehose_role.role_arn))event_consumer3_rule = events.Rule(self, 'eventConsumer3KinesisRule',description='Approved Transactions',event_pattern=events.EventPattern(source=['com.mycompany.myapp']))event_consumer3_rule.add_target(targets.KinesisFirehoseStream(stream=event_consumer3_kinesisfirehose))
      

      在这里插入图片描述

    • producer通过API Gateway进行公开

      	        # defines an API Gateway REST API resource backed by our "atm_producer_lambda" function.api = api_gw.LambdaRestApi(self, 'SampleAPI-EventBridge-Multi-Consumer',handler=event_producer_lambda,proxy=False)items = api.root.add_resource("items")items.add_method("POST")  # POST /items
      

2.3. 代码部署的确认

接下来进行cdk deploy来确认执行效果。

  • 一个producer与两个consumer,都是lambda
    在这里插入图片描述
  • 第三个consumer,一个kinesisFireHose
    在这里插入图片描述
  • APIproducer
    在这里插入图片描述

2.4. 对部署进行测试

  • API进行测试调用
    返回了正常的结果。这里,需要对请求正文request body一定要设定参数这里设置如下。
    {"item1":"123","item2":"234"}
    
    使用API调用,之后启动producerlamdba,向eventbridge进行putEvents
    在这里插入图片描述
  • consumer1consumer2进行确认
    在这里插入图片描述
  • consumer3进行确认
    这里主要是对S3 bucket进行确认。可以看到,
    producer -> event -> eventbridge -> consumer3 -> kinesis firehose -> S3 bucket
    最后cdk destroy

在这里插入图片描述


http://www.ppmy.cn/server/173993.html

相关文章

react拖曳组件react-dnd的简单封装使用

分享原因 由于项目中需要使用拖曳组件(需求:全局,跨组件,跨数据),我选择了react-dnd 概念 React DnD 是一组 React 高阶组件,我们在使用的时候只需要将目标元素进行包裹,就可以实现目标元素具有拖动或接受拖动的功能。…

MYSQL之创建数据库和表

创建数据库db_ck (下面的创建是最好的创建方法,如果数据库存在也不会报错,并且指定使用utf8mb4) show databases命令可以查看所有的数据库名,可以找到刚刚创建的db_ck数据库 使用该数据库时,发现里面没有…

C/C++基础知识复习(50)

1. ​如何处理对象的状态变化? 状态模式是一种行为设计模式,允许对象在其内部状态改变时改变其行为。 通俗解释: 对象的状态就是它的“心情”或“模式”,比如灯的开关状态。 例子: 一个电灯有“开”和“关”两种状…

python文本处理pdfminer库安装与使用

为了安装并使用pdfminer库来处理PDF文件,你需要先确保已经安装了这个库。pdfminer是一个可以从PDF文档中提取信息的工具包。在Python 3.9.7环境下,你可以通过pip来安装它。 安装 打开命令行工具(终端或命令提示符),然…

DeepStream推理dewarped所有surfaces

原视频\opt\nvidia\deepstream\deepstream\samples\streams\sample_cam6.mp4如上图所示,是一个360度的球型视频,DeepStream的nvdewarper插件可以将原视频拆分成多个单独的视频,nvdewarper可以生成最大4个dewarped surfaces. \opt\nvidia\dee…

Android中的Loader机制

Android中的Loader机制是在Android 3.0版本之后引入的一种异步加载数据的方法。以下是对Android中Loader机制的详细解释: 一、Loader机制的基本概念 Loader是Android提供的一种异步加载数据的机制,它可以在后台线程中执行耗时操作,并在加载…

高效编程指南:PyCharm与DeepSeek的完美结合

DeepSeek接入Pycharm 前几天DeepSeek的充值窗口又悄悄的开放了,这也就意味着我们又可以丝滑的使用DeepSeek的API进行各种辅助性工作了。本文我们来聊聊如何在代码编辑器中使用DeepSeek自动生成代码。 注:本文适用于所有的JetBrains开发工具&#xff0c…

软件测试基础:功能测试知识总结

🍅 点击文末小卡片 ,免费获取软件测试全套资料,资料在手,涨薪更快 一、测试项目启动与研读需求文档 (一) 组建测试团队 1、测试团队中的角色 2、测试团队的基本责任 尽早地发现软件程序、系统或产品中…