SSH 服务部署 + Docker(指定版本)完整安装 的一体化操作流程

SSH 服务部署 + Docker(指定版本)完整安装 的一体化操作流程(适配 Ubuntu 24.04,全程权限 / 兼容性优化,可直接复制批量执行):

核心说明

  • 整合 SSH 安装、Docker 指定版本(28.0.0)+ docker-compose-plugin(2.32.1)安装
  • 适配 Ubuntu 24.04(Noble),自动兼容系统架构(x86/arm)
  • 每步带日志输出,便于排查问题
bash 复制代码
#!/bin/bash
set -e  # 遇到错误立即退出,避免后续无效操作

# ==============================================
# 阶段1:基础环境准备 & SSH服务部署
# ==============================================
echo -e "\033[32m===== 阶段1:基础环境准备 & SSH服务部署 =====\033[0m"

# 步骤1:查询系统版本(确认系统类型/版本,适配Docker源)
echo -e "\n===== 1.1 查询系统版本 ====="
lsb_release -a 2>/dev/null || cat /etc/os-release
UBUNTU_CODENAME=$(lsb_release -cs 2>/dev/null || grep VERSION_CODENAME /etc/os-release | cut -d= -f2)
echo "当前Ubuntu版本代号:${UBUNTU_CODENAME}"

# 步骤1.2:更新系统软件源(确保包最新)
echo -e "\n===== 1.2 更新软件源 ====="
sudo apt update -y

# 步骤1.3:安装net-tools(兼容netstat端口查询)
echo -e "\n===== 1.3 安装net-tools工具包 ====="
sudo apt install net-tools -y

# 步骤1.4:安装OpenSSH服务端
echo -e "\n===== 1.4 安装OpenSSH服务端 ====="
sudo apt install openssh-server -y

# 步骤1.5:启动SSH服务 + 设置开机自启
echo -e "\n===== 1.5 启动并设置SSH开机自启 ====="
sudo systemctl start ssh
sudo systemctl enable ssh
sudo systemctl status ssh --no-pager

# 步骤1.6:验证SSH端口监听(双工具验证)
echo -e "\n===== 1.6 验证SSH端口监听 ====="
sudo ss -tnlp | grep ssh
sudo netstat -tnlp | grep ssh
ss -tuln | grep -E '22|ssh'

# 步骤1.7:防火墙放行SSH端口(关键)
echo -e "\n===== 1.7 防火墙放行SSH 22端口 ====="
sudo ufw status 2>/dev/null || echo "ufw未安装,跳过放行"
sudo ufw allow 22/tcp 2>/dev/null
sudo ufw reload 2>/dev/null

# 步骤1.8:SSH最终验证
echo -e "\n===== 1.8 SSH最终验证 ====="
echo "SSH服务状态:$(sudo systemctl is-active ssh)"
echo "SSH开机自启:$(sudo systemctl is-enabled ssh)"
echo "SSH监听端口:$(sudo ss -tnlp | grep ssh | awk '{print $4}')"

# ==============================================
# 阶段2:Docker(指定版本)+ docker-compose-plugin 安装
# ==============================================
echo -e "\n\n\033[32m===== 阶段2:Docker指定版本安装 =====\033[0m"

# 步骤2.1:安装Docker依赖包
echo -e "\n===== 2.1 安装Docker依赖 ====="
sudo apt-get install -y ca-certificates curl gnupg lsb-release

# 步骤2.2:添加Docker官方GPG密钥(适配新版APT密钥存储)
echo -e "\n===== 2.2 添加Docker GPG密钥 ====="
sudo mkdir -p /etc/apt/trusted.gpg.d
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/trusted.gpg.d/docker.gpg

# 步骤2.3:添加Docker APT源(适配当前Ubuntu版本)
echo -e "\n===== 2.3 添加Docker APT源 ====="
echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/trusted.gpg.d/docker.gpg] https://download.docker.com/linux/ubuntu ${UBUNTU_CODENAME} stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

# 步骤2.4:更新APT缓存(使Docker源生效)
echo -e "\n===== 2.4 更新APT缓存 ====="
sudo apt-get update -y

# 步骤2.5:列出可安装的Docker版本(确认目标版本存在)
echo -e "\n===== 2.5 列出可安装的Docker CE版本 ====="
apt-cache madison docker-ce | grep 28.0.0

# 步骤2.6:安装指定版本Docker(28.0.0-1~ubuntu.24.04~noble)
echo -e "\n===== 2.6 安装Docker 28.0.0 ====="
DOCKER_VERSION="5:28.0.0-1~ubuntu.24.04~noble"
sudo apt-get install -y \
  docker-ce=${DOCKER_VERSION} \
  docker-ce-cli=${DOCKER_VERSION} \
  containerd.io

# 步骤2.7:设置Docker开机自启并启动服务
echo -e "\n===== 2.7 配置Docker服务 ====="
sudo systemctl enable docker
sudo systemctl enable containerd
sudo systemctl start docker
sudo systemctl status docker --no-pager

# 步骤2.8:列出可安装的docker-compose-plugin版本
echo -e "\n===== 2.8 列出可安装的docker-compose-plugin版本 ====="
apt-cache madison docker-compose-plugin | grep 2.32.1

# 步骤2.9:安装指定版本docker-compose-plugin(2.32.1)
echo -e "\n===== 2.9 安装docker-compose-plugin 2.32.1 ====="
COMPOSE_VERSION="2.32.1-1~ubuntu.24.04~noble"
sudo apt install -y docker-compose-plugin=${COMPOSE_VERSION}

# ==============================================
# 阶段3:最终验证(SSH + Docker)
# ==============================================
echo -e "\n\n\033[32m===== 阶段3:最终验证 =====\033[0m"

# SSH验证
echo -e "\n【SSH验证】"
echo "SSH服务状态:$(sudo systemctl is-active ssh)"
echo "SSH监听端口:$(sudo ss -tnlp | grep ssh | awk '{print $4}')"

# Docker验证
echo -e "\n【Docker验证】"
docker --version
docker compose version
sudo systemctl is-active docker
sudo systemctl is-enabled docker

# 最终提示
echo -e "\n\033[32m✅ 全部操作完成!\033[0m"
echo -e "1. SSH远程连接:ssh 用户名@服务器IP(默认端口22)"
echo -e "2. Docker验证命令:docker run --rm hello-world"
echo -e "3. Docker Compose使用:docker compose up -d"
相关推荐
宇钶宇夕15 小时前
CoDeSys入门实战一起学习(十三):函数(FUN)深度解析:自定义、属性与实操案例
运维·算法·自动化·软件工程
bukeyiwanshui16 小时前
Nginx 服务器
运维·服务器·nginx
楼田莉子16 小时前
Linux学习之库的原理与制作
linux·运维·服务器·c++·学习
枷锁—sha16 小时前
【Vulhub】1Panel 访问控制绕过实战指南 (CVE-2024-39907)
运维·学习·安全·网络安全
kkoral16 小时前
【FFmpeg 智慧园区场景应用】2.自动化处理 Shell 脚本
运维·ffmpeg·自动化
Ghost Face...16 小时前
SoC启动流程详解:从Bootrom到多核负载均衡
运维·负载均衡
EverydayJoy^v^16 小时前
RH134学习进程——三.分析与存储日志
运维·服务器·网络
篱笆院的狗16 小时前
yum install 发生 Cannot find a valid baseurl for repo: centos-sclo-rh/x86_64
linux·运维·centos
磊磊cpp16 小时前
Ubuntu 22.04 手动安装 XRDP(RDP 远程桌面)教程
linux·运维·ubuntu
等风来不如迎风去16 小时前
【docker】ubuntu空间不够了,删除ragflow
ubuntu·docker·容器