【Terraform学习】使用 Terraform创建 S3 存储桶事件(Terraform-AWS最佳实战学习)

  本站以分享各种运维经验和运维所需要的技能为主

《python》:python零基础入门学习

《shell》:shell学习

《terraform》持续更新中:terraform_Aws学习零基础入门到最佳实战

《k8》暂未更新

《docker学习》暂未更新

《ceph学习》ceph日常问题解决分享

《日志收集》ELK+各种中间件

《运维日常》持续更新中

下面继续开始我们的terraform的学习,这次是学习创建s3.

使用 Terraform创建 S3 存储桶事件

实验步骤

前提条件

  • 安装 Terraform: 地址

下载仓库代码模版

  • 本实验代码位于 task_sns_s3 文件夹中

  • 变量文件 variables.tf

  • 在上面的代码中,您将声明aws_access_keyaws_secret_key和 区域变量

  • 还声明了电子邮件地址变量

  • terraform.tfvars

  

  • 在上面的代码中,您将定义变量的值

  • main.tf

 

  • 在上面的代码中,您将执行以下任务

    • 创建 Amazon S3 存储桶

    • 由于存储桶名称为全局唯一,因此还创建了一个随机字符串,该字符串将生成并添加到存储桶名称的末尾

    • 创建一个 SNS 主题添加 SNS 主题的访问策略。让您的 SNS 主题有权根据 S3 存储桶事件发送通知

    • 创建 SNS 主题后,让我们创建对该主题的订阅

    • 我们将以电子邮件作为协议创建订阅。

    • 电子邮件终端节点,即电子邮件地址将由您在变量中定义

    • 最后,创建 S3 存储桶事件通知添加 SNS 主题

    • 这样,每当有对象上传到 S3 存储桶时,它都会向订阅 SNS 主题的电子邮件发送事件通知

  • outputs.tf,将输出S3 存储桶名称和 SNS 主题 ARN 


使用 Terraform 部署

  • 确保您这些文件在同一位置

  • 通过运行以下命令初始化 Terraform

    • terraform init

    • 注意:terraform init检查所有插件依赖项下载它们

  • 查看生成计划,请运行以下命令

    • terraform plan

  • 创建在 main.tf 配置文件中声明的所有资源 ,请运行以下命令

    • terraform apply

  • 您将能够看到将要创建的资源,通过输入 yes 批准所有资源的创建

  • terraform apply 命令最多可能需要 2 分钟才能创建资源


检查 AWS 控制台中的资源

  • 确保您位于美国东部(弗吉尼亚北部)us-east-1 区域

  • 通过单击 AWS 控制台顶部导航到 S3

  • 单击您创建的存储桶

  • 切换到属性选项卡并向下滚动查找事件通知选项。 

  

  • 导航到 SNS

  • 您将能够看到我们使用Terraform创建的SNS主题。 

  

  • 单击该主题,在“订阅”选项卡中,您将看到已创建的订阅以及您的电子邮件地址

  • 订阅的状态为“等待确认”

  • 您将收到一封电子邮件,以确认您的 SNS 订阅。如果您在收件箱中没有看到该电子邮件,请检查您的垃圾邮件

 

  • 单击“确认订阅”

 

  • 您的电子邮件地址现已订阅 SNS 主题 my-s3-event-notification

  • 您可以导航到 SNS 主题的订阅选项卡进行确认。刷新页面,订阅状态将显示为“已确认”


将对象上传到 S3 存储桶并测试 SNS 通知

  • 菜单导航到 S3

  • 单击您创建的存储桶

  • 在存储桶中的“对象”下,单击“上传”

  • 现在,单击“添加文件”并从本地系统上传任何文件

  • 文件成功上传到 S3 存储桶后,单击关闭。现在,您可以在“对象”下看到上传的对象文件。

  • 导航到您的电子邮箱检查 SNS 通知。请保持刷新,因为接收通知可能需要一些时间

  • 您已成功收到基于 S3 存储桶中的 PUT 对象事件的 SNS 通知

 

补充: 简易理解-常用的创建s3过程

要使用 Terraform 创建 S3 存储桶事件,您需要使用 Terraform 的 S3 存储桶资源模块和事件通知模块。

以下是一个示例 Terraform 配置文件,用于创建一个名为 "my-bucket" 的 S3 存储桶,并设置其事件通知:


# 定义 AWS provider
provider "aws" {region = "us-east-1"
}# 定义 S3 存储桶
resource "aws_s3_bucket" "my_bucket" {bucket = "my-bucket"acl    = "private"
}# 定义 SNS 主题
resource "aws_sns_topic" "my_topic" {name = "my-topic"
}# 定义 S3 存储桶事件通知
resource "aws_s3_bucket_notification" "bucket_notification" {bucket = "${aws_s3_bucket.my_bucket.id}"lambda_function {lambda_function_arn = "${aws_lambda_function.my_lambda.arn}"events             = ["s3:ObjectCreated:*"]}sns_topic {topic_arn    = "${aws_sns_topic.my_topic.arn}"events       = ["s3:ObjectCreated:*"]}
}

在上面的配置中,我们首先定义了一个名为 "my-bucket" 的 S3 存储桶,并将其 ACL(访问控制列表)设置为 "private"。然后,我们创建了一个名为 "my-topic" 的 SNS 主题。最后,我们使用 aws_s3_bucket_notification 资源模块创建了一个 S3 存储桶事件通知。该通知将 S3 存储桶的 "s3:ObjectCreated:*" 事件路由到两个地方:一个 Lambda 函数和一个 SNS 主题。您可以将这些值替换为您自己的 Lambda 函数和 SNS 主题的 ARN。

要应用此配置并创建 S3 存储桶事件,请在终端中运行以下命令:

terraform apply

这将创建一个名为 "my-bucket" 的 S3 存储桶,并将事件通知配置应用于该存储桶。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/60570.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ATF(TF-A)安全通告 TFV-4 (CVE-2017-9607)

安全之安全(security)博客目录导读 ATF(TF-A)安全通告汇总 目录 一、ATF(TF-A)安全通告 TFV-4 (CVE-2017-9607) 二、CVE-2017-9607 一、ATF(TF-A)安全通告 TFV-4 (CVE-2017-9607) Title 错误的固件更新SMC可能导致在AArch32状态下复制或验证安全内存中的意外数据 CVE ID C…

树多选搜索查询,搜索后选中状态仍保留

<template><div class"half-transfer"><div class"el-transfer-panel"><div><el-checkbox v-model"selectAll" change"handleSelectAll">全部</el-checkbox></div><el-input v-model&qu…

journal日志导致服务器磁盘满

背景 ubuntu 18.04服务器磁盘突然100% 一查/var/log/journal目录占了14G 清理 要清理 journal 日志&#xff0c;可以使用以下步骤&#xff1a; 运行以下命令来查看 journal 日志的使用情况&#xff1a; journalctl --disk-usage这将显示 journal 日志的当前使用情况&#x…

Stable Diffusion 文生图技术原理

图像生成模型简介 图片生成领域来说&#xff0c;有四大主流生成模型&#xff1a;生成对抗模型&#xff08;GAN&#xff09;、变分自动编码器&#xff08;VAE&#xff09;、流模型&#xff08;Flow based Model&#xff09;、扩散模型&#xff08;Diffusion Model&#xff09;。…

SpringBoot与前端交互遇到的一些问题

一、XXX.jar中没有主清单属性 场景&#xff1a; SpringBoot打的jar包在Linux运行报错 解决方案&#xff1a; 百度找了很多都是一样的答案&#xff0c;但是解决不了我的问题&#xff0c;于是我新建了一个springboot项目发现打的jar包可以在Linux上运行。检查了下只要把下面这2个…

保护香港服务器的方法

保护香港服务器的方法 当你把一个香港服务器完全留给一个组织、应用程序或个人使用时&#xff0c;它被称为香港服务器租用。在这种类型的主机配置中&#xff0c;客户端将会借出整个服务器&#xff0c;并且不允许其他任何人使用它。 如果您计划使用香港服务器&#xff0c;安全性…

el-date-picker限制选择的时间范围

<el-date-pickersize"mini"v-model"dateTime"value-format"yyyy-MM-dd HH:mm:ss"type"datetimerange"range-separator"~"start-placeholder"开始日期"end-placeholder"结束日期":picker-options&quo…

[Python从零到壹] 七十.图像识别及经典案例篇之图像特效(怀旧、流年、光照和水波特效)

八月太忙,还是写一篇吧! 欢迎大家来到“Python从零到壹”,在这里我将分享约200篇Python系列文章,带大家一起去学习和玩耍,看看Python这个有趣的世界。所有文章都将结合案例、代码和作者的经验讲解,真心想把自己近十年的编程经验分享给大家,希望对您有所帮助,文章中不足…

非科班菜鸡算法学习记录 | 代码随想录算法训练营第51天||309.最佳买卖股票时机含冷冻期 714.买卖股票的最佳时机含手续费 股票总结

309.最佳买卖股票时机含冷冻期 309. Best Time to Buy and Sell Stock with Cooldown(英文力扣连接) 知识点&#xff1a;动规 状态&#xff1a;看思路ok 思路&#xff1a; 四个状态需要想&#xff0c;持有/不持有且过了冷却期/当天卖/正处于冷却期&#xff1b; 具体看注释…

ESP32-EYE编译笔记

1. 开发板介绍&#xff1a; https://www.espressif.com.cn/zh-hans/products/devkits/esp-eye/overview 2. ESP32-EYE代码库及环境搭建&#xff1a;https://github.com/espressif/esp-who/blob/master/docs/zh_CN/get-started/ESP-EYE_Getting_Started_Guide.md 3. ESP-IDF环…

MySQL事务原理、MVCC详解

事务原理 1 事务基础 1). 事务 事务 是一组操作的集合&#xff0c;它是一个不可分割的工作单位&#xff0c;事务会把所有的操作作为一个整体一起向系 统提交或撤销操作请求&#xff0c;即这些操作要么同时成功&#xff0c;要么同时失败。 2). 特性 原子性&#xff08;Atomi…

为什么mysql source命令导入数据比可视化工具执行sql文件快?

在一般情况下&#xff0c;使用MySQL的source命令导入数据比使用可视化工具执行SQL文件更快&#xff0c;这是因为涉及到了不同的执行方式和优化策略。 批量执行 vs. 逐条执行&#xff1a;source命令会将整个SQL文件作为一个批量进行执行&#xff0c;而可视化工具往往是逐条读取并…

【MySQL】表的增删查改(初阶)

MySQL中表的增删查改&#xff0c;即为CRUD&#xff0c;是增加&#xff08;Create&#xff09;查询&#xff08;Retrieve&#xff09;更新&#xff08;Update&#xff09;删除&#xff08;Delete&#xff09;四个单词首字母的缩写。 目录 1.新增 1.1单行数据全列插入 1.2多行…

LRU和LFU算法的简单实现

LRU #include <iostream> #include <unordered_map> #include <list> struct Node{int key;int value;Node(int key, int value):key(key),value(value){} }; class LruCache{ private:int maxCapacity;// 最大容量std::list<Node>CacheList;// 缓存链…

修改linux中tomcat的端口

随便修改一个 以8055为例子 开放8081端口 firewall-cmd --permanent --add-port8081/tcp firewall-cmd --reload firewall-cmd --list-all

Linux中的dpkg指令(dpkg -l | grep XXX等)

dpkg是Debian包管理系统中的一个工具&#xff0c;用于在Linux系统中安装、升级、删除和管理软件包。它是Debian、Ubuntu以及基于它们的发行版中的包管理器。 dpkg 有很多用法&#xff0c;常用之举例:dpkg -l | grep apt 显示系统中安装的与apt相关&#xff08;命名&#xff09…

Android 蓝牙开发( 二 )

前言 上一篇文章给大家分享了Android蓝牙的基础知识和基础用法&#xff0c;不过上一篇都是一些零散碎片化的程序&#xff0c;这一篇给大家分享Android蓝牙开发实战项目的初步使用 效果演示 : Android蓝牙搜索&#xff0c;配对&#xff0c;连接&#xff0c;通信 Android蓝牙实…

模拟实现应用层协议

模拟实现应用层协议 文章目录 模拟实现应用层协议应用层再谈协议 序列化和反序列化 网络版计算器自定义协议利用Json进行序列化和反序列化json库的安装条件编译 应用层 应用层&#xff08;Application layer&#xff09;是OSI模型的第七层。应用层直接和应用程序接口并提供常见…

在 WSL2 中使用 NVIDIA Docker 进行全栈开发和深度学习 TensorFlow pytorch GPU 加速

在 WSL2 中使用 NVIDIA Docker 进行全栈开发和深度学习 TensorFlow pytorch GPU 加速 0. 背景 0.1 起源 生产环境都是在 k8d pod 中运行&#xff0c;直接在容器中开发不好嘛&#xff1f;每次换电脑&#xff0c;都要配配配&#xff0c;呸呸呸新电脑只安装日常用的软件不好嘛&…

JVM虚拟机篇

JVM虚拟机篇 JVM介绍、运行流程 面试官&#xff1a; JVM由那些部分组成&#xff0c;运行流程是什么&#xff1f; 候选人&#xff1a; 嗯&#xff0c;好的~~ 在JVM中共有四大部分&#xff0c;分别是ClassLoader&#xff08;类加载器&#xff09;、Runtime Data Area&#x…