AWS 批量添加安全组

定义内网ip列表池
bash 复制代码
cat ip_list.txt

192.168.1.1
192.168.1.2
定义脚本安全组id等元数据
bash 复制代码
# cat sg-add.sh 


#!/bin/bash

# 定义安全组ID-宁夏 VPC:NX-NHRY-PRD-VPC vpc-xxx
SECURITY_GROUP_ID="sg-0f08237289xxxxx"

# 从文件中读取IP地址到数组
IFS=' ' read -ra INTERNAL_IPS <<< $(cat ip_list.txt)

# 循环遍历内网 IP 列表
for IP in "${INTERNAL_IPS[@]}"
do
    # 使用 AWS CLI 查询 EC2 实例,过滤出内网 IP 匹配的实例
    INSTANCE_ID=$(aws ec2 describe-instances --filters "Name=private-ip-address,Values=$IP" --query 'Reservations[].Instances[].InstanceId' --output text)

    # 如果找到匹配的实例,添加安全组
    if [ ! -z "$INSTANCE_ID" ]
    then
        # 获取实例当前的所有安全组
        CURRENT_SECURITY_GROUPS=$(aws ec2 describe-instances --instance-ids $INSTANCE_ID --query 'Reservations[].Instances[].SecurityGroups[].GroupId' --output text)

        # 添加新的安全组
        NEW_SECURITY_GROUPS="$CURRENT_SECURITY_GROUPS $SECURITY_GROUP_ID"
        
        echo "Adding security groups $NEW_SECURITY_GROUPS to instance $INSTANCE_ID"
        aws ec2 modify-instance-attribute --instance-id $INSTANCE_ID --groups $NEW_SECURITY_GROUPS
    else
        echo "No instance found with internal IP $IP"
    fi
done
相关推荐
站长朋友几秒前
解决SSL证书安装后网站仍显示“不安全”的问题
网络协议·安全·ssl·ssl证书安装不安全·锐安信ssltrus·ocsp响应速度·根证书链完整
BullSmall1 小时前
MySQL全面安全加固实战指南
mysql·安全·adb
suki_lynn2 小时前
Facebook 引流脚本:功能、风险与合规使用指南
android·云计算
wanhengidc3 小时前
云手机是真实手机吗
运维·服务器·游戏·智能手机·云计算
wanhengidc3 小时前
云手机 服务器网络安全
运维·服务器·安全·web安全·智能手机·云计算
GCKJ_08243 小时前
观成科技:Loki远控工具加密流量分析
安全·github
wanhengidc4 小时前
云手机的核心价值
运维·游戏·智能手机·云计算
Lynnxiaowen4 小时前
今天我们开始学习ansible之playbook的简单运用
linux·运维·学习·云计算·ansible
wanhengidc5 小时前
云手机的网络架构
服务器·网络·游戏·智能手机·架构·云计算
q***76665 小时前
网络安全防护指南:筑牢网络安全防线(510)
安全·web安全·php