Kubernetes (K8s) 集群部署指南:从环境准备到应用部署(脚本部署)

使用方法

本文章内容参考自:Kubernetes (K8s) 集群部署指南:从环境准备到应用部署

1. 环境准备

  • 操作系统:所有节点需为 CentOS 7。
  • 网络要求:所有节点需能相互通信,且能访问外网(或已配置镜像加速)。
  • 脚本文件 :将三个文件放置在同一目录,例如 /opt/kubernetes

2. 下载或上传脚本

  1. 使用wget直接下载(在每个节点都执行)

    请先执行 yum -y install wget

    bash 复制代码
    # 创建目录
    sudo mkdir -p /opt/kubernetes 
    
    # 切换目录
    cd /opt/kubernetes 
    
    # 下载资源
    wget https://gitee.com/xy12306/k8s/raw/master/URL/k8s_v2.6.tar
    
    # 解压资源
    tar -xvf k8s_v2.6.tar

3. 执行脚本

  • 打开master节点(在 /opt/kubernetes 文件夹下)

    bash 复制代码
    # 赋予执行权限
    chmod +x *.sh
    
    # Master节点
    ./master.sh 
  • 打开node节点(在 /opt/kubernetes 文件夹下)

    bash 复制代码
    # 赋予执行权限
    chmod +x *.sh
    
    # Node节点
    ./node.sh 

master节点 输出示例

按照以上格式复制后输入到Node节点即可成功加入集群。


验证集群状态

  • 在主节点执行以下命令
csharp 复制代码
# 查看节点状态
kubectl get nodes

# 查看 Pod 状态(确保 Calico 等组件正常)
kubectl get pods -n kube-system
  • 如果 Token 过期的话:在主节点重新生成 Token:
lua 复制代码
sudo kubeadm token create --print-identity

部署测试应用并访问

1. 部署一个简单的Nginx应用

ini 复制代码
kubectl create deployment nginx --image=nginx
kubectl expose deployment nginx --port=80 --type=NodePort

2. 查看服务状态:

kubectl get services

kubectl get pods

kubectl get deployments

scss 复制代码
[root@master ~] kubectl get svc nginx
NAME    TYPE       CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
nginx   NodePort   10.111.140.102   <none>        80:30433/TCP   5

您已经成功创建了一个 Nginx 的 Deployment 并将其暴露为 NodePort 类型的 Service。根据您的输出,Nginx 服务的 NodePort30433,这意味着您可以通过集群中任何节点的 IP 地址和端口 30433 访问 Nginx。

3. 访问 Nginx

使用查看节点的 IP 地址kubectl get nodes -o wideNodePort 端口(30433)访问 Nginx。您可以通过以下方式访问:

  • 通过浏览器访问 :在浏览器地址栏中输入 http://<节点IP>:30433
arduino 复制代码
http://192.168.55.161:30433
  • 通过 **curl**命令在虚拟机中访问:
arduino 复制代码
curl http://192.168.55.161:30433

安装 Kubernetes Dashboard 可视化工具

bash 复制代码
# 安装 Kubernetes Dashboard
kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v2.7.0/aio/deploy/recommended.yaml

# 检查是否正常运行,需状态全都为running
kubectl get pods -n kubernetes-dashboard
  • 创建 dashboard-admin 用户并授权
lua 复制代码
kubectl create serviceaccount dashboard-admin -n kubernetes-dashboard
kubectl create clusterrolebinding dashboard-admin --clusterrole=cluster-admin --serviceaccount=kubernetes-dashboard:dashboard-admin

创建了一个名为 dashboard-admin 的 ServiceAccount,位于 kubernetes-dashboard 命名空间。

创建了一个名为 dashboard-admin 的 ClusterRoleBinding,将 dashboard-admin ServiceAccount 绑定到 cluster-admin 角色。

  • 获取用户 Token
lua 复制代码
kubectl create token dashboard-admin -n kubernetes-dashboard
  • 修改 Service 类型为 NodePort
css 复制代码
kubectl patch svc kubernetes-dashboard -n kubernetes-dashboard -p '{"spec":{"type":"NodePort"}}'
  • 查看 Service 的 NodePort:
arduino 复制代码
kubectl get svc -n kubernetes-dashboard
  • 访问 Dashboard

    • 通过 https://<节点IP>:30375 访问 Dashboard。

注意:请将 <节点IP> 替换为实际的 Kubernetes 节点 IP 地址。


本文章仅供参考,适用于初学者

相关文章:

Kubernetes (K8s) 集群部署指南:从环境准备到应用部署

CentOS 7 环境下的 Docker 安装与配置

Docker国内镜像源/加速地址-每周更新

相关推荐
家庭云计算专家19 分钟前
onlyoffice 源码调试指南-ARM和x86双模式安装支持
arm开发·docker·容器·云计算
韩先超2 小时前
2025年3月,韩先超对国网宁夏进行Python线下培训
python·ai·云原生·kubernetes·devops
小马爱打代码5 小时前
K8S - 金丝雀发布实战 - Argo Rollouts 流量控制解析
云原生·容器·kubernetes
C-200210 小时前
使用Deployment部署运行Nginx和Apache服务
运维·kubernetes·apache
斯普信专业组10 小时前
基于Kubernetes的Apache Pulsar云原生架构解析与集群部署指南(下)
云原生·kubernetes·apache
leo·Thomas11 小时前
NetBox Docker 全功能部署方案(Ubuntu 22.04 + Docker)
运维·ubuntu·docker·容器·资产管理
码码哈哈0.015 小时前
2025最新:3分钟使用Docker快速部署Redis集群
redis·docker·容器
张青贤17 小时前
k8s的pod挂载共享内存
云原生·容器·kubernetes
和计算机搏斗的每一天18 小时前
k8s术语之secret
云原生·容器·kubernetes
韩先超18 小时前
2022年8月,韩先超对中移信息进行微服务架构原理(Docker+k8s+DevOps+Go等)培训
docker·微服务·kubernetes·devops