【Kubernetes】Pod学习(三)Pod容器共享Volume

此文为学习《Kubernetes权威指南》的相关笔记

学习笔记:

Pod中的容器通过共享Volume的方式,实现了文件共享和持久化。

Kubernetes中的Volume被定义在Pod上,然后被一个Pod里的多个容器挂载到具体的文件目录下。

Volume的生命容器与Pod相同,不与Pod中单个容器的生命周期相关。

当容器终止或者重启时,Volume中的数据也不会丢失。

Kubernetes支持多种类型的Volume。

本次实例中,容器busybox作为logreader,通过共同挂载的Volume,读取tomcat的工作日志并输出。

一、新建配置文件pod-volume-applogs.yaml

apiVersion: v1
kind: Pod
metadata:
 name: volume-pod
spec:
 containers:
 - name: tomcat
   image: tomcat
   ports:
   - containerPort: 8080
   volumeMounts:
   - name: app-logs
     mountPath: /usr/local/tomcat/logs  #将tomcat运行时日志挂载到下方声明的卷中

 - name: busybox
   image: busybox
   command: ["sh","-c","tail -f /logs/catalina*.log"]
   volumeMounts:
   - name: app-logs
     mountPath: /logs
    #与tomcat容器挂载同一个卷,可以跨容器文件共享,得到tomcat运行时的日志
 volumes:    #声明一个emptyDir类型的卷,供Pod内容器挂载
 - name: app-logs
   emptyDir: {}

>> 命令解释:

"sh -c" 命令,可以让 bash 将一个字串作为完整的命令来执行。

"tail -f"命令,等同于--follow=descriptor,根据文件描述符进行追踪,当文件改名或被删除,追踪停止,就是说可以随着文件更新不断输出内容。

2、根据配置文件建立Pod

# kubectl create -f pod-volume-applogs.yaml
pod/volume-pod created
# kubectl get pods
NAME         READY   STATUS    RESTARTS   AGE
volume-pod   2/2     Running   0          36s


3、查看logreader的运行日志:

# kubectl logs -c

# kubectl logs volume-pod -c busybox
10-Dec-2019 02:53:08.176 INFO [main] org.apache.catalina.startup.Catalina.load Initialization processed in 3841 ms
10-Dec-2019 02:53:08.226 INFO [main] org.apache.catalina.core.StandardService.startInternal Starting service [Catalina]
10-Dec-2019 02:53:08.226 INFO [main] org.apache.catalina.core.StandardEngine.startInternal Starting Servlet Engine: Apache Tomcat/8.5.49
10-Dec-2019 02:53:08.243 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/ROOT]

......

4、不使用logreader容器,直接进入tomcat容器查看日志的方法:

# kubectl exec -it -c --

查看日志目录文件:

# kubectl exec -it volume-pod -c tomcat -- ls /usr/local/tomcat/logs
catalina.2019-12-10.log      localhost_access_log.2019-12-10.txt
host-manager.2019-12-10.log  manager.2019-12-10.log
localhost.2019-12-10.log

查看日志详细信息:

# kubectl exec -it volume-pod -c tomcat -- tail /usr/local/tomcat/logs/catalina.2019-12-10.log
10-Dec-2019 07:10:13.770 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/docs] has finished in [32] ms
10-Dec-2019 07:10:13.771 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deploying web application directory [/usr/local/tomcat/webapps/examples]
10-Dec-2019 07:10:13.999 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [/usr/local/tomcat/webapps/examples] has finished in [228] ms

......

以上,可以看到,Pod内容器通过挂载一个共享卷,实现了文件共享。

你可能感兴趣的:(kubernetes)