Commit 92792670 authored by Łukasz Nowak's avatar Łukasz Nowak

- install logrotate and setup its cron entry

 - put cron configuration in etc directory


git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@45631 20353a03-c40f-0410-a6d1-a30d3c3de9de
parent 2ffda7ca
No related merge requests found
...@@ -54,6 +54,7 @@ class Recipe(BaseSlapRecipe): ...@@ -54,6 +54,7 @@ class Recipe(BaseSlapRecipe):
self.requirements, self.ws = self.egg.working_set([__name__]) self.requirements, self.ws = self.egg.working_set([__name__])
# self.cron_d is a directory, where cron jobs can be registered # self.cron_d is a directory, where cron jobs can be registered
self.cron_d = self.installCrond() self.cron_d = self.installCrond()
self.logrotate_d = self.installLogrotate()
ca_conf = self.installCertificateAuthority() ca_conf = self.installCertificateAuthority()
memcached_conf = self.installMemcached(ip=self.getLocalIPv4Address(), memcached_conf = self.installMemcached(ip=self.getLocalIPv4Address(),
port=11000) port=11000)
...@@ -88,6 +89,19 @@ class Recipe(BaseSlapRecipe): ...@@ -88,6 +89,19 @@ class Recipe(BaseSlapRecipe):
)) ))
return self.path_list return self.path_list
def installLogrotate(self):
"""Installs logortate main configuration file and registers its to cron"""
logrotate_d = os.path.abspath(os.path.join(self.etc_directory,
'logrotate.d'))
self._createDirectory(logrotate_d)
logrotate_conf = self.createConfigurationFile("logrotate.conf",
"include %s" % logrotate_d)
logrotate_cron = os.path.join(self.cron_d, 'logrotate')
state_file = os.path.join(self.data_root_directory, 'logrotate.status')
open(logrotate_cron, 'w').write('0 0 * * * %s -s %s %s' % (self.options['logrotate_binary'], state_file, logrotate_conf))
self.path_list.extend([logrotate_d, logrotate_conf, logrotate_cron])
return logrotate_d
def linkBinary(self): def linkBinary(self):
"""Links binaries to instance's bin directory for easier exposal""" """Links binaries to instance's bin directory for easier exposal"""
for linkline in self.options.get('link_binary_list', '').splitlines(): for linkline in self.options.get('link_binary_list', '').splitlines():
...@@ -234,8 +248,8 @@ class Recipe(BaseSlapRecipe): ...@@ -234,8 +248,8 @@ class Recipe(BaseSlapRecipe):
def installCrond(self): def installCrond(self):
timestamps = self.createDataDirectory('cronstamps') timestamps = self.createDataDirectory('cronstamps')
cron_d = os.path.join(self.var_directory, 'cron.d') cron_d = os.path.join(self.etc_directory, 'cron.d')
crontabs = os.path.join(self.var_directory, 'crontabs') crontabs = os.path.join(self.etc_directory, 'crontabs')
logfile = os.path.join(self.log_directory, 'cron.log') logfile = os.path.join(self.log_directory, 'cron.log')
self._createDirectory(cron_d) self._createDirectory(cron_d)
self._createDirectory(crontabs) self._createDirectory(crontabs)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment