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国内镜像源/加速地址-每周更新

相关推荐
海鸥811 小时前
查看k8s集群的资源使用情况
云原生·容器·kubernetes
云上艺旅2 小时前
K8S学习之基础十八:k8s的灰度发布和金丝雀部署
学习·云原生·容器·kubernetes
Macle_Chen5 小时前
Mac服务器上创建Docker并安装宝塔环境
服务器·macos·docker
ChinaRainbowSea5 小时前
Linux: Centos7 Cannot find a valid baseurl for repo: base/7/x86_64 解决方案
java·linux·运维·服务器·docker·架构
Hellc0076 小时前
Docker 部署 MongoDB 并持久化数据
mongodb·docker·容器
云上艺旅7 小时前
K8S学习之基础十五:k8s中Deployment扩容缩容
学习·docker·云原生·kubernetes·k8s
颜淡慕潇10 小时前
【K8S系列】Kubernetes中查看日志常见问题&解决方案
后端·云原生·容器·kubernetes
三天不学习10 小时前
Windows 系统 Docker Desktop 入门教程:从零开始掌握容器化技术
运维·docker·容器
mumu-hn10 小时前
Docker基础篇——Ubuntu下Docker安装
运维·docker·容器
自律的蜗牛12 小时前
在 Docker 中安装并配置 MySQL
mysql·docker·容器