在Ubuntu上进行Docker容器编排,常用工具为Docker Compose和Kubernetes,以下是具体步骤:
# 下载最新版二进制文件(推荐)
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
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:
# 启动服务(后台运行)
docker-compose up -d
# 查看运行状态
docker-compose ps
# 停止服务
docker-compose down
# 查看日志
docker-compose logs
docker-compose exec <服务名> /bin/bashdocker-compose builddocker-compose up -d --scale web=3(启动3个Nginx实例)# 安装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 # 锁定版本
在主节点执行:
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
创建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
# 查看Pod状态
kubectl get pods
# 扩展副本数
kubectl scale deployment nginx-deployment --replicas=5
# 更新镜像
kubectl set image deployment/nginx-deployment nginx=nginx:1.25
安装Flannel网络插件(需在所有节点执行):
kubectl apply -f https://raw.githubusercontent.com/flannel-io/flannel/master/Documentation/kube-flannel.yml
参考资料: