AWS中通过Endpoint Security(如Amazon GuardDuty)与安全组、网络ACL联动实现协同防御

设计AWS云架构方案实现基于AWS Endpoint Security(EPS)与AWS服务深度集成,结合AWS CLI或管理控制台,EPS与VPC安全组、网络ACL联动,实现网络层与终端层的协同防御。例如,当EPS检测到某实例被入侵时,可通过API自动调整安全组规则,限制其出站流量,以及具体实现的详细步骤和关键代码。

通过此方案,可实现终端层与网络层的实时联动防御,提升AWS环境的安全性。


架构设计概述

  1. 检测层:使用Amazon GuardDuty监控EC2实例的安全事件。
  2. 事件触发:通过Amazon EventBridge捕获GuardDuty事件并触发Lambda函数。
  3. 响应层:Lambda函数自动修改安全组规则限制受感染实例的出站流量,可选联动网络ACL。
  4. 恢复机制:记录原始安全组配置,支持手动或自动恢复。

详细步骤

1. 启用Amazon GuardDuty
  • 在AWS控制台启用GuardDuty,并配置检测规则(默认已包含常见威胁检测)。

2. 创建EventBridge规则监听GuardDuty事件
  • 规则名称 : guardduty-to-lambda

  • 事件模式 :

    json 复制代码
    {
      "source": ["aws.guardduty"],
      "detail-type": ["GuardDuty Finding"],
      "detail": {
        "severity": [7, 8, 8.9, 9],  // 高严重性事件
        "resource": {"resourceType": ["Instance"]}
      }
    }
  • 目标:选择后续创建的Lambda函数。


3. 创建Lambda函数处理事件
  • Runtime: Python 3.9+

  • IAM角色 :附加以下权限策略:

    json 复制代码
    {
      "Version": "2012-10-17",
      "Statement": [
        {
          "Effect": "Allow",
          "Action": [
            "ec2:CreateSecurityGroup",
            "ec2:AuthorizeSecurityGroupIngress",
            "ec2:RevokeSecurityGroupEgress",
            "ec2:ModifyInstanceAttribute",
            "ec2:DescribeInstances"
          ],
          "Resource": "*"
        }
      ]
    }

4. Lambda函数代码
python 复制代码
import boto3

def lambda_handler(event, context):
    # 解析事件中的实例ID
    instance_id = event['detail']['resource']['instanceDetails']['instanceId']
    ec2 = boto3.resource('ec2')
    instance = ec2.Instance(instance_id)
    
    # 获取实例的私有IP(用于网络ACL可选步骤)
    private_ip = instance.private_ip_address
    
    # 创建隔离安全组,仅允许管理员SSH访问
    ec2_client = boto3.client('ec2')
    isolated_sg = ec2_client.create_security_group(
        GroupName='Isolated_SG',
        Description='Restrict all outbound traffic',
        VpcId=instance.vpc_id
    )
    sg_id = isolated_sg['GroupId']
    
    # 添加入站规则:允许管理员IP访问SSH
    ec2_client.authorize_security_group_ingress(
        GroupId=sg_id,
        IpPermissions=[{
            'IpProtocol': 'tcp',
            'FromPort': 22,
            'ToPort': 22,
            'IpRanges': [{'CidrIp': 'YOUR_ADMIN_IP/32'}]
        }]
    )
    
    # 移除默认出站规则并拒绝所有出站
    ec2_client.revoke_security_group_egress(
        GroupId=sg_id,
        IpPermissions=[{'IpProtocol': '-1', 'IpRanges': [{'CidrIp': '0.0.0.0/0'}]}]
    )
    
    # 将实例关联到新安全组
    instance.modify_attribute(Groups=[sg_id])
    
    # (可选)修改网络ACL
    subnet = ec2.Subnet(instance.subnet_id)
    nacl_id = subnet.network_acl_id
    
    # 添加拒绝该实例出站的ACL规则(规则号需唯一)
    ec2_client.create_network_acl_entry(
        NetworkAclId=nacl_id,
        RuleNumber=100,
        Protocol='-1',
        RuleAction='deny',
        Egress=True,
        CidrBlock=f'{private_ip}/32'
    )
    
    return {'status': 'success'}

5. 测试与验证
  1. 模拟一次入侵(如触发GuardDuty的测试事件)。
  2. 检查Lambda日志(CloudWatch Logs),确认安全组和网络ACL被正确修改。
  3. 验证受感染实例的出站流量是否被阻断。

6. 恢复流程
  • 手动恢复
    1. 将实例重新关联原始安全组。
    2. 删除临时创建的隔离安全组和网络ACL条目。
  • 自动恢复:可通过额外Lambda定时任务或基于GuardDuty的解决事件触发。

关键注意事项

  1. 规则号冲突 :网络ACL的RuleNumber需唯一,建议使用动态生成的高位数值(如时间戳后几位)。
  2. 安全组默认规则:新安全组默认拒绝所有入站、允许所有出站,需显式移除出站规则。
  3. 跨账户支持:若GuardDuty跨账户检测,需配置EventBridge跨账户权限。
相关推荐
亚远景aspice11 分钟前
亚远景-ASPICE vs ISO 21434:汽车软件开发标准的深度对比
网络·安全
创客匠人老蒋17 分钟前
雷军「去执行化」与小米汽车更名:一场关乎安全与战略的双向奔赴|创客匠人热点评述
安全·汽车
从零开始学习人工智能27 分钟前
Feign 重试策略调整:优化微服务通信的稳定性
java·微服务·架构
Kookoos28 分钟前
从单体到微服务:基于 ABP vNext 模块化设计的演进之路
后端·微服务·云原生·架构·c#·.net
新能源汽车-小K28 分钟前
车载网络TOP20核心概念科普
网络
Dr.Zeus33 分钟前
新能源汽车CAN通信深度解析:MCU、VCU、ECU协同工作原理
网络·汽车
全栈工程师修炼指南37 分钟前
【网安等保】OpenEuler 24.03系统主机安全加固及配置优化实践指南
安全
EulerBlind42 分钟前
【MCP】为什么使用Streamable HTTP: 相比SSE的优势与实践指南
网络·网络协议·http
上海云盾第一敬业销售1 小时前
网站业务被 DDoS 攻击了怎么办?
网络·ddos
蹦蹦跳跳真可爱5892 小时前
Python----神经网络(《Going deeper with convolutions》论文解读和GoogLeNet网络)
网络·人工智能·pytorch·python·神经网络