这两天碰到的一个问题是,我们的产品给客户后,客户要统一管理日志,mysql要将日志输出到syslog,就需要在my.cnf的[mysqld_safe]
这几个月一直在学习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中测试通过
--------------------------------------分割线 --------------------------------------
ubuntu 14.04下安装mysql
《mysql权威指南(原书第2版)》清晰中文扫描版 pdf
ubuntu 14.04 lts 安装 lnmp nginx\php5 (php-fpm)\mysql
ubuntu 14.04下搭建mysql主从服务器
ubuntu 12.04 lts 构建高可用分布式 mysql 集群
ubuntu 12.04下源代码安装mysql5.6以及python-mysqldb
mysql-5.5.38通用二进制安装
--------------------------------------分割线 --------------------------------------
本文永久更新链接地址: