linux

Docker在Linux上的容器编排如何实现

小樊
52
2025-09-04 11:51:13
栏目: 智能运维

Docker在Linux上的容器编排主要通过Docker Compose或**Kubernetes(K8S)**实现,以下是具体方法:

一、使用Docker Compose(轻量级编排)

1. 安装Docker Compose

# 下载二进制文件(推荐最新版)
sudo curl -L "https://github.com/docker/compose/releases/download/v2.20.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
# 验证安装
docker-compose --version

2. 编写docker-compose.yml文件

通过YAML文件定义服务、网络和卷,例如:

version: '3'
services:
  web:
    image: nginx:latest
    ports:
      - "80:80"
    volumes:
      - ./html:/usr/share/nginx/html
  db:
    image: mysql:5.7
    environment:
      MYSQL_ROOT_PASSWORD: example
    volumes:
      - db_data:/var/lib/mysql
volumes:
  db_data:

3. 执行编排命令

# 启动服务(后台运行)
docker-compose up -d
# 停止服务
docker-compose down
# 查看运行状态
docker-compose ps

二、使用Kubernetes(K8S,企业级编排)

1. 安装Kubernetes集群

# 安装Docker(若未安装)
sudo apt-get update && sudo apt-get install -y docker.io

# 安装kubeadm、kubelet、kubectl
sudo apt-get update && sudo apt-get install -y apt-transport-https curl
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -
echo "deb https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list
sudo apt-get update
sudo apt-get install -y kubelet kubeadm kubectl
sudo apt-mark hold kubelet kubeadm kubectl

2. 初始化集群

主节点执行:

sudo kubeadm init --pod-network-cidr=10.244.0.0/16
# 配置kubectl
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config

3. 部署应用

通过kubectl命令或YAML文件部署,例如:

# 部署Nginx
kubectl create deployment nginx --image=nginx
# 暴露服务
kubectl expose deployment nginx --type=NodePort --port=80
# 查看服务端口
kubectl get svc

三、核心区别与适用场景

工具 适用场景 复杂度 关键特性
Docker Compose 单机多容器、快速原型开发 轻量级、基于YAML的简单服务编排
Kubernetes 多节点集群、大规模应用 自动扩缩容、服务发现、负载均衡、存储管理

四、注意事项

通过上述方法,可在Linux上高效实现Docker容器编排,满足从开发到生产的全流程需求。

0
看了该问题的人还看了