码迷,mamicode.com
首页 > 数据库 > 详细

在chroot环境下将MySQL日志输出到syslog

时间:2014-09-03 14:58:26      阅读:266      评论:0      收藏:0      [点我收藏+]

标签:mysql   syslog   chroot   

好久没写博客了,这几个月一直在学习nodejs,angularjs,做一些前端开发,目前还是学习阶段,等有一些体会再来分享。

这两天碰到的一个问题是,我们的产品给客户后,客户要统一管理日志,MySQL要将日志输出到syslog,就需要在my.cnf的[mysqld_safe]段配置syslog。但是修改了以后发现服务启动失败,而且没有日志,经过几番调查,还需要做如下的事情:

1. chroot MySQL的时候需要将/bin/logger拷贝到chroot jail中,因为logger是syslog的shell接口,没有logger可执行文件,就调用不了syslog

2. 通常情况下,logger做的事情是将日志发送到/dev/log这个socket上,但是在chroot环境下,jail里面是访问不到外面的文件的,所以要在chroot jail中配置log socket文件,方法是修改/etc/sysconfig/syslog,将SYSLOGD_OPTIONS改为

SYSLOGD_OPTIONS="-m 0 -a /var/chroot/mysql/dev/log"

男人(man)是这样说的:

 -a socket
              Using  this argument you can specify additional sockets from that syslogd has to listen to.  This is needed if you’re going to let some
              daemon run within a chroot() environment.  You can use up to 19 additional sockets.  


好了,重启syslog,MySQL的日志默认就输出到/var/log/daemon.log文件中了,同时可以看到在/var/chroot/mysql/dev目录下有了log socket文件。

以上,在CentOS 5.9中测试通过

在chroot环境下将MySQL日志输出到syslog

标签:mysql   syslog   chroot   

原文地址:http://blog.csdn.net/napolunyishi/article/details/39027351

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!