您的位置:

使用Ubuntu在K8s集群中进行Web应用部署

一、环境准备

在部署前,需要准备好以下内容:

1. 一组至少有两台 Ubuntu 16.04 或更新版本的主机。

2. 安装Docker,可以参照官方文档进行安装。

3. 安装 Kubeadm 工具。

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 -
sudo touch /etc/apt/sources.list.d/kubernetes.list 
echo "deb http://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee -a /etc/apt/sources.list.d/kubernetes.list 
sudo apt-get update
sudo apt-get install -y kubelet kubeadm kubectl

4. 配置 Kubernetes 中的网络插件。本文采用 Flannel 网络插件。

二、搭建Kubernetes集群

1. 初始化一个 Master 节点。

sudo kubeadm init --pod-network-cidr=10.244.0.0/16

2. 完成初始化后,按照提示使用以下语句完成配置:

sudo mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config

3. 部署 Flannel 网络插件。

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

4. 将其他节点加入 Kubernetes 集群。在每个节点上运行下面的命令:

sudo kubeadm join $controller_private_ip:6443 --token $token --discovery-token-ca-cert-hash $hash

其中,$controller_private_ip 为 Master 节点的 IP,$token 和 $hash 分别为初始化 Master 节点后得到的 token 和 hash。

三、部署Web应用

1. 创建一个 Deployment。

kubectl create deployment web --image=gcr.io/google-samples/hello-app:1.0

2. 创建一个 Service。

kubectl expose deployment web --port=80 --target-port=8080 --type=LoadBalancer

3. 部署完成后,使用以下命令查看Service IP:

kubectl get svc web

4. 在浏览器中输入 Service IP,即可访问 Web 应用。

四、优化

1. 如果需要暴露 Kubernetes 集群的端口通信,可以使用 NodePort 或 LoadBalancer 类型的 Service。

2. 如需进一步优化,可以启用 Kubernetes 的健康检查和负载均衡功能。

3. 可以通过该命令检查服务状态:

kubectl get pods
kubectl get services

五、总结

以上就是使用 Ubuntu 在 K8s 集群中进行 Web 应用部署的方法。希望本文对你有所帮助。在实践中,可能会遇到一些问题,可以通过 K8s 社区的支持和文档进行解决。