解决docker日志挂载的问题
关键是本地服务器没有写入的权限
关键看这里吧(permission denied), 一直没有看正方,以为是配置日志文件 找不到有问题,下面是部分异常
10:35:09,498 |-error in ch.qos.logback.core.rolling.rollingfileappender[file] - openfile(null,true) call failed. java.io.filenotfoundexception: logs/bandwidth.log.2019-04-25.log (permission denied) at java.io.filenotfoundexception: logs/bandwidth.log.2019-04-25.log (permission denied) at at java.io.fileoutputstream.open0(native method) at at java.io.fileoutputstream.open(fileoutputstream.java:270) at at java.io.fileoutputstream.<init>(fileoutputstream.java:213) at at ch.qos.logback.core.recovery.resilientfileoutputstream.<init>(resilientfileoutputstream.java:26) at at ch.qos.logback.core.fileappender.openfile(fileappender.java:204) at at ch.qos.logback.core.fileappender.start(fileappender.java:127) at at ch.qos.logback.core.rolling.rollingfileappender.start(rollingfileappender.java:100) at at ch.qos.logback.core.joran.action.appenderaction.end(appenderaction.java:90) at at ch.qos.logback.core.joran.spi.interpreter.callendaction(interpreter.java:309) at at ch.qos.logback.core.joran.spi.interpreter.endelement(interpreter.java:193)
尝试好多遍,才真正看懂原因也是从网上看到的一点启发,希望大家也能注意到,我用如下命令完美解决
docker run -it --privileged=true -v /dockerlogs:/app/logs -d -p 5080:5080 82edb4bbc79b
挂载宿主机已存在目录后,在容器内对其进行操作,报“permission denied”
可通过两种方式解决:
1> 关闭selinux。
临时关闭:# setenforce 0
永久关闭:修改/etc/sysconfig/selinux文件,将selinux的值设置为disabled。
2> 以特权方式启动容器
指定--privileged参数
如:
# docker run -it --privileged=true -v /test:/softlogs
补充知识:docker -v 挂载日志到宿主机
今天用docker拉了个vsftp的镜像,运行,想把这个容器的日志给挂载到宿主机上方便查看,结果日志怎么都不出来,百度找半天找不到原因。
最后发现是需要先在宿主机的挂载目录下新建个和日志名称一样的文件,如下。
上面是我容器日志的位置
1、刚开始我是这样运行容器并挂载日志的(正常情况这样是可以挂载出来的,但咱这个不是不正常么~~~),但日志怎么都不出来。
docker run -d -v /home/ftp:/home/vsftpd -p 20:20 -p 21:21 -p 21100-21110:21100-21110 -v /home/logs/:/var/log/vsftpd/ -e ftp_user=cqs -e ftp_pass=chaoshiye@2020 --name vsftpd fauria/vsftpd
2、实际解决办法就是在宿主机挂载目录下创建文件 vsftpd.log,然后再执行上面的挂载,就会成功。
以上这篇解决docker日志挂载的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
上一篇: MyBatis带参查询的方法详解
下一篇: Nginx的“远方表哥”—Tengine