ubuntu

docker在ubuntu上的容器编排怎么做

小樊
53
2025-09-06 17:52:28
栏目: 智能运维

在Ubuntu上进行Docker容器编排,常用工具为Docker ComposeKubernetes,以下是具体步骤:

一、Docker Compose(轻量级编排,适合中小规模场景)

1. 安装Docker Compose

# 下载最新版二进制文件(推荐)
sudo curl -L "https://github.com/docker/compose/releases/latest/download/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文件

在项目目录创建docker-compose.yml,定义服务、网络和卷。例如:

version: '3'
services:
  web:
    image: nginx:latest
    ports:
      - "80:80"
  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 ps

# 停止服务
docker-compose down

# 查看日志
docker-compose logs

4. 其他常用操作

二、Kubernetes(企业级编排,适合大规模集群)

1. 安装Kubernetes组件

# 安装Docker(若未安装)
sudo apt update
sudo apt install docker.io

# 添加Kubernetes APT仓库
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 update

# 安装kubelet、kubeadm、kubectl
sudo apt install -y kubelet kubeadm kubectl
sudo apt-mark hold kubelet kubeadm kubectl  # 锁定版本

2. 初始化Kubernetes集群

主节点执行:

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. 部署应用

创建YAML文件(如nginx-deployment.yaml):

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80

部署应用:

kubectl apply -f nginx-deployment.yaml

4. 管理集群

# 查看Pod状态
kubectl get pods

# 扩展副本数
kubectl scale deployment nginx-deployment --replicas=5

# 更新镜像
kubectl set image deployment/nginx-deployment nginx=nginx:1.25

5. 网络插件(必选)

安装Flannel网络插件(需在所有节点执行):

kubectl apply -f https://raw.githubusercontent.com/flannel-io/flannel/master/Documentation/kube-flannel.yml

三、选择建议

参考资料:

0
看了该问题的人还看了