Oracle的always free oci实例,standard em2.1.micro,保活脚本

以下是可手动启动/停止的持续保活脚本

  • CPU 利用率 :持续 30%~50% 左右(可调)
  • 网络利用率 :持续 30%+(通过定期下载/上传产生流量)

不会轻易把实例搞崩溃,且完全可控。

1. 准备工作(执行一次)

bash 复制代码
sudo apt update
sudo apt install stress-ng iperf3 curl wget screen -y

2. 创建保活脚本

bash 复制代码
nano ~/keepalive.sh

粘贴以下内容:

bash 复制代码
#!/bin/bash
# Oracle E2.1 Micro 保活脚本 - CPU + 网络持续负载
# 可手动启动/停止

MODE=${1:-start}   # start / stop

if [ "$MODE" = "stop" ]; then
    echo "停止保活进程..."
    pkill -f "stress-ng.*keepalive"
    pkill -f "iperf3.*keepalive"
    pkill -f "wget.*keepalive"
    echo "已停止"
    exit 0
fi

echo "启动保活进程... (CPU ~50% + 网络持续活动)"
echo "按 Ctrl+C 停止当前会话,或用 ./keepalive.sh stop 停止"

# CPU 负载:用 stress-ng 产生适中持续负载(可调 --cpu-load)
stress-ng --cpu 1 --cpu-load 50 --timeout 0 --metrics-brief &

# 网络负载:用 iperf3 + wget 组合,产生稳定流量
while true; do
    # iperf3 下载测试(每轮跑 45 秒)
    iperf3 -c iperf.cloudflare.net -t 45 -P 1 >/dev/null 2>&1 || true
    
    # 下载大文件产生爆发流量
    wget -q -O /dev/null --timeout=30 --tries=2 https://speed.cloudflare.com/__down?bytes=50000000 2>/dev/null || true
    
    # 随机等待 30-90 秒,保持利用率波动但整体 >30%
    sleep $((RANDOM % 60 + 30))
done

保存后赋予权限:

bash 复制代码
chmod +x ~/keepalive.sh

3. 使用方法(手动控制)

启动

bash 复制代码
cd ~
./keepalive.sh

推荐用 screen 后台运行(这样退出 SSH 也不会停止):

bash 复制代码
screen -S keepalive
./keepalive.sh
# 按 Ctrl+A 再按 D 脱离 screen

停止

bash 复制代码
./keepalive.sh stop
# 或
screen -r keepalive   # 重新进入后 Ctrl+C

4. 进阶:做成 Systemd 服务(推荐长期使用)

bash 复制代码
sudo nano /etc/systemd/system/keepalive.service

内容:

ini 复制代码
[Unit]
Description=Oracle Keepalive Service (CPU + Network)
After=network.target

[Service]
Type=simple
User=ubuntu
WorkingDirectory=/home/ubuntu
ExecStart=/home/ubuntu/keepalive.sh
Restart=always
RestartSec=10

[Install]
WantedBy=multi-user.target

启用服务:

bash 复制代码
sudo systemctl daemon-reload
sudo systemctl enable --now keepalive.service

# 查看状态
sudo systemctl status keepalive.service

# 停止/启动
sudo systemctl stop keepalive.service
sudo systemctl start keepalive.service

效果预期

  • CPU:基本稳定在 30%~45%
  • 网络:利用率超过 30%(取决于你的带宽上限)
  • 可随时手动停止,不会一直占用资源

注意

  • E2.1 Micro 内存只有 1GB,不要把 CPU load 调太高(35% 左右最安全)。
  • 定期用 htop 检查负载(sudo apt install htop)。
  • 如果实例变慢,可把 --cpu-load 35 调低到 25-30。
相关推荐
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
大树883 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
小宇宙Zz3 天前
Maven依赖冲突
java·服务器·maven
古城小栈3 天前
Unix 与 Linux 异同小叙
linux·服务器·unix
程序猿阿伟3 天前
《Chrome离线扩展安装的底层逻辑与场景落地指南》
服务器·网络·chrome
曹牧3 天前
Oracle EXPLAIN PLAN
数据库·oracle
贤时间3 天前
codex 助力oracle ebs 开发
数据库·oracle
凡人叶枫3 天前
Effective C++ 条款42:了解 typename 的双重意义
java·linux·服务器·c++
AC赳赳老秦3 天前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw
秉承初心3 天前
PostgreSQL 数据性能瓶颈突破实战
数据库·postgresql·oracle