k8s(二)——kubectl的使用以及创建deployment

kubectl的使用以及创建deployment

  • kubectl的使用
    • 常见概念
    • kubectl管理命令概要
  • 管理和使用deployment
    • 基于deployment创建nginx pod,有一个副本
    • 查看k8s对象状态
    • 发布应用
    • 服务伸缩
    • 滚动更新

kubectl的使用

常见概念

  • devops 开发和运维
    实现的方式有:python,docker+k8s,git+Jenkins
  • k8s
    k8s集成了docker三剑客(compose,swam,machine)的功能。
  • pod与pod控制器
    一个pod是一个或者多个容器。
    pod控制器是用来控制、管理pod的数量,状态。
  • service
    由于pod的地址会发生改变,通过service可以为pod提供一个统一的访问入口

kubectl管理命令概要

k8s(二)——kubectl的使用以及创建deployment_第1张图片
k8s(二)——kubectl的使用以及创建deployment_第2张图片

kubectl create -h
kubectl create deployment -h

管理和使用deployment

deployment的作用:

  • 创建指定数量的pod
  • 检查pod健康状态和数量

基于deployment创建nginx pod,有一个副本

  • 方法一
kubectl run nginx-dep1 --image=nginx:1.8 --replicas=1
kubectl get deployment
kubectl get pods
kubectl get pods -o wide
free -m

k8s(二)——kubectl的使用以及创建deployment_第3张图片

  • 方法二:通过kuboard创建pod
    k8s(二)——kubectl的使用以及创建deployment_第4张图片
    k8s(二)——kubectl的使用以及创建deployment_第5张图片
    k8s(二)——kubectl的使用以及创建deployment_第6张图片
    k8s(二)——kubectl的使用以及创建deployment_第7张图片
  • 方法三:创建yaml文件
## 创建yaml文件
vim ngx-dep.yaml
## yaml文件内容
apiVersion: apps/v1
kind: Deployment
metadata:
  name: ngx-dep3
  labels:
      app: ngx
      type: webservice
spec:
  replicas: 1
  selector:
    matchLabels:
      app: ngx
  template:
    metadata:
      labels:
        app: ngx
    spec:
      containers:
      - name: nginx
        image: nginx:1.8
## 执行yaml文件
kubectl apply -f ngx-dep.yaml 

k8s(二)——kubectl的使用以及创建deployment_第8张图片

查看k8s对象状态

kubectl get 资源类型
kubectl get pod
kubectl get pod -o wide
kubectl get deployment
kubectl get deployment -o wide
kubectl get namespace
# 指定查看某个命名空间下的pod
kubectl get pod -n kube-system
# 查看所有命名空间下的pod
kubectl get pod -A -o wide


kubectl describe 资源类型
kubectl describe pod
kubectl describe pod web-nginx-dep2-5f4fbd5bfb-jqw9z
kubectl describe pod -o wide
kubectl describe deployment
kubectl describe deployment -o wide
kubectl describe namespace
# 指定查看某个命名空间下的pod
kubectl describe pod -n kube-system
# 查看所有命名空间下的pod
kubectl describe pod -A -o wide

kubectl logs 显示pod中的容器中运行过程中产生的日志信息
kubectl logs ngx-dep3-64cfcc9ddc-92x9s

kubectl run bx --image=busybox
kubectl exec -it nginx-dep1-6dd5d75f8b-mgndd /bin/bash
kubectl exec -it pod对象 /bin/bash

资源类型:
node
pod
service
deployment
namespace
k8s(二)——kubectl的使用以及创建deployment_第9张图片
k8s(二)——kubectl的使用以及创建deployment_第10张图片
k8s(二)——kubectl的使用以及创建deployment_第11张图片

发布应用

用service来发布服务

首先创建yaml

apiVersion: v1
kind: Service
metadata:
  name: ngx-svc
  labels:
    app: ngx
spec:
  selector:
    app: ngx
  ports:
  - name: nginx-ports
    protocol: TCP
    port: 80
    nodePort: 32002
    targetPort: 80
  type: NodePort
## 执行yaml文件
kubectl apply -f ngx_svc.yaml
#查看service的端口映射信息
kubectl get svc
#此时,可以访问集群中的任意一个node节点,来访问web页面
curl http://192.168.31.66:32002

k8s(二)——kubectl的使用以及创建deployment_第12张图片
k8s(二)——kubectl的使用以及创建deployment_第13张图片
k8s(二)——kubectl的使用以及创建deployment_第14张图片

服务伸缩

根据客户端的请求流量实现弹性管理
k8s(二)——kubectl的使用以及创建deployment_第15张图片
k8s(二)——kubectl的使用以及创建deployment_第16张图片

滚动更新

## 将1.8修改成1.7.9
 vim ngx-dep.yaml 
 kubectl apply -f ngx-de
 kubectl apply -f ngx-dep.yaml 
 watch kubectl get pods -l app=ngx
 kubectl get pods -l app=ngx
 kubectl describe pod ngx-dep3-5f55b87775-6lpjj

k8s(二)——kubectl的使用以及创建deployment_第17张图片

你可能感兴趣的:(docker,k8s,kubernetes,docker,kubernetes,运维)