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

网站建设租房网模块一起做网店17普宁池尾

网站建设租房网模块,一起做网店17普宁池尾,房产微信营销方案,网站建设与用户体验目录 一、yml的简介二、手写yml文件进行配置三、使用yaml格式导出生成模板四、deployment.yaml文件详解五、Pod yaml文件详解六、Service yaml文件详解 一、yml的简介 Kubernetes 支持 YAML 和 JSON 格式管理资源对象 JSON 格式#xff1a;主要用于 api 接口之间消息的传递 Y… 目录 一、yml的简介二、手写yml文件进行配置三、使用yaml格式导出生成模板四、deployment.yaml文件详解五、Pod yaml文件详解六、Service yaml文件详解 一、yml的简介 Kubernetes 支持 YAML 和 JSON 格式管理资源对象 JSON 格式主要用于 api 接口之间消息的传递 YAML 格式用于配置和管理YAML 是一种简洁的非标记性语言内容格式人性化较易读 YAML 语法格式 ●大小写敏感 ●使用缩进表示层级关系 ●不支持Tab键制表符缩进只使用空格缩进 ●缩进的空格数目不重要只要相同层级的元素左侧对齐即可通常开头缩进两个空格 ●符号字符后缩进一个空格如冒号逗号短横杆-等 ●“—”表示YAML格式一个文件的开始用于分隔文件间 ●“#”表示注释 二、手写yml文件进行配置 查看 api 资源版本标签 kubectl api-versions查看每个资源所使用的 api 版本是什么 kubectl api-resources查看yml编写时的格式 可以加上内容的其他字段来显示可以写入什么内容 kubectl explain 来进行查看后续的内容写一个yaml文件demo mkdir /opt/demo cd demo/apiVersion: apps/v1 kind: Deployment metadata:name: mynginx-dznamespace: dznblabels:app: myapp-deployspec:replicas: 3selector:matchLabels:app: myapp-podtemplate:metadata:labels:app: myapp-podspec:containers:- name: myappimage: nginx:1.15.4ports:- containerPort: 80name: nginxprotocol: TCP- containerPort: 443name: nginx1protocol: TCP在创建的yaml文件里写入内容 创建资源对象 kubectl apply -f demo1-deploy.yaml删除资源对象 kubectl delete -f demo1-deploy.yaml查看创建的pod资源 kubectl get pods -o wide -n dznb1、创建service服务对外提供访问并测试 apiVersion: v1 kind: Service metadata:name: mynginx-servicenamespace: dznb spec:type: NodePortselector:app: myapp-podports:- name: nginxport: 8080targetPort: 80nodePort: 31000protocol: TCPexternalTrafficPolicy: Cluster什么是external-traffic-policy(外部流量转发策略) 在k8s的Service对象申明一条访问通道中有一个“externalTrafficPolicy”字段可以设置。有2个值可以设置Cluster或者Local。 1Cluster表示流量可以转发到其他节点上的Pod。 2Local表示流量只发给本机的Pod。 2、创建资源对象 kubectl create -f demo2-service.yaml3、查看创建的service kubectl get pods -n dznb -o widekubectl get svc -n dznb在浏览器输入 nodeIP:nodePort 即可访问 详解k8s中的port portport 是 k8s 集群内部访问service的端口即通过 clusterIP: port 可以从 Pod 所在的 Node 上访问到 service nodePortnodePort 是外部访问 k8s 集群中 service 的端口通过 nodeIP: nodePort 可以从外部访问到某个 service。 targetPorttargetPort 是 Pod 的端口从 port 或 nodePort 来的流量经过 kube-proxy 反向代理负载均衡转发到后端 Pod 的 targetPort 上最后进入容器。 containerPortcontainerPort 是 Pod 内部容器的端口targetPort 映射到 containerPort。 三、使用yaml格式导出生成模板 kubectl run --dry-runclient 打印相应的 API 对象而不执行创建 kubectl create deployment nginx-deploy -n dznb --imagenginx --port80 --replicas3 --dry-runclient查看生成yaml格式 kubectl create deployment nginx-deploy -n dznb --imagenginx --port80 --replicas3 --dry-runclient -o yaml查看生成json格式 kubectl create deployment nginx-deploy -n dznb --imagenginx --port80 --replicas3 --dry-runclient -o json使用yaml格式导出生成模板并进行修改以及删除一些不必要的参数 kubectl create deployment nginx-deploy -n dznb --imagenginx --port80 --replicas3 --dry-runclient -o yaml demo3-dz.yml将里面不需要的内容进行删除 生成service资源模版的配置 kubectl expose -n dznb deployment mynginx-dz --target-port80 --typeNodePort --namesvc-deploy --dry-runclient -o yaml生成一个service资源配置文件 kubectl expose -n dznb deployment mynginx-dz --target-port80 --typeNodePort --namesvc-deploy --dry-runclient -o yaml demo4-svc.yml也可以将之前的service模版进行导出使用并进行保持到新的文件当中 写yaml太累怎么办 ●用 --dry-run 命令生成 kubectl run my-deploy --imagenginx --dry-runclient -o yaml my-deploy.yaml●用get命令导出 kubectl get svc nginx-service -o yaml my-svc.yaml 或 kubectl edit svc nginx-service #复制配置再粘贴到新文件四、deployment.yaml文件详解 apiVersion: extensions/v1beta1 #接口版本 kind: Deployment #接口类型 metadata:name: cango-demo #Deployment名称namespace: cango-prd #命名空间labels:app: cango-demo #标签 spec:replicas: 3strategy:rollingUpdate: ##由于replicas为3,则整个升级,pod个数在2-4个之间maxSurge: 1 #滚动升级时会先启动1个podmaxUnavailable: 1 #滚动升级时允许的最大Unavailable的pod个数template: metadata:labels:app: cango-demo #模板名称必填sepc: #定义容器模板该模板可以包含多个容器containers: - name: cango-demo #镜像名称image: swr.cn-east-2.myhuaweicloud.com/cango-prd/cango-demo:0.0.1-SNAPSHOT #镜像地址command: [ /bin/sh,-c,cat /etc/config/path/to/special-key ] #启动命令args: #启动参数- -storage.local.retention$(STORAGE_RETENTION)- -storage.local.memory-chunks$(STORAGE_MEMORY_CHUNKS)- -config.file/etc/prometheus/prometheus.yml- -alertmanager.urlhttp://alertmanager:9093/alertmanager- -web.external-url$(EXTERNAL_URL)#如果command和args均没有写那么用Docker默认的配置。#如果command写了但args没有写那么Docker默认的配置会被忽略而且仅仅执行.yaml文件的command不带任何参数的。#如果command没写但args写了那么Docker默认配置的ENTRYPOINT的命令行会被执行但是调用的参数是.yaml中的args。#如果如果command和args都写了那么Docker默认的配置被忽略使用.yaml的配置。imagePullPolicy: IfNotPresent #如果不存在则拉取livenessProbe: #表示container是否处于live状态。如果LivenessProbe失败LivenessProbe将会通知kubelet对应的container不健康了。随后kubelet将kill掉container并根据RestarPolicy进行进一步的操作。默认情况下LivenessProbe在第一次检测之前初始化值为Success如果container没有提供LivenessProbe则也认为是SuccesshttpGet:path: /health #如果没有心跳检测接口就为/port: 8080scheme: HTTPinitialDelaySeconds: 60 ##启动后延时多久开始运行检测timeoutSeconds: 5successThreshold: 1failureThreshold: 5readinessProbe:httpGet:path: /health #如果没有心跳检测接口就为/port: 8080scheme: HTTPinitialDelaySeconds: 30 ##启动后延时多久开始运行检测timeoutSeconds: 5successThreshold: 1failureThreshold: 5resources: ##CPU内存限制requests:cpu: 2memory: 2048Milimits:cpu: 2memory: 2048Mienv: ##通过环境变量的方式直接传递pod自定义Linux OS环境变量- name: LOCAL_KEY #本地Keyvalue: value- name: CONFIG_MAP_KEY #局策略可使用configMap的配置KeyvalueFrom:configMapKeyRef:name: special-config #configmap中找到name为special-configkey: special.type #找到name为special-config里data下的keyports:- name: httpcontainerPort: 8080 #对service暴露端口volumeMounts: #挂载volumes中定义的磁盘- name: log-cachemount: /tmp/log- name: sdb #普通用法该卷跟随容器销毁挂载一个目录mountPath: /data/media - name: nfs-client-root #直接挂载硬盘方法如挂载下面的nfs目录到/mnt/nfsmountPath: /mnt/nfs- name: example-volume-config #高级用法第1种将ConfigMap的log-script,backup-script分别挂载到/etc/config目录下的一个相对路径path/to/...下如果存在同名文件直接覆盖。mountPath: /etc/config - name: rbd-pvc #高级用法第2中挂载PVC(PresistentVolumeClaim)#使用volume将ConfigMap作为文件或目录直接挂载其中每一个key-value键值对都会生成一个文件key为文件名value为内容volumes: # 定义磁盘给上面volumeMounts挂载- name: log-cacheemptyDir: {}- name: sdb #挂载宿主机上面的目录hostPath:path: /any/path/it/will/be/replaced- name: example-volume-config # 供ConfigMap文件内容到指定路径使用configMap:name: example-volume-config #ConfigMap中名称items:- key: log-script #ConfigMap中的Keypath: path/to/log-script #指定目录下的一个相对路径path/to/log-script- key: backup-script #ConfigMap中的Keypath: path/to/backup-script #指定目录下的一个相对路径path/to/backup-script- name: nfs-client-root #供挂载NFS存储类型nfs:server: 10.42.0.55 #NFS服务器地址path: /opt/public #showmount -e 看一下路径- name: rbd-pvc #挂载PVC磁盘persistentVolumeClaim:claimName: rbd-pvc1 #挂载已经申请的pvc磁盘五、Pod yaml文件详解 apiVersion: v1 #必选版本号例如v1 kind: Pod #必选Pod metadata: #必选元数据name: string #必选Pod名称namespace: string #必选Pod所属的命名空间labels: #自定义标签- name: string #自定义标签名字annotations: #自定义注释列表- name: string spec: #必选Pod中容器的详细定义containers: #必选Pod中容器列表- name: string #必选容器名称image: string #必选容器的镜像名称imagePullPolicy: [Always | Never | IfNotPresent] #获取镜像的策略Alawys表示总是下载镜像IfnotPresent表示优先使用本地镜像否则下载镜像Nerver表示仅使用本地镜像command: [string] #容器的启动命令列表如不指定使用打包时使用的启动命令args: [string] #容器的启动命令参数列表workingDir: string #容器的工作目录volumeMounts: #挂载到容器内部的存储卷配置- name: string #引用pod定义的共享存储卷的名称需用volumes[]部分定义的的卷名mountPath: string #存储卷在容器内mount的绝对路径应少于512字符readOnly: boolean #是否为只读模式ports: #需要暴露的端口库号列表- name: string #端口号名称containerPort: int #容器需要监听的端口号hostPort: int #容器所在主机需要监听的端口号默认与Container相同protocol: string #端口协议支持TCP和UDP默认TCPenv: #容器运行前需设置的环境变量列表- name: string #环境变量名称value: string #环境变量的值resources: #资源限制和请求的设置limits: #资源限制的设置cpu: string #Cpu的限制单位为core数将用于docker run --cpu-shares参数memory: string #内存限制单位可以为Mib/Gib将用于docker run --memory参数requests: #资源请求的设置cpu: string #Cpu请求容器启动的初始可用数量memory: string #内存清楚容器启动的初始可用数量livenessProbe: #对Pod内个容器健康检查的设置当探测无响应几次后将自动重启该容器检查方法有exec、httpGet和tcpSocket对一个容器只需设置其中一种方法即可exec: #对Pod容器内检查方式设置为exec方式command: [string] #exec方式需要制定的命令或脚本httpGet: #对Pod内个容器健康检查方法设置为HttpGet需要制定Path、portpath: stringport: numberhost: stringscheme: stringHttpHeaders:- name: stringvalue: stringtcpSocket: #对Pod内个容器健康检查方式设置为tcpSocket方式port: numberinitialDelaySeconds: 0 #容器启动完成后首次探测的时间单位为秒timeoutSeconds: 0 #对容器健康检查探测等待响应的超时时间单位秒默认1秒periodSeconds: 0 #对容器监控检查的定期探测时间设置单位秒默认10秒一次successThreshold: 0failureThreshold: 0securityContext:privileged:falserestartPolicy: [Always | Never | OnFailure] #Pod的重启策略Always表示一旦不管以何种方式终止运行kubelet都将重启OnFailure表示只有Pod以非0退出码退出才重启Nerver表示不再重启该PodnodeSelector: obeject #设置NodeSelector表示将该Pod调度到包含这个label的node上以keyvalue的格式指定imagePullSecrets: #Pull镜像时使用的secret名称以keysecretkey格式指定- name: stringhostNetwork:false #是否使用主机网络模式默认为false如果设置为true表示使用宿主机网络volumes: #在该pod上定义共享存储卷列表- name: string #共享存储卷名称 volumes类型有很多种emptyDir: {} #类型为emtyDir的存储卷与Pod同生命周期的一个临时目录。为空值hostPath: string #类型为hostPath的存储卷表示挂载Pod所在宿主机的目录path: string #Pod所在宿主机的目录将被用于同期中mount的目录secret: #类型为secret的存储卷挂载集群与定义的secre对象到容器内部scretname: string items: - key: stringpath: stringconfigMap: #类型为configMap的存储卷挂载预定义的configMap对象到容器内部name: stringitems:- key: string六、Service yaml文件详解 apiVersion: v1 kind: Service matadata: #元数据name: string #service的名称namespace: string #命名空间 labels: #自定义标签属性列表- name: stringannotations: #自定义注解属性列表 - name: string spec: #详细描述selector: [] #label selector配置将选择具有label标签的Pod作为管理 #范围type: string #service的类型指定service的访问方式默认为 #clusterIpclusterIP: string #虚拟服务地址 sessionAffinity: string #是否支持sessionports: #service需要暴露的端口列表- name: string #端口名称protocol: string #端口协议支持TCP和UDP默认TCPport: int #服务监听的端口号targetPort: int #需要转发到后端Pod的端口号nodePort: int #当type NodePort时指定映射到物理机的端口号status: #当spce.typeLoadBalancer时设置外部负载均衡器的地址loadBalancer: #外部负载均衡器 ingress: #外部负载均衡器 ip: string #外部负载均衡器的Ip地址值hostname: string #外部负载均衡器的主机名
http://www.dnsts.com.cn/news/69351.html

相关文章:

  • 做购物网站的步骤wordpress实现聊天功能
  • 建设网站的功能定位是什么原因后期网站建设及维护推广
  • 聊城正规网站建设设计公司淘宝联盟网站建设不完整
  • 自己建立网站后怎么做淘客网站建设招标公示
  • 广州网站建设免费wordpress自定义字体
  • 制作网页网站的软件是网络软件开发专业
  • 眉山北京网站建设网站seo优化技能
  • 枣庄建网站通过邮箱查注册网站
  • 新浪云 建设网站wordpress 评论框主题
  • 企业查查官网入口官网南宁网站运营优化平台
  • 网站建设质量体系审核指导自己编写代码建设微网站
  • 建设银行网站色调wordpress商城购物表单
  • 苏州营销型网站制作多少钱那家公司网站做的好
  • 合肥网站建设套餐顺德大良哪家做网站好
  • 网站建设好的乡镇做网站的北京
  • 设计兼职网站推荐免备案网站建设
  • 网站建设要什么软件网站建设企业网站制作平台
  • 外贸手机网站建设秦皇岛北京网站建设
  • 佛山建站 网站 商城企业建设网站个人总结报告
  • 南浦电商网站建设公司网站建设劳伦
  • asp网站建设公司网站如何做301跳转
  • 免费的行情网站推荐下载安装旅游时政热点新闻
  • 南京 网站开发合肥商城网站建设地址
  • 网站建设流程六个步骤企业管理咨询公司宗旨
  • 宁波网站推广软件哪家强网络推广营销方案100例
  • 网站内链有什么用wordpress 已安装主题
  • 网站收录和反链都正常关键词却没有排名的原因巴里坤网站建设
  • 大连网站设计案例100个最好的微信小程序
  • 做电商网站搭建晋升微信平台服务电话
  • 专业网站网站设计有什么软件可以找客户