您现在的位置是: 网站首页 >Kubernetes >Docker&Kubernetes技术全解 Kubernetes

【K8s+Docker技术全解】13.验证kubernets集群

admin2020年10月19日 23:08 Docker | Kubernetes | Linux 1863人已围观

Docker&Kubernetes技术全解简介 Kubernetes 是一个可移植的、可扩展的开源平台,用于管理容器化的工作负载和服务,可促进声明式配置和自动化。Kubernetes 拥有一个庞大且快速增长的生态系统。Kubernetes 的服务、支持和工具广泛可用。 课程来自老男孩教育学习总结。

## 验证kubernets集群 ### 在任意运算节点创建资源配置清单 在任意一个运算节点,常见一个资源配置清单,例如在 k8s99-151 上创建 ```bash [root@k8s99-151 ~]# cd [root@k8s99-151 ~]# vim /root/nginx-ds.yaml ``` 添加下面的内容 ```yaml # 创建资源配置清单 apiVersion: apps/v1 kind: DaemonSet metadata: name: nginx-ds spec: template: metadata: labels: app: nginx-ds spec: containers: - name: my-nginx image: harbor.study.com/public/nginx:latest ports: - containerPort: 80 ``` #### 解决nginx-ds.yaml新版配置错误问题 创建资源 ```bash [root@k8s99-151 ~]# kubectl create -f nginx-ds.yaml error: unable to recognize "nginx-ds.yaml": no matches for kind "DaemonSet" in version "extensions/v1beta1" # 将配置文件内的api接口修改为 apps/v1 ,导致原因为之间使用的kubernetes 版本弃用了原来的extensions/v1beta1接口 # 查看当前可用的API版本 [root@k8s99-151 ~]# kubectl api-versions admissionregistration.k8s.io/v1 admissionregistration.k8s.io/v1beta1 apiextensions.k8s.io/v1 apiextensions.k8s.io/v1beta1 apiregistration.k8s.io/v1 apiregistration.k8s.io/v1beta1 apps/v1 authentication.k8s.io/v1 authentication.k8s.io/v1beta1 authorization.k8s.io/v1 authorization.k8s.io/v1beta1 autoscaling/v1 autoscaling/v2beta1 autoscaling/v2beta2 batch/v1 batch/v1beta1 certificates.k8s.io/v1beta1 coordination.k8s.io/v1 coordination.k8s.io/v1beta1 discovery.k8s.io/v1beta1 events.k8s.io/v1beta1 extensions/v1beta1 networking.k8s.io/v1 networking.k8s.io/v1beta1 node.k8s.io/v1beta1 policy/v1beta1 rbac.authorization.k8s.io/v1 rbac.authorization.k8s.io/v1beta1 scheduling.k8s.io/v1 scheduling.k8s.io/v1beta1 storage.k8s.io/v1 storage.k8s.io/v1beta1 v1 # 将extensions/v1beta1修改为apps/v1后,又报错 [root@k8s99-151 ~]# kubectl create -f nginx-ds.yaml error: error validating "nginx-ds.yaml": error validating data: ValidationError(DaemonSet.spec): missing required field "selector" in io.k8s.api.apps.v1.DaemonSetSpec; if you choose to ignore these errors, turn validation off with --validate=false # 参考网上查看这个错误的帮助 [root@k8s99-151 ~]# kubectl explain DaemonSet.spec.selector KIND: DaemonSet VERSION: apps/v1 RESOURCE: selector <Object> DESCRIPTION: A label query over pods that are managed by the daemon set. Must match in order to be controlled. It must match the pod template's labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors A label selector is a label query over a set of resources. The result of matchLabels and matchExpressions are ANDed. An empty label selector matches all objects. A null label selector matches no objects. FIELDS: matchExpressions <[]Object> matchExpressions is a list of label selector requirements. The requirements are ANDed. matchLabels <map[string]string> matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is "key", the operator is "In", and the values array contains only "value". The requirements are ANDed. ``` 在配置文件中增加`selector:`配置后,再次创建 ```bash [root@k8s99-151 ~]# vim nginx-ds.yaml ``` 配置文件如下,在`spec:`中增加了 ```yaml selector: matchLabels: app: nginx-ds ``` #### nginx-ds.yaml 配置文件 ```yaml apiVersion: apps/v1 kind: DaemonSet metadata: name: nginx-ds spec: selector: matchLabels: app: nginx-ds template: metadata: labels: app: nginx-ds spec: containers: - name: my-nginx image: harbor.study.com/public/nginx:latest ports: - containerPort: 80 ``` 再次创建成功了 ```bash [root@k8s99-151 ~]# kubectl create -f nginx-ds.yaml daemonset.apps/nginx-ds created ``` #### 查看使用配置清单生成的pod ```bash [root@k8s99-151 ~]# kubectl get pods NAME READY STATUS RESTARTS AGE nginx-ds-5txgt 1/1 Running 0 2m4s nginx-ds-g27vj 1/1 Running 0 2m4s [root@k8s99-151 ~]# kubectl get pods -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES nginx-ds-5txgt 1/1 Running 0 2m37s 172.99.152.2 k8s99-152.host.com <none> <none> nginx-ds-g27vj 1/1 Running 0 2m37s 172.99.151.2 k8s99-151.host.com <none> <none> ``` ### 使用curl测试访问nginx 上面得到了两个IP,现在可以通过`curl`测试 ```bash [root@k8s99-151 ~]# curl 172.99.151.2 <!DOCTYPE html> <html> <head> <title>Welcome to nginx!</title> <style> body { width: 35em; margin: 0 auto; font-family: Tahoma, Verdana, Arial, sans-serif; } </style> </head> <body> <h1>Welcome to nginx!</h1> <p>If you see this page, the nginx web server is successfully installed and working. Further configuration is required.</p> <p>For online documentation and support please refer to <a href="http://nginx.org/">nginx.org</a>.<br/> Commercial support is available at <a href="http://nginx.com/">nginx.com</a>.</p> <p><em>Thank you for using nginx.</em></p> </body> </html> # 可以得到nginx的主页信息 [root@k8s99-151 ~]# curl 172.99.152.2 curl: (7) Failed connect to 172.99.152.2:80; 拒绝连接 # 无法访问,原因是跨宿主机的Docker容器还不能通信 ``` 在另一台上访问也是 ```bash [root@k8s99-152 ~]# kubectl get pods -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES nginx-ds-5txgt 1/1 Running 0 12m 172.99.152.2 k8s99-152.host.com <none> <none> nginx-ds-g27vj 1/1 Running 0 12m 172.99.151.2 k8s99-151.host.com <none> <none> [root@k8s99-152 ~]# curl 172.99.152.2 <!DOCTYPE html> <html> <head> <title>Welcome to nginx!</title> <style> body { width: 35em; margin: 0 auto; font-family: Tahoma, Verdana, Arial, sans-serif; } </style> </head> <body> <h1>Welcome to nginx!</h1> <p>If you see this page, the nginx web server is successfully installed and working. Further configuration is required.</p> <p>For online documentation and support please refer to <a href="http://nginx.org/">nginx.org</a>.<br/> Commercial support is available at <a href="http://nginx.com/">nginx.com</a>.</p> <p><em>Thank you for using nginx.</em></p> </body> </html> # 可以访问 [root@k8s99-152 ~]# curl 172.99.151.2 curl: (7) Failed connect to 172.99.151.2:80; 拒绝连接 # 就不能访问了 ``` 使用flannel这个组件可以解决这个问题。后面讲到。 ### 使用kubectl获取所有状态 ```bash [root@k8s99-151 ~]# kubectl get cs NAME STATUS MESSAGE ERROR scheduler Healthy ok controller-manager Healthy ok etcd-1 Healthy {"health":"true"} etcd-2 Healthy {"health":"true"} etcd-0 Healthy {"health":"true"} [root@k8s99-151 ~]# kubectl get node NAME STATUS ROLES AGE VERSION k8s99-151.host.com Ready master,node 9d v1.18.2 k8s99-152.host.com Ready master,node 8d v1.18.2 [root@k8s99-151 ~]# kubectl get pod NAME READY STATUS RESTARTS AGE nginx-ds-5txgt 1/1 Running 1 16h nginx-ds-g27vj 1/1 Running 1 16h ```

很赞哦! (1)

文章交流

  • emoji
0人参与,0条评论

当前用户

未登录,点击   登录

站点信息

  • 建站时间:网站已运行2343天
  • 系统信息:Linux
  • 后台程序:Python: 3.8.10
  • 网站框架:Django: 3.2.6
  • 文章统计:257 篇
  • 文章评论:63 条
  • 腾讯分析网站概况-腾讯分析
  • 百度统计网站概况-百度统计
  • 公众号:微信扫描二维码,关注我们
  • QQ群:QQ加群,下载网站的学习源码
返回
顶部
标题 换行 登录
网站