服务器 
首页 > 服务器 > 浏览文章

解决docker日志挂载的问题

(编辑:jimmy 日期: 2024/11/19 浏览:3 次 )

关键是本地服务器没有写入的权限

关键看这里吧(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的镜像,运行,想把这个容器的日志给挂载到宿主机上方便查看,结果日志怎么都不出来,百度找半天找不到原因。

最后发现是需要先在宿主机的挂载目录下新建个和日志名称一样的文件,如下。

解决docker日志挂载的问题

上面是我容器日志的位置

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日志挂载的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

上一篇:解决docker加载新的镜像后repository和tag名称都为none的问题
下一篇:在docker下删除两个id相同的镜像的操作
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?