系统相关
首页 > 系统相关> > linux – logrotate表示在旋转日志/重新创建日志文件时拒绝权限

linux – logrotate表示在旋转日志/重新创建日志文件时拒绝权限

作者:互联网

我是新手在linux机器上进行logrotate …这是我在我的应用程序的logrotate.d文件中设置的内容:

/var/log/myapp.log {
daily
missingok
create 0660 root utmp
rotate 1
}

我使用chmod直接从bash shell为mypro.log文件设置了运行相关应用程序的帐户的所有者权限.

当应用程序第一次运行时,一切都很好.它记录得很好,一切都很好.但是当日志轮换时,它会删除日志文件,然后尝试重新创建日志文件,并提供权限被拒绝错误:

/bin/bash: /var/log/myapp.log: Permission denied

我知道我在使用logrotate配置文件或chmod或其他东西时出错了…有人能指出我正确的方向并帮我解决问题吗?

解决方法:

I set owner permissions on the myapp.log file for the account that runs the app in question, using chmod, directly from the bash shell.

…所以除非“运行相关应用程序的帐户”是root,否则配置选项

create 0660 root utmp

是错误的,因为那是要求logrotate创建一个新的myapp.log(在它将原来的myapp.log旋转到myapp.log.0之后),用户root和group utmp拥有权限0660.用应用程序所需的属性替换它们应该可以解决问题.

标签:permission-denied,linux,chmod,file-permissions,logrotate
来源: https://codeday.me/bug/20190903/1796858.html