mirror of
https://github.com/ansible/awx.git
synced 2026-02-27 15:58:45 -03:30
Merge pull request #4302 from rooftopcellist/rsyslog_conf_race
Prevent Rsyslog config race condition when writing to file
This commit is contained in:
@@ -1,5 +1,6 @@
|
|||||||
import os
|
import os
|
||||||
|
import shutil
|
||||||
|
import tempfile
|
||||||
import urllib.parse as urlparse
|
import urllib.parse as urlparse
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
@@ -112,6 +113,10 @@ def construct_rsyslog_conf_template(settings=settings):
|
|||||||
|
|
||||||
def reconfigure_rsyslog():
|
def reconfigure_rsyslog():
|
||||||
tmpl = construct_rsyslog_conf_template()
|
tmpl = construct_rsyslog_conf_template()
|
||||||
with open('/var/lib/awx/rsyslog/rsyslog.conf', 'w') as f:
|
# Write config to a temp file then move it to preserve atomicity
|
||||||
f.write(tmpl + '\n')
|
with tempfile.TemporaryDirectory(prefix='rsyslog-conf-') as temp_dir:
|
||||||
|
path = temp_dir + '/rsyslog.conf.temp'
|
||||||
|
with open(path, 'w') as f:
|
||||||
|
f.write(tmpl + '\n')
|
||||||
|
shutil.move(path, '/var/lib/awx/rsyslog/rsyslog.conf')
|
||||||
supervisor_service_command(command='restart', service='awx-rsyslogd')
|
supervisor_service_command(command='restart', service='awx-rsyslogd')
|
||||||
|
|||||||
Reference in New Issue
Block a user