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跨账户权限。
相关推荐
Johny_Zhao44 分钟前
Docker + CentOS 部署 Zookeeper 集群 + Kubernetes Operator 自动化运维方案
linux·网络安全·docker·信息安全·zookeeper·kubernetes·云计算·系统运维
鸭鸭鸭进京赶烤2 小时前
大学专业科普 | 云计算、大数据
大数据·云计算
诗句藏于尽头2 小时前
完成ssl不安全警告
网络协议·安全·ssl
ai小鬼头6 小时前
AIStarter如何助力用户与创作者?Stable Diffusion一键管理教程!
后端·架构·github
SH11HF6 小时前
小菜狗的云计算之旅,学习了解rsync+sersync实现数据实时同步(详细操作步骤)
学习·云计算
独行soc7 小时前
#渗透测试#批量漏洞挖掘#HSC Mailinspector 任意文件读取漏洞(CVE-2024-34470)
linux·科技·安全·网络安全·面试·渗透测试
Me4神秘7 小时前
Linux国产与国外进度对垒
linux·服务器·安全
掘金-我是哪吒8 小时前
分布式微服务系统架构第156集:JavaPlus技术文档平台日更-Java线程池使用指南
java·分布式·微服务·云原生·架构
国服第二切图仔8 小时前
文心开源大模型ERNIE-4.5-0.3B-Paddle私有化部署保姆级教程及技术架构探索
百度·架构·开源·文心大模型·paddle·gitcode
Me4神秘8 小时前
电信、移动、联通、广电跨运营商网速慢原因
网络