1.1 先跑起来

  k8s官网已经为大家准备好了一个现成的最小可用系统。

   https://kubernetes.io/docs/tutorials/kubernetes-basics/

1.2 创建K8s集群

  https://kubernetes.io/docs/tutorials/kubernetes-basics/create-cluster/cluster-interactive/

  全屏后就是一个模拟的linux系统。

  kubectl get nodes

  kubectl get pods

  kubectl cluster-info            // 查看集群信息

  kubectl cluster-info dump // 集群详细信息

1.3 部署应用

  kubectl run --help :  这个命令用来部署一个应用

  kubectl run kubernetes-bootcamp --image=docker.io/jocatalin/kubernetes-bootcamp:v1 --port=8080            // 启动pod

  --image: 指定镜像。

  --port : 设置应用对外服务的端口。

  pod:  紧密相关的一组容器放到一个Pod中,同一个Pod中的容器共享IP地址和Port空间。

上面命令运行后:使用    kubectl get deployment

                     NAME                     DESIRED          CURRENT        UP-TO-DATE            AVAILABLE            AGE
                   kubernetes-bootcamp     1                   1                           1                             1                            11s

1.4  访问应用

  默认情况下,所有Pod只能在集群内部访问。对于上边的例子,要访问应用只能直接访问8080端口。为了能从外部访问应用,我们需要将容器的

8080端口映射到节点的端口。

  kubectl expose        // 将资源(deployment、service、replica setreplication controllerpod )暴露为新的Kubernetes Service。并使用该资源的选择器作

为指定端口上新服务的选择器。

    kubectl expose deployment/kubernetes-bootcamp --type="NodePort" --port=8080
      service/kubernetes-bootcamp exposed

然后查看services:

$ kubectl get services
  NAME                                 TYPE       CLUSTER-IP      EXTERNAL-IP     PORT(S)          AGE
  kubernetes                          ClusterIP      10.96.0.1           <none>                 443/TCP         10m
  kubernetes-bootcamp          NodePort   10.108.24.178    <none>          8080:31385/TCP    2m

NodePort:   表示外界可以通过访问node port 的31385(这个是随机的)访问这个服务。

 Service:可以暂时理解为端口映射。

  $ hostname                                // 查看当前的host name
   minikube
  $ curl minikube:31385              // 访问服务
           Hello Kubernetes bootcamp! | Running on: kubernetes-bootcamp-56cdd766d-rwrs6 | v=1

 1.5 scale 应用

  $ kubectl scale deployments/kubernetes-bootcamp --replicas=3           // 增加副本数量
    deployment.extensions/kubernetes-bootcamp scaled
  $ kubectl get deployment
    NAME                              DESIRED     CURRENT   UP-TO-DATE  AVAILABLE   AGE
    kubernetes-bootcamp              3                  3                 3                     3                19m

  这个时候再看

    kubectl get pods, 发现是三个pods在运行:
      NAME                                                   READY              STATUS               RESTARTS                     AGE
kubernetes-bootcamp-56cdd766d-jfhgh                     1/1                    Running                      0                                 2m
kubernetes-bootcamp-56cdd766d-m2df7                   1/1                    Running                      0                                 2m
kubernetes-bootcamp-56cdd766d-rwrs6                    1/1                    Running                      0                                 22m

然后再访问service:  发现后端的请求被打散到不同的容器,这样就实现了负载均衡。

  $ curl minikube:31385
    Hello Kubernetes bootcamp! | Running on: kubernetes-bootcamp-56cdd766d-jfhgh | v=1
  $ curl minikube:31385
    Hello Kubernetes bootcamp! | Running on: kubernetes-bootcamp-56cdd766d-jfhgh | v=1
  $ curl minikube:31385
    Hello Kubernetes bootcamp! | Running on: kubernetes-bootcamp-56cdd766d-m2df7 | v=1
  $ curl minikube:31385
    Hello Kubernetes bootcamp! | Running on: kubernetes-bootcamp-56cdd766d-jfhgh | v=1
  $ curl minikube:31385
    Hello Kubernetes bootcamp! | Running on: kubernetes-bootcamp-56cdd766d-m2df7 | v=1

1.6 滚动更新(rolling update)

  当前使用image的版本为v1, 执行如下命令将其升级到v2:

  $ kubectl set image deployments/kubernetes-bootcamp kubernetes-bootcamp=jocatalin/kubernetes-bootcamp:v2
    deployment.extensions/kubernetes-bootcamp image updated

上面的更改立即生效,pod会逐渐被清除,新的pod逐渐启动。

   要想回退到原来的版本: kubectl rollout undo deployments/kubernetes-bootcamp

  

    

第一章 先把Kubernetes跑起来的更多相关文章

  1. [转] VS2015中跑OpenGL红宝书第八版的第一章示例代码,运行

    Ori Article Link OpenGL的东西快忘光了,把角落的第八版红宝书拿出来复习一下 从书中的地址下了个示例代码结果新系统(Win10+VS2015)各种跑不起来,懊恼之后在网上疯狂搜索资 ...

  2. 第一章 Kubernetes入门

    第一章 Kubernetes入门 kubernetes是基于容器技术的分布式架构领先方案,是一个完备的分布式系统支撑平台. kubernetes带来的好处:1)全面拥抱微服务:2)统可以随时随地整体“ ...

  3. 白话SpringCloud | 第一章:什么是SpringCloud

    前言 作为SpringCloud的正式第一章,我们先来简单了解下SpringCloud相关知识点吧,内容可能比较多. 何为微服务 传统单体架构 服务化架构 微服务架构 什么是SpringCloud 核 ...

  4. 日暮·第一章·决斗

    日暮 第一章 决斗   泉州府,位于帝国的东南沿海,在数百年前,这里已是帝国最大的通商口岸之一,其一城之繁荣喧哗足以与异邦小国的都城相媲美,无数的人曾经来到这里,追逐财富,梦想,女人以及所有他们认为可 ...

  5. PRML读书会第一章 Introduction(机器学习基本概念、学习理论、模型选择、维灾等)

    主讲人 常象宇 大家好,我是likrain,本来我和网神说的是我可以作为机动,大家不想讲哪里我可以试试,结果大家不想讲第一章.估计都是大神觉得第一章比较简单,所以就由我来吧.我的背景是统计与数学,稍懂 ...

  6. 翻译学python---《Learn Python the hard Way》---第一章 绪论

    打算学习python,但是又不想单纯地看书或是写个小项目,干脆引入很流行的翻译学习法来学习吧-         在论坛上看到了国外的一本<Learn Python the hard Way> ...

  7. 第一章、C#委托和事件(Delegate、Event、EventHandler、EventArgs)

    第一章.C#委托和事件(Delegate.Event.EventHandler.EventArgs) 分类: 学习笔记-C#网络编程2012-12-08 14:10 7417人阅读 评论(3) 收藏  ...

  8. 按照鬼哥学so变化,四,第一章的例子

    跟随鬼哥伦比亚科学so变化,四.第一章的例子 图纸/文化  听鬼哥说故事 ---------------------------------------------切割线--------------- ...

  9. (第一章)对程序员来说CPU是什么

    这几天,看到一本书,<程序是怎么跑起来的>,觉得之前都没有完整的看完一本书,现在要从这本书开始,慢慢的培养自己写读书笔记的习惯,不能度过去就忘了. 学习是一个螺旋上升的过程,不要指望一下子 ...

随机推荐

  1. SQL2008R2 收缩数据库问题 - 日志文件不变小

    数据库的日志文件(*.ldf)越来越大,怎么办? 收缩吧.收缩日志文件的操作真不简单哟,还跟数据库的恢复模式有关啊. 一.“简单恢复模式”时的日志收缩 1. 截断日志 当数据库的恢复模式为“简单”的时 ...

  2. this指针逃逸问题

    this指针逃逸是指在构造函数返回之前,其他线程已经就持有了该对象的应用,产生的结果自然和预期可能会产生差异.常见的this指针逃逸,在并发编程实战一书中,作者指出:在构造函数中注册事件监听,在构造函 ...

  3. mysql报错注入手工方法

    以前觉得报错注入有那么一长串,还有各种concat(),rand()之类的函数,不方便记忆和使用,一直没怎么仔细的学习过.这次专门学习了一下,看了一些大牛的总结,得到一些经验,特此记录下来,以备后续巩 ...

  4. 20165202 2017-2018-2《Java程序设计》课程总结

    每周作业链接汇总 ++预备作业一:我期待的师生关系++ ++预备作业二:学习基础和C语言基础调查++ ++预备作业三:linux安装及学习++ ++第一周作业:初识JAVA,注册码云并配置Git++ ...

  5. ss-libev 源码解析udp篇 (3)

    本篇分析server_recv_cb,这个是udp转发中最重要的函数. server_recv_cb: 当ss-local或ss-server接收到来自前端的udp数据包时调用.这个函数代码比较多,除 ...

  6. Sublime Text 2 设置文件详解(转)

    Sublime Text 2是那种让人会一眼就爱上的编辑器,不仅GUI让人眼前一亮,功能更是没的说,拓展性目前来说也完全够用了,网上介绍软件的文章和推荐插件的文章也不少,而且很不错,大家可以去找找自己 ...

  7. CSS琐碎[1]

    (1)letter-spacing 设置字符间局,用长度指定(百分比兼容性不好) 没有间距 间距6px API:http://gucong3000.github.io/css-book/propert ...

  8. Luogu 3806 点分治1

    Luogu 3806 点分治 要分清楚各个函数的作用及互相调用的关系. 因为是无根树,找重心的时候,父亲一边的所有节点也可以看做是一颗子树. #include<bits/stdc++.h> ...

  9. HDU2473 Junk-Mail Filter 【可删除的并查集】

    HDU2473 Junk-Mail Filter Problem Description Recognizing junk mails is a tough task. The method used ...

  10. UWP 流畅设计中的光照效果(容易的 RevealBorderBrush 和不那么容易的 RevealBackgroundBrush)

    在 Windows 10.0.16299 中,RevealBrush 被引入,可以实现炫酷的鼠标滑过高亮效果和点击光照.本文将告诉大家如何完整地实现这样的效果. Reveal 的效果(自带) 在微软官 ...