[英]Best way to convert cloudformation serverless template into Terraform
I'm trying to convert a serverless framework
YML file into a Terraform script.我正在尝试将serverless framework
YML 文件转换为 Terraform 脚本。
It's my first time with terraform
and I don't have much experience with infra either.这是我第一次使用terraform
,我对基础设施也没有太多经验。
I'm getting some errors with my Terraform but my question is more about my approach.我的 Terraform 出现了一些错误,但我的问题更多是关于我的方法。
Is there a better/simpler/smarter way to write the same serverless yml in Terraform ?是否有更好/更简单/更智能的方法在 Terraform 中编写相同的无服务器 yml?
Maybe modules out there which would make my life easier.也许那里的模块会让我的生活更轻松。
Terraform地形
# Lambda invoke function role data
data "aws_iam_policy_document" "lambda_invoke_function_role" {
version = "2012-10-17"
statement {
sid = ""
effect = "Allow"
actions = ["sts:AssumeRole"]
principals {
service = "lambda.amazonaws.com"
}
}
}
# Lambda ec2
data "aws_iam_policy_document" "ec2_lambda_policies_role" {
version = "2012-10-17"
statement {
sid = ""
effect = "Allow"
actions = [
"ec2:CreateNetworkInterface",
"ec2:DescribeNetworkInterfaces",
"ec2:DetachNetworkInterface",
"ec2:DeleteNetworkInterface"
]
resources = "*"
}
}
# Lambda allow invoke
data "aws_iam_policy_document" "allow_invoke_role" {
version = "2012-10-17"
statement {
sid = ""
effect = "Allow"
actions = [
"lambda:InvokeFunction"
]
resources = "*"
}
}
# Lambda invoke function role
resource "aws_iam_role" "lambda_invoke_function_role" {
name = "lambdaRole"
assume_role_policy = "${data.aws_iam_policy_document.lambda_invoke_function_role.json}"
}
# EC2 ##############################################################################
resource "aws_iam_policy" "ec2_lambda_policies_policy" {
name = "ec2LambdaPolicy"
assume_role_policy = "${data.aws_iam_policy_document.ec2_lambda_policies_role.json}"
}
resource "aws_iam_role_policy_attachment" "ec2_lambda_policies_policy_attachment" {
role = "${aws_iam_role.lambda_invoke_function_role.name}"
policy_arn = "${aws_iam_policy.ec2_lambda_policies_policy.arn}"
}
###############################################################################
# Allow Invoke #####################################################################
resource "aws_iam_policy" "allow_invoke_policy" {
name = "allowInvokePolicy"
assume_role_policy = "${data.aws_iam_policy_document.allow_invoke_role.json}"
}
resource "aws_iam_role_policy_attachment" "allow_invoke_policy_attachment" {
role = "${aws_iam_role.lambda_invoke_function_role.name}"
policy_arn = "${aws_iam_policy.allow_invoke_policy.arn}"
}
###############################################################################
# Lambda invoke function role policy attachment
resource "aws_iam_role_policy_attachment" "aws_lambda_basic_execution_role" {
role = "${aws_iam_role.lambda_invoke_function_role.name}"
policy_arn = "arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
}
# Lambda invoke function role policy attachment
resource "aws_iam_role_policy_attachment" "aws_lambda_vpc_access_execution_role" {
role = "${aws_iam_role.lambda_invoke_function_role.name}"
policy_arn = "arn:aws:iam::aws:policy/service-role/AWSLambdaVPCAccessExecutionRole"
}
Serverless YML (cloudformation)无服务器 YML(云形成)
LambdaRole:
Type: AWS::IAM::Role
Properties:
Path: '/'
RoleName: LambdaRole
AssumeRolePolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: Allow
Principal:
Service:
- lambda.amazonaws.com
Action: sts:AssumeRole
Policies:
- PolicyName: ec2LambdaPolicies
PolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: Allow
Action:
- ec2:CreateNetworkInterface
- ec2:DescribeNetworkInterfaces
- ec2:DetachNetworkInterface
- ec2:DeleteNetworkInterface
Resource: "*"
- PolicyName: 'AllowInvoke'
PolicyDocument:
Version: '2012-10-17'
Statement:
- Effect: 'Allow'
Action: 'lambda:InvokeFunction'
Resource: '*'
ManagedPolicyArns:
- arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole
- arn:aws:iam::aws:policy/service-role/AWSLambdaVPCAccessExecutionRole
You may want to take a look at cf-to-tf which will convert cloudformation into terraform.您可能想看看cf-to-tf ,它将云形成转换为 terraform。
cf-to-tf --stack foobarbaz config | json2hcl | cf-to-tf clean-hcl | terraform fmt -
That will import your stack foobarbaz
from AWS and convert it into terraform and print it to stdout.这将从 AWS 导入您的堆栈foobarbaz
并将其转换为 terraform 并将其打印到标准输出。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.