k8s(二)——kubectl的使用以及创建deployment
k8s(二)——kubectl的使用以及创建deployment
·
kubectl的使用以及创建deployment
kubectl的使用
常见概念
- devops 开发和运维
实现的方式有:python,docker+k8s,git+Jenkins - k8s
k8s集成了docker三剑客(compose,swam,machine)的功能。 - pod与pod控制器
一个pod是一个或者多个容器。
pod控制器是用来控制、管理pod的数量,状态。 - service
由于pod的地址会发生改变,通过service可以为pod提供一个统一的访问入口
kubectl管理命令概要
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
- 方法二:通过kuboard创建pod
- 方法三:创建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 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
发布应用
用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
服务伸缩
根据客户端的请求流量实现弹性管理
滚动更新
## 将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
更多推荐
已为社区贡献3条内容
所有评论(0)