51 lines
2.0 KiB
Markdown
51 lines
2.0 KiB
Markdown
|
|
# AWS IP 替换网站(Flask)
|
|||
|
|
|
|||
|
|
基于 Flask + boto3 + MySQL 的小工具,用于:
|
|||
|
|
- 根据输入的 IP 查找对应的 EC2 实例并终止
|
|||
|
|
- 使用配置好的 AMI 创建新实例
|
|||
|
|
- 如果新实例的公网 IP 存在于运维表(黑名单),通过停止/启动循环获取新 IP
|
|||
|
|
- 支持多 AWS 账户,通过配置文件切换
|
|||
|
|
|
|||
|
|
## 快速开始
|
|||
|
|
1) 安装依赖
|
|||
|
|
```bash
|
|||
|
|
python -m venv .venv
|
|||
|
|
.\\.venv\\Scripts\\activate
|
|||
|
|
pip install -r requirements.txt
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
2) 配置环境变量
|
|||
|
|
复制 `.env.example` 为 `.env`,按需修改:
|
|||
|
|
- `DATABASE_URL`:MySQL 连接串,例如 `mysql+pymysql://user:pass@localhost:3306/ip_ops`
|
|||
|
|
- `AWS_CONFIG_PATH`:AWS 账户配置文件(默认 `config/accounts.yaml`)
|
|||
|
|
- `IP_RETRY_LIMIT`:新 IP 与运维表冲突时的关机/开机重试次数
|
|||
|
|
|
|||
|
|
3) 准备数据库
|
|||
|
|
创建数据库并授权,然后首次运行时会自动创建表 `ip_operations`:
|
|||
|
|
```sql
|
|||
|
|
CREATE DATABASE ip_ops DEFAULT CHARACTER SET utf8mb4;
|
|||
|
|
GRANT ALL ON ip_ops.* TO 'user'@'%' IDENTIFIED BY 'pass';
|
|||
|
|
```
|
|||
|
|
表中记录的 IP 被视为不可使用的 IP 黑名单。
|
|||
|
|
|
|||
|
|
4) 配置 AWS 账户
|
|||
|
|
编辑 `config/accounts.yaml`,为每个账户填写:访问密钥、区域、AMI ID、实例类型、子网、安全组等。
|
|||
|
|
|
|||
|
|
5) 启动
|
|||
|
|
```bash
|
|||
|
|
flask --app app run --host 0.0.0.0 --port 5000
|
|||
|
|
# 或 python app.py
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 运行流程
|
|||
|
|
1) 页面输入需要替换的 IP,并选择 AWS 账户
|
|||
|
|
2) 后端在该账户中查找实例(先查公网 IP,再查私网 IP)
|
|||
|
|
3) 终止旧实例
|
|||
|
|
4) 使用配置的 AMI/实例规格创建新实例并等待 `running`
|
|||
|
|
5) 如果新公网 IP 在 `ip_operations` 表中,自动执行停止+启动直到拿到未被列入黑名单的 IP(最多 `IP_RETRY_LIMIT` 次)
|
|||
|
|
|
|||
|
|
## 注意事项
|
|||
|
|
- 真实环境会产生终止/创建实例等成本操作,请先在测试账户验证流程
|
|||
|
|
- 如果 AWS 或数据库配置加载失败,页面会显示错误提示
|
|||
|
|
- 根据需要可在 `ip_operations` 表中维护不可用 IP 列表,避免重复分配
|