003.kubernets对于namespace的管理
一 Kuberbetes的架构简单介绍
1.1 云计算的传统分类

1.2 kubernetes基础架构

工作机制

- 用户通过kubectl向api-server提交需要运行的pod描述
- api-server接收请求并将相关描述存储到etcd
- scheduler 监控api-server拿到相关描述信息,开始扫描node节点,找到满足条件的node节点,将Pod与node的对应关系写入etcd
- Kubelet定时请求api-server,拿到需要在本机运行的Pod信息,运行起来
- 用户提交RC描述,rc控制器监视集群中的容器并保持数量
- 用户提交service描述,由kube-proxy负责具体的工作流量转发
1.3 创建一个容器的步骤
- 镜像从哪里获取以及版本号
- 镜像仓库是否需要认证,如果需要,请提供认证密钥
- 容器如果挂掉了,是否需要重启
- 容器是否需要挂载持久存储
- 是否为容器指定自己的dns
- 是否指定容器运行的节点
- 是否需要传递环境变量
- 容器启动之后,是否需要执行某些操作
- 容器在销毁时,是否需要执行某些操作
- 在什么情况下,我们认为容器是存活的
- 在什么情况下,我们认为容器是可以提供服务的
- 在容器启动之前,是否还需要做一些准备工作
在前面已经安装完成一个kubernetes的集群
[root@docker-server1 ~]# kubectl get nodes
NAME STATUS ROLES AGE VERSION
192.168.132.131 Ready master 105m v1.17.0
192.168.132.132 Ready <none> 92m v1.17.0
192.168.132.133 Ready <none> 90m v1.17.0
[root@docker-server1 ~]# kubectl get pods -n kube-system
NAME READY STATUS RESTARTS AGE
coredns-6955765f44-8kxdg 1/1 Running 0 108m
coredns-6955765f44-m66bw 1/1 Running 0 108m
etcd-192.168.132.131 1/1 Running 0 108m
kube-apiserver-192.168.132.131 1/1 Running 0 108m
kube-controller-manager-192.168.132.131 1/1 Running 0 108m
kube-flannel-ds-amd64-dbckr 1/1 Running 0 95m
kube-flannel-ds-amd64-fg972 1/1 Running 0 93m
kube-flannel-ds-amd64-m9lgq 1/1 Running 0 104m
kube-proxy-7xgt9 1/1 Running 0 95m
kube-proxy-k8kb7 1/1 Running 0 93m
kube-proxy-q867d 1/1 Running 0 108m
kube-scheduler-192.168.132.131 1/1 Running 0 108m
kubectl 主要管理集群中的资源对象,容器也是资源
1.4 常用资源介绍
Node
Namespace
Container
Pod
Label
Annotations
ReplicaController
ReplicaSet
Deployment
HPA
Service
Job
资源对象:分为集群级别资源(node,pv,clusterrole)和命名空间级别资源(pods)
node:节点,node不属于任何命名空间,是集群资源
二 namespace的简单操作
集群安装的时候会自动帮助我们创建几个namesapce,查看namespace
2.1 查看
[root@docker-server1 ~]# kubectl get ns
NAME STATUS AGE
default Active 137m
kube-node-lease Active 137m
kube-public Active 137m
kube-system Active 137m
kubernetes-dashboard Active 82m
kubectl get pods -n kube-system 这个操作就是查看kube-system 这个命名空间所有的容器
当我们执行kubectl get pods,不指定命名空间的话 ,就去查询default这个默认的命名空间,但是没任何容器运行
[root@docker-server1 ~]# kubectl get pods
No resources found in default namespace.
2.3 创建一个命名空间
[root@docker-server1 ~]# kubectl create ns projecta
也可以通过提交资源描述文件进行创建
[root@docker-server1 ~]# kubectl get ns
NAME STATUS AGE
default Active 171m
kube-node-lease Active 171m
kube-public Active 171m
kube-system Active 171m
kubernetes-dashboard Active 116m
projecta Active 6s
2.3 删除namespace
[root@docker-server1 ~]# kubectl delete ns projecta

[root@docker-server1 ~]# kubectl get ns
NAME STATUS AGE
default Active 173m
kube-node-lease Active 173m
kube-public Active 173m
kube-system Active 173m
kubernetes-dashboard Active 117m
命名空间的命名规范
[root@docker-server1 ~]# kubectl create ns Projecta
The Namespace "Projecta" is invalid: metadata.name: Invalid value: "Projecta": a DNS-1123 label must consist of lower case alphanumeric characters or '-', and must start and end with an alphanumeric character (e.g. 'my-name', or '123-abc', regex used for validation is '[a-z0-9]([-a-z0-9]*[a-z0-9])?')
从这里就可以看到规则
2.4 资源描述文件操作namespace
[root@docker-server1 ~]# mkdir -p /yamls/namespace
[root@docker-server1 ~]# cd /yamls/namespace
[root@docker-server1 namespace]# vim projectb.yaml
apiVersion: v1 #API版本
kind: Namespace #资源类型
metadata:
name: projectb #命名空间名称
[root@docker-server1 namespace]# kubectl apply -f projectb.yaml
[root@docker-server1 namespace]# kubectl get ns
NAME STATUS AGE
default Active 3h18m
kube-node-lease Active 3h18m
kube-public Active 3h18m
kube-system Active 3h18m
kubernetes-dashboard Active 142m
projectb Active 19s
删除命名空间
[root@docker-server1 namespace]# kubectl delete -f projectb.yaml
[root@docker-server1 namespace]# kubectl get ns
NAME STATUS AGE
default Active 3h18m
kube-node-lease Active 3h18m
kube-public Active 3h18m
kube-system Active 3h18m
kubernetes-dashboard Active 142m
命名空间简单介绍到这里
博主声明:本文的内容来源主要来自誉天教育晏威老师,由本人实验完成操作验证,需要的博友请联系誉天教育(http://www.yutianedu.com/),获得官方同意或者晏老师(https://www.cnblogs.com/breezey/)本人同意即可转载,谢谢!
003.kubernets对于namespace的管理的更多相关文章
- kubernets之namespace
一 命名空间的介绍以及作用 1 概念 为了方便不同部门之间对kubernets集群的使用,并且对其进行有效的隔离,kubernets提供了一种资源隔离手段,通过将各种不同资源分组到 一个区域,并且统 ...
- 使用kubectl管理Kubernetes(k8s)集群:常用命令,查看负载,命名空间namespace管理
目录 一.系统环境 二.前言 三.kubectl 3.1 kubectl语法 3.2 kubectl格式化输出 四.kubectl常用命令 五.查看kubernetes集群node节点和pod负载 5 ...
- 使用TreeView+ListBox+TxtBox 资料管理器
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(86)-日程管理-fullcalendar插件用法
前言 本文分享fullcalendar用法,最后面提供代码下载 说到日程管理,基于JQuery的插件FullCalendar当之无愧,完整的API稳定和调用方式,非常易于扩展!可以用于系统的个人历程管 ...
- Docker集群管理工具 - Kubernetes 部署记录 (运维小结)
一. Kubernetes 介绍 Kubernetes是一个全新的基于容器技术的分布式架构领先方案, 它是Google在2014年6月开源的一个容器集群管理系统,使用Go语言开发,Kubernete ...
- fullcalendar插件日程管理
日程管理-fullcalendar插件用法 前言 本文分享fullcalendar用法,最后面提供代码下载 说到日程管理,基于JQuery的插件FullCalendar当之无愧,完整的API稳定和 ...
- Nacos(六):多环境下如何“管理”及“隔离”配置和服务
前言 前景回顾: Nacos(五):多环境下如何"读取"Nacos中相应环境的配置 Nacos(四):SpringCloud项目中接入Nacos作为配置中心 现如今,在微服务体系中 ...
- docker集群——K8s简介
Kubernetes是谷歌开源的容器集群管理系统,是Google多年大规模容器管理技术Borg的开源版本,主要功能包括: 基本容器的应用部署.维护和滚动升级: 负载均衡和服务发现: 跨机器和跨地区的集 ...
- Kubernetes 组件简介
关于Kubernetes是什么??? Kubernetes是致力于提供跨主机集群的自动部署.扩展.高可用以及运行应用程序容器的平台. Kubernets集群组成有哪些??? k8s由master和no ...
随机推荐
- OO 第二单元
前言 第二单元 OO 作业的主题是多线程,课程组通过了电梯调度这个经典问题考察了多线程的调度. 从第五次作业到第七次作业的迭代为,单部多线程可捎带电梯,多部多线程可捎带调度电梯(电梯属性相同) ...
- 机器学习--如何理解Accuracy, Precision, Recall, F1 score
当我们在谈论一个模型好坏的时候,我们常常会听到准确率(Accuracy)这个词,我们也会听到"如何才能使模型的Accurcy更高".那么是不是准确率最高的模型就一定是最好的模型? 这篇博文会向大家解释 ...
- JVM经典垃圾收集器
这个关系不是一成不变的,由于维护和兼容性测试的成本,在JDK 8时将Serial+CMS. ParNew+Serial Old这两个组合声明为废弃(JEP 173),并在JDK 9中完全取消了这些 ...
- Go-21-结构体
Go语言的面向对象 其他编程语言大多使用关键字"类"(class)来定义封装对象,表示该类的具体特征,然而Go并不是一个纯面向对象的编程语言.Go语言采用更灵活的"结构体 ...
- 基本dos命令
Dos命令 打开cmd方法 开始---windows系统---命令提示符 win键 + R键 输入cmd --- 回车 按住Shift键---右击任意文件夹-----单击在此处打开PowerShell ...
- Java集合原理分析和知识点大杂烩(多图初学者必备!!)
一.数据结构 数据结构就是计算机存储.组织数据的方式. 在计算机科学中,算法的时间复杂度是一个函数,它定性描述了该算法的运行时间,常用O符号来表述. 时间复杂度是同一问题可用不同算法解决, ...
- 什么是JWT?原理是什么?
什么是JWT JWT 是Json Web Tokens的简称.用百度上面的解释讲,是目前流行的跨域认证解决方案,一种基于JSON的.用于在网络上声明某种主张的令牌(token). JTW原理 jwt验 ...
- 1.Java开发环境搭建
Java开发环境搭建 date: 2021-4-7 19:17:30 JDK安装 下载所需的JDK版本,点此下载JDK8的安装包 挑选对应的系统版本 配置环境变量 打开高级系统设置,找到系统变量 在系 ...
- 关于Number、parseInt、isNaN转化参数
1.首先,关于NaN的相等判断 alert(NaN==NaN) //返回的是false: 2.isNaN 确定这个参数是否是数值或者是否可以被转化为数值:NaN是not a number 的缩写,所以 ...
- (转载)springboot + rabbitmq发送邮件(保证消息100%投递成功并被消费)
转载自https://www.jianshu.com/p/dca01aad6bc8 一.先扔一张图 image.png 说明: 本文涵盖了关于RabbitMQ很多方面的知识点, 如: 消息发送确认 ...