在CentOS上部署Kubernetes(k8s)并应用部署的实践步骤如下:
安装Docker:
sudo yum install -y docker
sudo systemctl start docker
sudo systemctl enable docker
配置Docker镜像加速:
/etc/docker/daemon.json
文件,添加国内镜像源。{
"registry-mirrors": ["https://<your-mirror-url>"]
}
sudo systemctl restart docker
安装Kubernetes组件:
sudo yum install -y kubeadm kubelet kubectl
sudo systemctl enable --now kubelet
初始化主节点:
sudo kubeadm init --pod-network-cidr=10.244.0.0/16
kubeadm join
命令,用于加入工作节点。配置kubectl:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
安装网络插件(例如Flannel):
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
创建Deployment和Service:
# 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
# nginx-service.yaml
apiVersion: v1
kind: Service
metadata:
name: nginx-service
spec:
selector:
app: nginx
ports:
- protocol: TCP
port: 80
targetPort: 80
type: LoadBalancer
应用配置:
kubectl apply -f nginx-deployment.yaml
kubectl apply -f nginx-service.yaml
验证部署:
kubectl get svc nginx-service
sudo kubeadm join <master-ip>:<master-port> --token <token> --discovery-token-ca-cert-hash sha256:<hash>
安装监控工具(例如Prometheus和Grafana):
kubectl apply -f https://raw.githubusercontent.com/prometheus-operator/prometheus-operator/master/bundle.yaml
使用kubectl进行日常管理:
kubectl get pods
kubectl get services
备份etcd数据:
etcdctl snapshot save /var/lib/etcd/backup.db
恢复etcd数据:
etcdctl snapshot restore /var/lib/etcd/backup.db
通过以上步骤,你可以在CentOS上成功部署Kubernetes集群并应用部署。根据实际需求,可以进一步优化和扩展集群功能。