1. 检查kubernetes 组件是否正常运行。

[root@c720120 ~]# kubectl get cs

NAME                 STATUS    MESSAGE              ERROR

scheduler            Healthy   ok                  

controller-manager   Healthy   ok                  

etcd-0               Healthy   {"health": "true"}  

etcd-1               Healthy   {"health": "true"}  

etcd-2               Healthy   {"health": "true"}

2. 检查kubernetes master状态

[root@c720120 ~]# kubectl cluster-info

Kubernetes master is running at https://192.168.20.134:6443

Heapster is running at https://192.168.20.134:6443/api/v1/namespaces/kube-system/services/heapster/proxy

KubeDNS is running at https://192.168.20.134:6443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy

monitoring-grafana is running at https://192.168.20.134:6443/api/v1/namespaces/kube-system/services/monitoring-grafana/proxy

monitoring-influxdb is running at https://192.168.20.134:6443/api/v1/namespaces/kube-system/services/monitoring-influxdb/proxy

To further debug and diagnose cluster problems, use 'kubectl cluster-info dump'.

3. 检查所有节点是否准备好。

[root@c720120 ~]# kubectl get nodes

NAME               STATUS     ROLES     AGE       VERSION

c720120.xiodi.cn   Ready      master    23d       v1.10.3

c720121.xiodi.cn   Ready      master    23d       v1.10.3

c720128.xiodi.cn   Ready      <none>    23d       v1.10.3

c720129.xiodi.cn   Ready      <none>    23d       v1.10.3

4. 运行一个nginx的容器案例

[root@c720120 ~]# kubectl run my-first-nginx --image=nginx --replicas=2 --port=80

deployment.apps "my-first-nginx" created

5. 查看所有的pods.

[root@c720120 ~]# kubectl get pods

NAME                                READY     STATUS    RESTARTS   AGE

alpine-interactive-669f6844-dxns9   1/1       Running   3          21d

flask-7bdd449f7f-kj2z9              1/1       Running   1          2d

my-first-nginx-6c9fb6f56b-f8kxd     1/1       Running   0          52s

my-first-nginx-6c9fb6f56b-k5vdz     1/1       Running   0          52s

nginx                               1/1       Running   2          22d

6. 查看所有的deployment

[root@c720120 ~]# kubectl get deployment

NAME                 DESIRED   CURRENT   UP-TO-DATE   AVAILABLE   AGE

alpine-interactive   1         1         1            1           21d

flask                1         1         1            1           21d

my-first-nginx       2         2         2            2           3m

7. 映射端口到外部,让用户能够访问该服务

[root@c720120 ~]# kubectl expose deployment my-first-nginx --port=80 --type=LoadBalancer

service "my-first-nginx" exposed

8. 查看发布的服务

[root@c720120 ~]# kubectl get services

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

kubernetes       ClusterIP      10.96.0.1     <none>        443/TCP        23d

my-first-nginx   LoadBalancer   10.97.75.31   <pending>     80:31158/TCP   3m

9. 停止应用

[root@c720120 ~]# kubectl delete deployment my-first-nginx

deployment.extensions "my-first-nginx" deleted

[root@c720120 ~]# kubectl delete service my-first-nginx

service "my-first-nginx" deleted

10. 可以查看创建的服务详细信息

[root@c720120 ~]# kubectl describe service my-first-nginx

Name:                     my-first-nginx

Namespace:                default

Labels:                   run=my-first-nginx

Annotations:              <none>

Selector:                 run=my-first-nginx

Type:                     LoadBalancer

IP:                       10.111.128.100

Port:                     <unset>  80/TCP

TargetPort:               80/TCP

NodePort:                 <unset>  30066/TCP

Endpoints:                10.244.3.20:80,10.244.4.8:80

Session Affinity:         None

External Traffic Policy:  Cluster

Events:                   <none>

11. 用浏览器进行校验下服务

在kubernetes运行一个容器案例的更多相关文章

  1. 运行 Docker 容器时的安全风险:别丢了你的套接字

    我们都遇到过这种情况:你只是想尝试一段命令行,但安装进程却如同抵押贷款申请那般繁琐.如果不是强制要求完成这么多步骤,你的开发环境会被永远不会再使用的库弄乱.自然, Docker 来了以后,你惊异地发现 ...

  2. kubernetes之多容器pod以及通信

    系列目录 容器经常是为了解决单一的,窄范围的问题,比如说微服务.然而现实中,一些复杂问题的完成往往需要多个容器.这里我们讨论一下如何把多个容器放在同一个pod里以及容器间的通信 什么是pod pod是 ...

  3. 运行docker容器镜像

    docker容器可以理解为在盒中运行的进程. 这个盒包含了该进程运行所必须的资源,包括文件系统.系统类库.shell 环境等等. 但这个盒默认是不会运行任何程序的. 1.运行镜像之前,可以先查看本地有 ...

  4. kubernetes 每个node上只能运行一个副本DaemonSet

    每个node上只能运行一个副本: apiVersion: extensions/v1beta1 kind: DaemonSet #使用DaemonSet的方式运行 metadata: name: ku ...

  5. Kubernetes 实战 —— 03. pod: 运行于 Kubernetes 中的容器

    介绍 pod P53 pod 是 Kubernetes 中最为重要的核心概念,而其他对象仅仅用于 pod 管理. pod 暴露或被 pod 使用. pod 是一组并置的容器,代表了 Kubernete ...

  6. 通过运行一个tomcat容器来记录下初学docker常用的几个命令---容器篇

    1.查看容器列表 显示正在运行的容器: [root@localhost HMK]# docker ps 显示所有容器,包括未运行的: [root@localhost HMK]# docker ps - ...

  7. 使用Minikube运行一个本地单节点Kubernetes集群(阿里云)

    使用Minikube运行一个本地单节点Kubernetes集群中使用谷歌官方镜像由于某些原因导致镜像拉取失败以及很多人并没有代理无法开展相关实验. 因此本文使用阿里云提供的修改版Minikube创建一 ...

  8. 【云计算】K8S DaemonSet 每个node上都运行一个pod

    Kubernetes容器集群中的日志系统集成实践 Kubernetes是原生的容器编排管理系统,对于负载均衡.服务发现.高可用.滚动升级.自动伸缩等容器云平台的功能要求有原生支持.今天我分享一下我们在 ...

  9. 基于Kubernetes构建企业容器云

    前言 团队成员有DBA.运维.Python开发,由于需要跨部门向公司私有云团队申请虚拟机, 此时我在思考能否在现有已申请的虚拟机之上,再进行更加细粒度的资源隔离和划分,让本团队的成员使用, 也就是在私 ...

随机推荐

  1. Qt ------ 主事件循环与 QEventLoop

    1.事件循环一般用exec()函数开启.QApplicaion::exec().QMessageBox::exec()都是事件循环.其中前者又被称为主事件循环. 事件循环首先是一个无限“循环”,程序在 ...

  2. scp 从本地往线上传文件

    scp /home/wwwroot/default/tf_ment.sql root@IP:/home/wwwroot/default/

  3. eclipse/myeclipse添加插件3种方式

    个人比较偏爱links的方式,以下方式eclipse/myeclipse均适合 1.links方式 在eclipse目录先新建links目录,新建一个xx.link(例如:android.link) ...

  4. dhtmlx3.6 grid列头合并

    mygrid.setHeader("序号,操作人员,发药,#cspan,审核,#cspan,数量小计,金额小计");mygrid.attachHeader(["#rspa ...

  5. python 常用模块之ConfigParser

    在程序中使用配置文件来灵活的配置一些参数是一件很常见的事情,配置文件的解析并不复杂,在Python里更是如此,在官方发布的库中就包含有做这件事情的库,那就是ConfigParser, Python C ...

  6. Nodejs文件监控chokidar

    最近有个需求是扫描用例,用例是放在svn上,如果每次扫描都去遍历目录的话会有占用太多的io,所以想着用文件监控,有文件变化时只对该文件进行操作. Nodejs里的 chokidar 模块可以更好的对文 ...

  7. select多选框

    select多选框 效果: 代码: <HTML> <HEAD> <TITLE>选择下拉菜单</TITLE> <meta http-equiv=&q ...

  8. 【洛谷 P4134】 [BJOI2012]连连看(费用流)

    题目链接 首先是可以\(O(n^2)\)枚举出所有符合要求的点对的,然后考虑建图. 还是拆点把每个点拆成入点和出点,源点连入点,出点连汇点,流量都是1,费用都是0. 然后对于没对符合要求的\((x,y ...

  9. Linux 下解决安装多个node冲突的问题(重新安装node)

    一个系统中不经意安装了多个node版本,结果更新后还是原来的版本,下面思考一下解决办法: 敲黑板: 1. nodejs 用 包管理器安装一般在 /usr/local/bin 2. 查看当前目录下的no ...

  10. ValueList用法

    ValueList的OverView 概述 在很多情况下,使用JDBC是很繁琐的,有很多方法可以替换JDBC,比如JDO.Hibernate等. 即使在从service中接收POJO的List的解决方 ...