在我们部署Spinnaker之前,我们需要一个YAML格式的配置文件,它会包含了一些配置信息。可以从Spinnaker Helm Chart repository[2]获得这个文件。

$curl -Lo values.yaml https://raw.githubusercontent.com/kubernetes/charts/master/stable/spinnaker/values.yaml

%Total % Received % Xferd Average Speed Time Time Time Current

Dload Upload Total Spent Left Speed

100 2950 100 2950 0 0 2950 0 0:00:01 --:--:-- 0:00:01 10535

现在我们可以安装Spinnaker了。用下面的命令可以把它部署在我们的Kubernetes集群里:

$ helm install-n kubelive stable/spinnaker -f values.yaml --timeout 300 --version 0.3.5 --namespace spinnaker

这里的-f参数的意思是指出安装的配置文件。--timeout会让Helm在遇到错误的时候等待至少300秒再退出。这篇文章中我们用的是0.3.5的版本,是用--version指定的。最后我们用--namespace指定了安装Spinnaker的namespace。

过了一会儿,我们应该可以看到下面的输出。

NAME: kubelive

LAST DEPLOYED: Wed Jan 3 11:26:12 2018

NAMESPACE: spinnaker

STATUS: DEPLOYED

RESOURCES:

…..

NOTES:

You will need to create2port forwarding tunnels inordertoaccessthe Spinnaker UI:

exportDECK_POD=$(kubectl getpods --namespace spinnaker -l "component=deck,app=kubelive-spinnaker" -o jsonpath="{.items[0].metadata.name}")

kubectl port-forward --namespace spinnaker $DECK_POD 9000

Visit the Spinnaker UI byopening your browser to: http://127.0.0.1:9000

Formore info onthe Kubernetes integration forSpinnaker, visit:

http://www.spinnaker.io/docs/kubernetes-source-to-prod

如果你遇到错误超时退出,可以用helm del --purge kubelive 命令去删除,并且重新运行安装命令。

所有的Spinnaker的相关组件都已经部署到了Spinnaker的namespace里了,我们可以用下面的命令去确认。

$ kubectl get pod --namespace=spinnaker

NAME READY STATUS RESTARTS AGE

kubelive-jenkins -67bb8f6b96-w5rdp 1/ 1Running 053m

kubelive-minio -5946fc9bcc-fcvv8 1/ 1Running 053m

kubelive-redis -7bb9d95468-kt2vq 1/ 1Running 153m

kubelive-spinnaker-clouddriver -6cd89c9bd5 -8rwln 1/ 1Running 153m

kubelive-spinnaker-deck -7846d6497-bjg7b 1/ 1Running 053m

kubelive-spinnaker-echo -6fd649469d -2pxzd 1/ 1Running 153m

kubelive-spinnaker-front50 -85dd9fd58c-ktj6j 1/ 1Running 153m

kubelive-spinnaker-gate -5868d9f8ff-hjpvg 1/ 1Running 053m

kubelive-spinnaker-igor-fdbdcc9c8-hldsk 1/ 1Running 053m

kubelive-spinnaker-orca-dd79c8bc7-xmwc7 1/ 1Running 053m

kubelive-spinnaker-rosco -7b9f77b5bb-drxhs 1/ 1Running 053m

在我们通过浏览器访问Spinnaker之前,我们需要用下面命令打开端口转发功能。也就是说这个命令将会把Spinnaker Web UI的端口映射到主机的端口上。

$ export DECK_POD=$(kubectl get pods --namespace spinnaker -l "component=deck,app=kubelive-spinnaker"-o jsonpath= "{.items[0].metadata.name}")

$ kubectl port-forward --namespace spinnaker $DECK_POD 9000

现在可以通过http://localhost:9000去访问Spinnaker了。

通过Spinnaker去部署一个容器化的应用

现在我们可以通过部署一个Nginx Web服务器去熟悉Spinnaker的概念和术语。

首先在右上角的“操作”菜单下单击“Create Application”来创建应用程序。“application”是一个资源的逻辑集合,包括负载均衡、安全组、服务组和集群。

现在我们在这个application里去创建一个负载均衡器。单击菜单顶部的"Load Balancer",并且点击“Create Load Balancer” 按钮。

当你创建了一个新的负载均衡器,输入prod作为堆栈的名字。80端口作为Target Port,并且选择NodePort类型,点击Create按钮。

在 Clusters里,选择 Create Server Group。

在下拉框里选择nginx:latest作为容器。选择nginx-prod作为负载均衡器,输入10作为副本数。

在Container设置里,选择Probes去创建Readiness Probe和Liveness Probe。最后点击Create按钮。

当这个实例在Server Group里状态变成可用,如果是红色则代表这个实例还是不可能的状态。

切换到终端,并且运行下面命令可以得到服务的NodePort。

$ kubectl get svc

NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE

kubernetes ClusterIP 10.96.0.1 <none>443/TCP 50m

nginx-prod NodePort 10.99.164.47 <none>80:31728/TCP 18m

这个负载均衡器已经被Spinnaker创建好,并且通过Kubernetes的NodePort对外提供访问。我们现在可以直接通过Minikube的命令访问了。

$ minikube service nginx-prod

Opening kubernetes service default/nginx-prod indefaultbrowser...

运行kubectl get pods可以显示一共有10个Nginx的Pod被创建出来了。

$ kubectl getpods

NAME READY STATUS RESTARTS AGE

nginx-prod-v000 -6m642 1/ 1Running 09m

nginx-prod-v000 -9kxtv 1/ 1Running 09m

nginx-prod-v000-bpzw4 1/ 1Running 09m

nginx-prod-v000-f87gn 1/ 1Running 09m

nginx-prod-v000-h629g 1/ 1Running 09m

nginx-prod-v000-hkhjc 1/ 1Running 09m

nginx-prod-v000-jhnv2 1/ 1Running 09m

nginx-prod-v000-jmkgx 1/ 1Running 09m

nginx-prod-v000-s59pm 1/ 1Running 09m

nginx-prod-v000-ssz85 1/ 1Running 09m

在Spinnaker的仪表板扩展服务组(Server Group)一样相同。

这篇文章涵盖了在开发环境中,使用和运行Spinnaker的所有步骤。在本系列的下一篇文章里,我们会用Spinnaker去建立一个end-to-end的CI/CD pipeline环境,然后去发布一个应用的蓝绿部署。敬请关注!

  1. https://www.thenewstack.io/tag/Learn-Spinnaker
  2. https://github.com/kubernetes/charts/tree/master/stable/spinnaker

Kubernetes 集群中使用 Helm 搭建 Spinnaker的更多相关文章

  1. 在Kubernetes集群中安装Helm及证书认证

    安装Kubernetes 测试环境使用kubeadm安装kubernetes v1.6.3版本, 安装过程略过. 为Helm创建客户端认证 客户端认证是为了能够使用helm命令行调用Helm的服务端T ...

  2. 初试 Kubernetes 集群中使用 Traefik 反向代理

    初试 Kubernetes 集群中使用 Traefik 反向代理 2017年11月17日 09:47:20 哎_小羊_168 阅读数:12308    版权声明:本文为博主原创文章,未经博主允许不得转 ...

  3. 在kubernetes集群中创建redis主从多实例

    分类 > 正文 在kubernetes集群中创建redis主从多实例 redis-slave镜像制作 redis-master镜像制作 创建kube的配置文件yaml 继续使用上次实验环境 ht ...

  4. kubernetes集群中的pause容器

    昨天晚上搭建好了k8s多主集群,启动了一个nginx的pod,然而每启动一个pod就伴随这一个pause容器,考虑到之前在做kubelet的systemd unit文件时有见到: 1 2 3 4 5 ...

  5. ingress-nginx 的使用 =》 部署在 Kubernetes 集群中的应用暴露给外部的用户使用

    文章转载自:https://mp.weixin.qq.com/s?__biz=MzU4MjQ0MTU4Ng==&mid=2247488189&idx=1&sn=8175f067 ...

  6. 在Kubernetes集群中使用calico做网络驱动的配置方法

    参考calico官网:http://docs.projectcalico.org/v2.0/getting-started/kubernetes/installation/hosted/kubeadm ...

  7. Kubernetes集群中Service的滚动更新

    Kubernetes集群中Service的滚动更新 二月 9, 2017 0 条评论 在移动互联网时代,消费者的消费行为已经“全天候化”,为此,商家的业务系统也要保持7×24小时不间断地提供服务以满足 ...

  8. 【转载】浅析从外部访问 Kubernetes 集群中应用的几种方式

    一般情况下,Kubernetes 的 Cluster Network 是属于私有网络,只能在 Cluster Network 内部才能访问部署的应用.那么如何才能将 Kubernetes 集群中的应用 ...

  9. Kubernetes集群中Jmeter对公司演示的压力测试

    6分钟阅读 背景 压力测试是评估Web应用程序性能的有效方法.此外,越来越多的Web应用程序被分解为几个微服务,每个微服务的性能可能会有所不同,因为有些是计算密集型的,而有些是IO密集型的. 基于微服 ...

随机推荐

  1. Python基础之简介

    参考原文 廖雪峰Python教程 什么是Python? Python是一种计算机程序设计语言,又被称为胶水语言,它是高级的编程语言. Python能干什么? 网站后端程序员.自动化运维.数据分析师.游 ...

  2. Java基础——二分法

    BinarySearch 二分法查找,顾名思义就是要将数据每次都分成两份然后再去找到你想要的数据,我们可以这样去想,二分法查找很类似与我们平时玩的猜价格游戏,当你报出一个价格时裁判会告诉你价格相对于真 ...

  3. linux shell学习笔记二---自定义函数(定义、返回值、变量作用域)介绍

    linux shell 可以用户定义函数,然后在shell脚本中可以随便调用.下面说说它的定义方法,以及调用需要注意那些事项. 一.定义shell函数(define function) 语法: [ f ...

  4. 诊断:ORA-38760: This database instance failed to turn on flashback database

    $ oerr ora 38760 38760, 00000, "This database instance failed to turn on flashback database&quo ...

  5. P1541 乌龟棋 题解(洛谷,动态规划递推)

    题目:P1541 乌龟棋 感谢大神的题解(他的写的特别好) 写一下我对他的代码的理解吧(哎,蒟蒻就这能这样...) 代码: #include<bits/stdc++.h> #define ...

  6. css--小白入门篇5

    一.行高和字号 1.1 行高 CSS中,所有的行,都有行高.盒模型的padding,绝对不是直接作用在文字上的,而是作用在“行”上的. 1 line-height: 40px; 文字,是在自己的行里面 ...

  7. Re0:DP学习之路 饭卡 HDU - 2546

    解法 01背包变式,首先贪心的想一下如果要保证余额最小那么就需要用相减后最小的钱减去之前最大的价格,且得保证这个钱在5元以上 对于寻找如何减最多能包含在5元以上,这里用01背包 我们把价钱看做体积装进 ...

  8. (远程调试)-idea

    远程调试 1.开启远程调试的端口 tomcat示例: catalina.bat jpda start

  9. 49. spring boot日志升级篇—理论【从零开始学Spring Boot】

    我们之前在其中的一篇文章介绍过如何在spring boot中使用日志记录SLF4J. Spring Boot在所有内部日志中使用Commons Logging,但是默认配置也提供了对常用日志的支持,如 ...

  10. C#中的定制特性(Attributes)

    C#中的定制特性(Attributes) 介绍 Attributes是一种新的描述信息,我们既可以使用attributes来定义设计期信息(例如:帮助文件.文档的URL),还可能用attributes ...