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
分享到:
相关推荐
包含guestbook-php-frontend,guestbook-redis-slave,pause-amd64,redis-master四个tar的docker镜像包
Guestbook k8s示例旨在展示k14s工具如何与实际应用程序一起工作。 本示例基于。 进行了更改以删除未使用的功能。 安装k14s工具 转至以获得安装说明。 部署 git clone ...
基本的Kubernetes实验室和各种测试 瘦的 将此示例库用作一组示例。 我已经在实验室中使用Fedora和Atomic图像上传了一组针对一个Master和5个节点的工作配置。 我最终将清理此存储库,并在以后使它更有用(此功能很快...
provider-k14s Slack:带有有关资源及其属性,示例的主题的请参阅以获取设置说明状态:实验中k14s Terraform提供程序当前具有以下功能: 模板使用解决图像摘要部署K8S资源与有关安装Kubernetes Guestbook的示例,请...
"helm-chart-guestbook" 是一个特定的 Helm 图表示例,它可能是用来演示或教学如何使用 Helm 来部署一个名为 "Guestbook" 的应用程序。Guestbook 通常是一个简单的 Web 应用,用于展示 Kubernetes 集群上的服务部署...
一个简单的kubernetes留言簿示例,用于演示如何使用带有AWS云提供商支持的演示如何部署kubernetes。 此使用了示例 留言本/ 修改后的示例,以使用AWS云提供商进行演示。 我是/ 用于配置实例配置文件的示例IAM策略...
要将此示例存储库用作我们的ArgoCD App of Apps教程的一部分,您需要安装以下组件的Kubernetes集群: 要了解如何在Kubernetes集群中安装上述工具,请查看我们的。 它包含您需要入门的所有详细信息!
该示例显示了如何使用Kubernetes和构建一个简单的多层Web应用程序。 目录 第三步:启动复制的从属Pod 第四步:创建redis从属服务 第五步:创建前端复制的容器 第六步:设置访客留言簿前端服务。 对前端服务使用...
使用New Relic APM进行配置的简单kubernetes应用 基于此环境的博客文章: : 要求 新的文物许可证密钥 AWS或Google Cloud帐户 Kubectl 您将需要派生此存储库并调整NEWRELIC_LICENSE_KEY环境变量以指向您的帐户。 ...