`
奔跑的羚羊
  • 浏览: 581053 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Kubernetes示例Guestbook

 
阅读更多
Guestbook的文档,根据kubernetes的不同版本而不同,具体的版本信息:releases.k8s.io.
kubernetes发现Service有2种方式:环境变量,DNS
环境变量
服务可用被之前的容器发现。
DNS
使用cluster's DNS service, 所有的pod基于Service name自动解析到service。这种方式,需要安装cluster DNS

本例使用环境变量env的方式,无需安装cluster DNS。因此在创建之前,需要修改examples/guestbook/redis-slave-deployment.yaml 和 examples/guestbook/frontend-deployment.yaml中变量GET_HOSTS_FROM 的值,由dns变更为env

1 准备工作
需要准备一套kubernetes的运行环境,因此我们通过kubectl来检查集群的情况,如果没安装,请参考之前的帖子
# kubectl cluster-info


2 创建redis master
本例中的redis master并不是高可用的
2.1 定义Deployment
定义文件redis-master-deployment.yaml:

2.2 定义Service
定义文件redis-master-service.yaml:

2.3 创建Service
# kubectl create -f redis-master-service.yaml

2.4 查看Service
# kubectl get service

2.5 创建Deployment
#kubectl create -f redis-master-deployment.yaml

2.6 查看Deployment
# kubectl get deployments

# kubectl get pods


3 创建redis slave
定义两个slave pod
3.1 定义Deployment

由于没安装cluster DNS,先修改GET_HOSTS_FROM为env

3.2 定义Service
定义文件redis-slave-service.yaml:

3.3 创建Service
# kubectl create -f redis-slave-service.yaml

3.4 创建Deployment
# kubectl create -f redis-slave-deployment.yaml

3.5 构建image
# docker build -t gcr.io/google_samples/gb-redisslave:v1 .

3.6 验证
# kubectl get services
# kubectl get deployments
# kubectl get pods

4 创建frontend
4.1 定义Deployment
定义文件frontend-deployment.yaml

4.2 定义Service
定义文件frontend-service.yaml

4.3 创建Service
# kubectl create -f frontend-service.yaml

4.4 创建Deployment
# kubectl create -f frontend-deployment.yaml

4.5 构建image

# docker build -t gcr.io/google-samples/gb-frontend:v4 .

4.6 验证
# kubectl get services
# kubectl get deployments
# kubectl get pods -L tier
查找label为tier的所有pod

php的代码:

5 外部访问guestbook
kubernetes支持2种方式暴露一个服务到外部:NodePort和LoadBalancer
NodePort:
修改front-service.yaml, 设置type为NodePort,这样kubernetes会为其随机分配一个端口(默认:30000-32767)
如果希望指定nodePort的端口号,而不是系统自动分配。设置spec.ports
  • .nodePort的值为自定义的数字,当然这样需要自己保障不要和其他端口冲突

  • 重启frontend的service

    重新创建Service成功以后,我们再次查看所有的Service,发现frontend的EXTERNAL-IP更新为nodes

    在外部用浏览器访问的效果

    6 清理
    使用label标签,快速查找相关的资源,并且删除
    # kubectl delete deployments,services -l "app in (redis, guestbook)"


    参考:
    https://github.com/kubernetes/kubernetes/tree/master/examples/guestbook#guestbook-example




    • 大小: 4.2 KB
    • 大小: 28.1 KB
    • 大小: 12 KB
    • 大小: 3.7 KB
    • 大小: 7.3 KB
    • 大小: 4.1 KB
    • 大小: 5.3 KB
    • 大小: 5.8 KB
    • 大小: 39.1 KB
    • 大小: 9.3 KB
    • 大小: 10.8 KB
    • 大小: 3.5 KB
    • 大小: 3.8 KB
    • 大小: 31.2 KB
    • 大小: 25.5 KB
    • 大小: 35.2 KB
    • 大小: 15.6 KB
    • 大小: 3.8 KB
    • 大小: 3.8 KB
    • 大小: 42.9 KB
    • 大小: 31.9 KB
    • 大小: 36.3 KB
    • 大小: 21.9 KB
    • 大小: 21.6 KB
    • 大小: 12.9 KB
    • 大小: 19.8 KB
    • 大小: 12.7 KB
    分享到:
    评论

    相关推荐

      kubernetes权威指南2GuestBook示例镜像

      包含guestbook-php-frontend,guestbook-redis-slave,pause-amd64,redis-master四个tar的docker镜像包

      carvel-guestbook-example-on-kubernetes:使用k14s工具部署的K8s留言簿示例

      Guestbook k8s示例旨在展示k14s工具如何与实际应用程序一起工作。 本示例基于。 进行了更改以删除未使用的功能。 安装k14s工具 转至以获得安装说明。 部署 git clone ...

      kubelab:使用kubernetes masternode配置示例的openstack环境中的基本Box设置

      基本的Kubernetes实验室和各种测试 瘦的 将此示例库用作一组示例。 我已经在实验室中使用Fedora和Atomic图像上传了一组针对一个Master和5个节点的工作配置。 我最终将清理此存储库,并在以后使它更有用(此功能很快...

      terraform-provider-carvel:k14s包含ytt和kapp资源的Terraform提供程序以模板化并部署到Kubernetes

      provider-k14s Slack:带有有关资源及其属性,示例的主题的请参阅以获取设置说明状态:实验中k14s Terraform提供程序当前具有以下功能: 模板使用解决图像摘要部署K8S资源与有关安装Kubernetes Guestbook的示例,请...

      helm-chart-guestbook

      "helm-chart-guestbook" 是一个特定的 Helm 图表示例,它可能是用来演示或教学如何使用 Helm 来部署一个名为 "Guestbook" 的应用程序。Guestbook 通常是一个简单的 Web 应用,用于展示 Kubernetes 集群上的服务部署...

      k8s-guestbook

      一个简单的kubernetes留言簿示例,用于演示如何使用带有AWS云提供商支持的演示如何部署kubernetes。 此使用了示例 留言本/ 修改后的示例,以使用AWS云提供商进行演示。 我是/ 用于配置实例配置文件的示例IAM策略...

      argocd-app-of-apps-child-guestbook

      要将此示例存储库用作我们的ArgoCD App of Apps教程的一部分,您需要安装以下组件的Kubernetes集群: 要了解如何在Kubernetes集群中安装上述工具,请查看我们的。 它包含您需要入门的所有详细信息!

      pri-guestbook

      该示例显示了如何使用Kubernetes和构建一个简单的多层Web应用程序。 目录 第三步:启动复制的从属Pod 第四步:创建redis从属服务 第五步:创建前端复制的容器 第六步:设置访客留言簿前端服务。 对前端服务使用...

      newrelic-k8s-guestbook:在带有新的Relic APM的k8s上运行的node.js的演示

      使用New Relic APM进行配置的简单kubernetes应用 基于此环境的博客文章: : 要求 新的文物许可证密钥 AWS或Google Cloud帐户 Kubectl 您将需要派生此存储库并调整NEWRELIC_LICENSE_KEY环境变量以指向您的帐户。 ...

    Global site tag (gtag.js) - Google Analytics