Docker在Linux上的容器编排主要通过Docker Compose或**Kubernetes(K8S)**实现,以下是具体方法:
# 下载二进制文件(推荐最新版)
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
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:
# 启动服务(后台运行)
docker-compose up -d
# 停止服务
docker-compose down
# 查看运行状态
docker-compose ps
# 安装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
在主节点执行:
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
通过kubectl
命令或YAML文件部署,例如:
# 部署Nginx
kubectl create deployment nginx --image=nginx
# 暴露服务
kubectl expose deployment nginx --type=NodePort --port=80
# 查看服务端口
kubectl get svc
工具 | 适用场景 | 复杂度 | 关键特性 |
---|---|---|---|
Docker Compose | 单机多容器、快速原型开发 | 低 | 轻量级、基于YAML的简单服务编排 |
Kubernetes | 多节点集群、大规模应用 | 高 | 自动扩缩容、服务发现、负载均衡、存储管理 |
root
用户运行容器,通过--user
参数指定非特权用户。volumes
挂载宿主机目录或命名卷,确保数据不丢失。kubectl
或Docker Secrets管理敏感信息。通过上述方法,可在Linux上高效实现Docker容器编排,满足从开发到生产的全流程需求。