在Ubuntu中进行Docker容器编排,常用工具为Docker Compose和Kubernetes,以下是具体步骤:
安装Docker:
sudo apt update
sudo apt install docker-ce docker-ce-cli containerd.io # 安装Docker CE
sudo systemctl enable docker # 开机自启
sudo usermod -aG docker $USER # 可选:添加用户到docker组(避免sudo)
安装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 # 验证安装
docker-compose.yml文件在项目目录创建docker-compose.yml,定义服务、网络和卷。例如:
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 ps # 查看运行中的服务
docker-compose logs # 查看日志
停止服务:
docker-compose down # 停止并删除容器、网络
安装Docker:
同上(需先安装Docker作为Kubernetes的运行时)。
安装kubeadm、kubelet、kubectl:
sudo apt update
sudo apt 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 update
sudo apt install -y kubelet kubeadm kubectl
sudo apt-mark hold kubelet kubeadm kubectl # 锁定版本
在Master节点执行:
sudo kubeadm init --pod-network-cidr=10.244.0.0/16 # 指定Pod网络CIDR
配置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
更多细节可参考官方文档:Docker Compose文档、Kubernetes文档。