当前位置: 首页 > news >正文

网站建设维护招聘电子商务网站建设说课稿

网站建设维护招聘,电子商务网站建设说课稿,中山企业网站建设定制,产品推广计划一、yaml文件简介 Kubernetes只支持YAML和JSON格式创建资源对象,JSON格式用于接口之间消息的传递,适用于开发;YAML格式用于配置和管理,适用于云平台管理,YAML是一种简洁的非标记性语言。 1)yaml的语法规则&…

一、yaml文件简介
Kubernetes只支持YAML和JSON格式创建资源对象,JSON格式用于接口之间消息的传递,适用于开发;YAML格式用于配置和管理,适用于云平台管理,YAML是一种简洁的非标记性语言。
1)yaml的语法规则:
大小写敏感
使用缩进表示层级关系
缩进时不允许使用Tal键,只允许使用空格
缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
”#” 表示注释,从这个字符一直到行尾,都会被解析器忽略
注:- - - 为可选的分隔符 ,当需要在一个文件中定义多个结构的时候需要使用
2)在Kubernetes中,只需要知道两种结构类型即可:
Lists
Maps
2.1)YAML Maps
Map顾名思义指的是字典,即一个Key:Value 的键值对信息。例如:

---
apiVersion: v1
kind: Pod

上述内容表示有两个键apiVersion和kind,分别对应的值为v1和Pod。
Maps的value既能够对应字符串也能够对应一个Maps。例如:

---
apiVersion: v1
kind: Pod
metadata:name: kube100-sitelabels:app: web

注:上述的YAML文件中,metadata这个KEY对应的值为一个Maps,而嵌套的labels这个KEY的值又是一个Map。实际使用中可视情况进行多层嵌套。
2.2)YAML Lists
Lists的子项也可以是Maps,Maps的子项也可以是List,例如:

---
apiVersion: v1
kind: Pod
metadata:name: nginxlabels:app: web
spec:containers:- name: front-endimage: nginxports:- containerPort: 80- name: flaskapp-demoimage: jcdemo/flaskappports: 8080

二、yaml常见语法
1)apiVersion
查看当前所有可用的API版本

[root@master1 ~]# kubectl api-versions
admissionregistration.k8s.io/v1
apiextensions.k8s.io/v1
apiregistration.k8s.io/v1
apps/v1
authentication.k8s.io/v1
authorization.k8s.io/v1
autoscaling/v1
autoscaling/v2
batch/v1
certificates.k8s.io/v1
coordination.k8s.io/v1
crd.projectcalico.org/v1
discovery.k8s.io/v1
events.k8s.io/v1
flowcontrol.apiserver.k8s.io/v1beta2
flowcontrol.apiserver.k8s.io/v1beta3
networking.k8s.io/v1
node.k8s.io/v1
policy/v1
rbac.authorization.k8s.io/v1
scheduling.k8s.io/v1
storage.k8s.io/v1
v1

常用apiversion:
v1: Kubernetes API的稳定版本,包含很多核心对象:pod、service等。
apps/v1: 包含一些通用的应用层的api组合,如:Deployments, RollingUpdates, and ReplicaSets。
batch/v1: 包含与批处理和类似作业的任务相关的对象,如:job、cronjob。
autoscaling/v1: 允许根据不同的资源使用指标自动调整容器。
networking.k8s.io/v1: 用于Ingress。
rbac.authorization.k8s.io/v1:用于RBAC。

2)kind
kind指定这个资源对象的类型,如 pod、deployment、statefulset、job、cronjob

3)metadata
metadata常用的配置项有 name,namespace,即配置其显示的名字与归属的命名空间。

4)spec
一个嵌套字典与列表的配置项,也是主要的配置项,支持的子项非常多,根据资源对象的不同,子项会有不同的配置。
如一个pod的spec配置:

apiVersion: v1 #必选,版本号,例如v1
kind: Pod #必选,Pod 
metadata: #必选,元数据 name: nginx #必选,Pod名称 labels: #自定义标签 app: nginx #自定义标签名字 
spec: #必选,Pod中容器的详细定义 containers: #必选,Pod中容器列表,一个pod里会有多个容器 - name: nginx #必选,容器名称 image: nginx #必选,容器的镜像名称 imagePullPolicy: IfNotPresent # [Always | Never | IfNotPresent] #获取镜像的策略 Alawys表示下载镜像 IfnotPresent表示优先使用本地镜像,否则下载镜像,Nerver表示仅使用本地镜像 ports: #需要暴露的端口库号列表 - containerPort: 80 #容器需要监听的端口号 restartPolicy: Always # [Always | Never | OnFailure]#Pod的重启策略,Always表示一旦不管以何种方式终止运行,kubelet都将重启,OnFailure表示只有Pod以非0退出码退出才重启,Nerver表示不再重启该Pod 

一个service 的 spec 的配置:

apiVersion: v1
kind: Service
metadata:name: service-hellolabels:name: service-hello
spec:type: NodePort      #这里代表是NodePort类型的,另外还有ingress,LoadBalancerports:- port: 80          #这里的端口和clusterIP(kubectl describe service service-hello中的IP的port)对应,即在集群中所有机器上curl 10.98.166.242:80可访问发布的应用服务。targetPort: 8080  #端口一定要和container暴露出来的端口对应,nodejs暴露出来的端口是8081,所以这里也应是8081protocol: TCPnodePort: 31111   # 所有的节点都会开放此端口30000--32767,此端口供外部调用。selector:run: nginx         #这里选择器一定要选择容器的标签

三、port详解
port:port是k8s集群内部访问service的端口,即通过clusterIP: port可以访问到某个service
nodePort:nodePort是外部访问k8s集群中service的端口,通过nodeIP: nodePort可以从外部访问到某个service。
targetPort:targetPort是pod的端口,从port和nodePort来的流量经过kube-proxy流入到后端pod的targetPort上,最后进入容器。
containerPort:containerPort是pod内部容器的端口,targetPort映射到containerPort。

四、yaml简单示例
1)deployment

apiVersion: apps/v1   # 1.9.0 之前的版本使用 apps/v1beta2,可通过命令 kubectl api-versions 查看
kind: Deployment    #指定创建资源的角色/类型
metadata:    #资源的元数据/属性name: nginx-deployment    #资源的名字,在同一个namespace中必须唯一
spec:replicas: 2    #副本数量2selector:      #定义标签选择器matchLabels:app: web-servertemplate:      #这里Pod的定义metadata:labels:    #Pod的labelapp: web-serverspec:        # 指定该资源的内容  containers:  - name: nginx      #容器的名字  image: nginx:1.12.1  #容器的镜像地址    ports:  - containerPort: 80  #容器对外的端口

2)pod

apiVersion: v1
kind: Pod  
metadata:  name: pod-redislabels:name: redis
spec: containers:- name: pod-redisimage: docker.io/redis  ports:- containerPort: 80 #容器对外的端口

3)service

apiVersion: v1  
kind: Service  # 指明资源类型是 service
metadata:  name: httpd-svc # service 的名字是 httpd-svclabels:  name: httpd-svc 
spec:  ports:  # 将 service 8080 端口映射到 pod 的 80 端口,使用 TCP 协议- port: 8080targetPort: 80  protocol: TCP  selector:  run: httpd # 指明哪些 label 的 pod 作为 service 的后端

4)vs

apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:annotations:devops-gitops-host1: minioname: minionamespace: paas-middleware
spec:gateways:- miniohosts:- minio.paas..cmit.cloudhttp:- match:- uri:prefix: /route:- destination:host: minio-headlessport:number: 1300

5)ingress

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:name: ingress-nginxnamespace: default
spec:ingressClassName: nginx       rules:- host: xx.xxx.com           http:paths:                   - backend:              service:             name: xxxxxx      prot:              number: 8080     path: /               pathTpye: Prefix       

五、Label与Selector
1)Label
Label是Kubernetes系列中另外一个核心概念。是一组绑定到K8s资源对象上的key/value对。同一个对象的labels属性的key必须唯一。label可以附加到各种资源对象上,如Node,Pod,Service,RC等。

通过给指定的资源对象捆绑一个或多个不用的label来实现多维度的资源分组管理功能,以便于灵活,方便地进行资源分配,调度,配置,部署等管理工作。
示例如下:
版本标签:“release” : “stable” , “release” : “canary”…
环境标签:“environment” : “dev” , “environment” : “production”
架构标签:“tier” : “frontend” , “tier” : “backend” , “tier” : “middleware”
分区标签:“partition” : “customerA” , “partition” : “customerB”…
质量管控标签:“track” : “daily” , “track” : “weekly”

2)Selector
Label selector是Kubernetes核心的分组机制,通过label selector客户端/用户能够识别一组有共同特征或属性的资源对象。符合这个标签的 Pod 会作为这个 Service 的 backend。

apiVersion: v1
kind: Service
metadata:name: hellolabels:app: hello
spec:ports:- port: 80targetPort: 80selector:app: hello

六、kubectl create和 kubectl apply二者区别
kubectl create:
kubectl create命令可创建新资源。 因此,如果再次运行该命令,则会抛出错误,因为资源名称在名称空间中应该是唯一的。

kubectl apply:
kubectl apply命令将配置应用于资源。 如果资源不在那里,那么它将被创建。 kubectl apply命令可以多次运行,配置若没有改变。 所以,pod没有改变。

http://www.15wanjia.com/news/194318.html

相关文章:

  • h5特效网站欣赏公司注册的流程与步骤
  • 品牌网站制作报价做网站用discuz还是wp
  • 各地平台网站二级网站如何一级域名
  • 建立一个自己的网站需要多少钱做国外营销型网站
  • 网站开发课设心得体会做餐厅网站的需求分析
  • 外贸正品网站口腔医院网站优化服务商
  • 网站可信查验网站建设费会计分录
  • 网站忘记备案宽屏网站背景
  • 百中搜网站建设旅游网页
  • 惠网 做网站九年级上册信息技术做网站
  • 柳州网站制作公司网站开发和前端是一样吗
  • 国内电商平台网站制作排行榜怎么查看网站是否被百度惩罚降权或者被k
  • 网站建设的大作业代码网站改版提示无需改版
  • 怎么在网站标头做图标郑州网站策划
  • 南昌住房城市建设支行官方网站网站架构的重要性
  • 建网站哪家好 优帮云宁波城乡建设局管方网站
  • 网站静态模板下载wordpress素材网
  • 智能建站和成品网站的区别wordpress安装悬浮qq
  • 纪检监察网站建设 讲话各学院二级网站建设通报
  • 金华城乡建设网站熊猫采集 wordpress 发布
  • 做一个营销型网站wordpress插件储存目录
  • 怎样在织梦网站建设目录北京网站建设工作
  • 做跨境的网站百度指数人群画像哪里查询
  • 商务网站建设中存在的问题用php做京东网站页面
  • 平泉市住房和城乡建设局网站手机网站表单页面制作
  • 西宁电商网站制作公司机刷推广软件
  • 学校集约网站建设婚庆行业网站建设方案1
  • 网站备案名称中国开头网站页面设计与实现
  • 沂源网站设计多语言版本网站
  • 北京响应式网站建设费用外链网盘网站