Google Kubernetes Engine 集群实战详解

 更新时间:2022年08月30日 16:06:35   作者:青Cheng序员石头  
这篇文章主要为大家介绍了Google Kubernetes Engine 集群实战详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

GKE 集群介绍

Google Kubernetes Engine (GKE) 集群由 Kubernetes 开源集群管理系统提供支持。Kubernetes 为用户提供了与容器集群进行交互的机制。您可以使用 Kubernetes 命令和资源来部署和管理应用、执行管理任务、设置政策,以及监控您部署的工作负载的运行状况。

K8s 带来的好处

  • 自动管理
  • 对应用容器进行监控和活跃性探测
  • 自动扩缩
  • 滚动更新

Google Cloud 上的 Kubernetes 运行 GKE 集群时,您还可以获享 Google Cloud 提供的高级集群管理功能所带来的好处,其中包括:

  • 针对 Compute Engine 实例提供的负载平衡功能
  • 节点池(可用于在集群中指定节点子集以提高灵活性)
  • 自动扩缩集群的节点实例数量
  • 自动升级集群的节点软件
  • 节点自动修复,以保持节点的正常运行和可用性
  • 利用 Cloud Monitoring 进行日志记录和监控,让您可以清楚了解自己集群的状况

使用 GKE 编排集群

1.打开cloud shell,并设置project (如果默认连接成功则不需要)

gcloud config set project <Project ID>

2.设置默认计算可用区域

gcloud config set compute/zone  <Zone>

3.启动新的GKE集群,要耗时几分钟,耐心等待

gcloud container clusters create --machine-type=e2-medium lab-cluster

输出结果如下:

创建集群后,您需要身份验证凭据才能与其交互,所以接下来获取身份验证凭据。

4.获取用于集群的身份验证凭据

gcloud container clusters get-credentials lab-cluster 

输出结果如下所示:

5.将应用部署到集群中

GKE 使用 Kubernetes 对象创建和管理集群的资源。Kubernetes 提供了 Deployment 对象,用以部署网络服务器等无状态应用。Service 对象则用于定义从互联网访问您的应用时需要遵循的规则和负载平衡机制。

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

输出结果如下所示:

此 Kubernetes 命令kubectl会创建一个代表 hello-server 的 Deployment 对象。在本例中,--image 指定了要部署的容器映像。该命令会从 Container Registry 存储分区中拉取示例映像。gcr.io/google-samples/hello-app:1.0 指定了要拉取的特定映像版本。如果未指定版本,则使用最新版本。

6.运行命令kubectl expose 以创建K8s Service

kubectl expose deployment hello-server --type=LoadBalancer --port 8080

在上面的命令中:

  • --port 指定了该容器公开的端口。
  • type="LoadBalancer" 表示为您的容器创建一个 Compute Engine 负载平衡器。

输出结果如下所示:

注意: 生成外部 IP 地址可能需要一分钟时间。如果 EXTERNAL-IP 列的状态为 pending,请再次运行上述命令。

7.运行 kubectl get 命令,以检查 hello-server Service:

kubectl get service

输出结果如下所示:

8.浏览器上访问http://[EXTERNAL-IP]:8080,会获取到如下信息

9.删除集群,可能需要几分钟的时间

gcloud container clusters delete lab-cluster 

以上就是Google Kubernetes Engine 集群实战详解的详细内容,更多关于Google Kubernetes Engine集群的资料请关注脚本之家其它相关文章!

相关文章

  • K8s-helm简介及基本概念详解

    K8s-helm简介及基本概念详解

    ​Helm 使用的包格式称为 chart,它是一个描述 Kubernetes 相关资源对象的文件集合,这篇文章主要介绍了K8s-helm简介及基本概念,需要的朋友可以参考下
    2022-07-07
  • 一文详解基于k8s部署Session模式Flink集群

    一文详解基于k8s部署Session模式Flink集群

    这篇文章主要为大家介绍了基于k8s部署Session模式Flink集群详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • k8s控制deamonset中pod数量的方法

    k8s控制deamonset中pod数量的方法

    DaemonSet是Kubernetes中用于确保每个节点运行一个Pod副本的控制器,常用于运行集群守护进程,通过节点选择器、节点亲和性、容忍度和更新策略,可以精确控制Pod的数量和调度,本文介绍k8s控制deamonset中pod数量的方法,感兴趣的朋友一起看看吧
    2025-01-01
  • kubernetes(k8s)中Yaml文件详解

    kubernetes(k8s)中Yaml文件详解

    这篇文章主要给大家介绍了关于kubernetes(k8s)中Yaml文件详解的相关资料,YAML是专门用来写配置文件的语言,非常简洁和强大,使用比json更方便,需要的朋友可以参考下
    2023-12-12
  • 一文详解如何高效查看k8s日志

    一文详解如何高效查看k8s日志

    K8S是kubernetes的缩写,是为解决容器服务编排而生的,在运维K8S服务的过程中,经常会遇到各种报错和诊断问题,那么我们一般怎么查看K8S组件的日志,这篇文章主要给大家介绍了关于如何高效查看k8s日志的相关资料,需要的朋友可以参考下
    2023-10-10
  • K8s搭建Jenkins的详细教程(附源代码)

    K8s搭建Jenkins的详细教程(附源代码)

    Jenkins 是一个开源的自动化服务器,主要用于持续集成和持续交付,这篇文章主要来和大家介绍一下如何在K8s中搭建Jenkins,有需要的可以了解下
    2025-03-03
  • 2022最新青龙面板对接机器人的详细过程(傻妞对接onebot(oicq)协议实现机器人功能)

    2022最新青龙面板对接机器人的详细过程(傻妞对接onebot(oicq)协议实现机器人功能)

    这篇文章主要介绍了2022最新青龙面板对接机器人的详细过程(傻妞对接onebot(oicq)协议实现机器人功能),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • k8s使用rbd作为存储的操作方法

    k8s使用rbd作为存储的操作方法

    这篇文章主要介绍了k8s使用rbd作为存储的操作方法,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • Kubernetes集群环境初始化

    Kubernetes集群环境初始化

    这篇文章介绍了Kubernetes集群环境初始化的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Prometheus Operator架构介绍

    Prometheus Operator架构介绍

    这篇文章主要为大家介绍了Prometheus Operator架构介绍,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11

最新评论