在k8s集群中部署应用
kubectl run
直接部署pod
kubectl run testapp --image=ccr.ccs.tencentyun.com/k8s-tutorial/test-k8s:v1
可以看到pod创建成功:
data:image/s3,"s3://crabby-images/529c1/529c1b145b3c15ccfc2f98f94bd18cdf1ca4d6ad" alt=""
通过yaml文件创建pod
pod.yaml
apiVersion: v1
kind: Pod
metadata:
name: test-pod
spec:
# 定义容器,可以多个
containers:
- name: test-k8s # 容器名字
image: ccr.ccs.tencentyun.com/k8s-tutorial/test-k8s:v1 # 镜像
kind
表示这是一个Pod;
metadata
中的name
定义了这个pod的名字;
spec
中的containers
中可定义多个容器,容器名字和容器镜像地址;
kubectl apply -f pod.yaml
运行这个文件:
data:image/s3,"s3://crabby-images/cdd11/cdd113e24f29a37c6fd48345d2eb88b79a9f4954" alt=""
通过yaml文件创建deployment
在集群里面需要运行很多pod,可以运行一个Deployment
:
app.yaml:
apiVersion: apps/v1
kind: Deployment
metadata:
# 部署名字
name: test-k8s
spec:
replicas: 2
# 用来查找关联的 Pod,所有标签都匹配才行
selector:
matchLabels:
app: test-k8s
# 定义 Pod 相关数据
template:
metadata:
labels:
app: test-k8s
spec:
# 定义容器,可以多个
containers:
- name: test-k8s # 容器名字
image: ccr.ccs.tencentyun.com/k8s-tutorial/test-k8s:v1 # 镜像
spec
的replicas
为该deployment中运行的pod数量;
deployment通过标签label来关联创建的若干个pod,label是一个key:value
的值,如上面的app: test-k8s
;
spec
-template
中定义容器,容器中的metadata
-labels
定义一个与deployment一样的标签,用来与该deployment进行关联;
data:image/s3,"s3://crabby-images/3502d/3502d75f3629b61c7303e6e89c981cb1c9751dcb" alt=""
pod名字后面加了随机串。
pod常用操作命令
部署应用
kubectl apply -f app.yaml
查看 deployment / pod
kubectl get deployment
kubectl get pod -o wide
查看所有/指定namespace下的pod
# 查看所有namespace下的pod
kubectl get pods --all-namespaces
# 查看指定namespace下的所有pod
kubectl get pod -n kube-system
data:image/s3,"s3://crabby-images/1124c/1124cb6a2cac53dec5b9820b8523514e327b46b7" alt=""
describe 查看 pod 详情
# 查看 pod 详情
kubectl describe pod pod-name
data:image/s3,"s3://crabby-images/0bc3c/0bc3c05dd84bd1c761429e4ca703f219d96516aa" alt=""
查看pod运行日志
# 查看pod 运行 log
kubectl logs pod-name
data:image/s3,"s3://crabby-images/d677e/d677e7154e74ecc2460fa5ada1bfa01998f98d16" alt=""
exec进入pod里面
# 进入 Pod 容器终端, -c container-name 可以指定进入哪个容器。
kubectl exec -it pod-name -- bash
--
无其他含义,只是版本问题:
data:image/s3,"s3://crabby-images/cb375/cb375fd780adc91ad43656400ea9ed07ad825a59" alt=""
data:image/s3,"s3://crabby-images/07127/07127084142fe50b615f15ed3a19db04177c559d" alt=""
pod里面的容器名字可以通过kubectl describe pod pod-name
查看。
复制文件操作
kubectl cp pod-name:容器内文件路径 /root/主机目录文件 -n namespace
kubectl cp test-pod:/app/log4js.json /root/log4js.json -n default
kubectl cp /root/.bash_logout test-pod:/app/.bash_logout -n default
把pod集群内端口映射到节点所在服务器
# 把pod集群内端口映射到节点所在服务器
kubectl port-forward pod-name 8090:8080
data:image/s3,"s3://crabby-images/4a270/4a2704c604bb50c84086861971ccdceb8e972b53" alt=""
需要保持一直转发,终端不能断。
kubectl get all 查看全部
# 查看全部
kubectl get all
data:image/s3,"s3://crabby-images/c5032/c5032bea529ff378906aa87cb204181cd415bb62" alt=""
参考链接
https://k8s.easydoc.net/docs/dRiQjyTY/28366845/6GiNOzyZ/puf7fjYr