मैं Ubuntu 10.04 LTS पर स्टॉक rsyslogd (4.2.0-2ubuntu8.1) का उपयोग करके एक साधारण केंद्रीकृत syslog सर्वर को लागू करने का प्रयास कर रहा हूं। इस बिंदु पर मेरे पास मेरे सभी क्लाइंट नोड्स हैं जो केंद्रीय सर्वर पर लॉग भेजते हैं, लेकिन क्लाइंट लॉग संदेश भेज रहे हैं जिसमें उनके FQDN के बजाय उनके लघु होस्टनाम शामिल हैं।
उबंटू rsyslogd मैनपेज के अनुसार:
यदि दूरस्थ होस्ट होस्ट के समान डोमेन में स्थित है, तो rsyslogd चल रहा है, पूरे fqdn के बजाय केवल साधारण होस्टनाम लॉग किया जाएगा।
मेरे लिए यह समस्याग्रस्त है, क्योंकि मैं वातावरण के बीच छोटे नामों का पुन: उपयोग कर रहा हूं, जैसे core1.example.com और core1.stg.example.com दोनों ही अपने संदेशों को core1 के रूप में लॉग करते हैं।
क्लाइंट और सर्वर दोनों के पास समान / आदि / डिफ़ॉल्ट / rsyslog है:
RSYSLOGD_OPTIONS="-c4"
और वही /etc/rsyslogd.conf फ़ाइल:
$ModLoad imuxsock
$ModLoad imklog
$PreserveFQDN on
$ActionFileDefaultTemplate RSYSLOG_TraditionalFileFormat
$FileOwner root
$FileGroup adm
$FileCreateMode 0640
$IncludeConfig /etc/rsyslog.d/*.conf
ग्राहकों के पास यह /etc/rsyslog.d/remote.conf फ़ाइल है, जो उन्हें दूरस्थ सर्वर पर भेजने के लिए कह रही है:
*.* @@syslog.example.com
और सर्वर इस /etc/rsyslog.d/server.conf फ़ाइल का उपयोग करता है:
$ModLoad imtcp
$InputTCPServerRun 514
$DirGroup root
$DirCreateMode 0755
$FileGroup root
$template PerHostAuth,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/auth.log"
$template PerHostCron,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/cron.log"
$template PerHostSyslog,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/syslog"
$template PerHostDaemon,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/daemon.log"
$template PerHostKern,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/kern.log"
$template PerHostLpr,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/lpr.log"
$template PerHostUser,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/user.log"
$template PerHostMail,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/mail.log"
$template PerHostMailInfo,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/mail.info"
$template PerHostMailWarn,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/mail.warn"
$template PerHostMailErr,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/mail.err"
$template PerHostNewsCrit,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/news.crit"
$template PerHostNewsErr,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/news.err"
$template PerHostNewsNotice,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/news.notice"
$template PerHostDebug,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/debug"
$template PerHostMessages,"/srv/rsyslog/%$YEAR%/%$MONTH%/%$DAY%/%HOSTNAME%/messages"
auth,authpriv.* ?PerHostAuth
*.*;auth,authpriv.none -?PerHostSyslog
cron.* ?PerHostCron
daemon.* -?PerHostDaemon
kern.* -?PerHostKern
lpr.* -?PerHostLpr
mail.* -?PerHostMail
user.* -?PerHostUser
mail.info -?PerHostMailInfo
mail.warn ?PerHostMailWarn
mail.err ?PerHostMailErr
news.crit ?PerHostNewsCrit
news.err ?PerHostNewsErr
news.notice -?PerHostNewsNotice
*.=debug;\
auth,authpriv.none;\
news.none;mail.none -?PerHostDebug
*.=info;*.=notice;*.=warn;\
auth,authpriv.none;\
cron,daemon.none;\
mail,news.none -?PerHostMessages
जैसा कि क्लाइंट और सर्वर दोनों एक कॉन्फ़िगरेशन साझा करते हैं जो "$ PreserveFQDN पर" निर्दिष्ट करता है, मुझे FQDN होस्टनाम को syslog संदेशों में देखने की उम्मीद है, लेकिन सेटिंग का कोई प्रभाव नहीं पड़ा है। अधिकांश अन्य सेटिंग्स जो मैंने rsyslog के लिए पाई हैं, उनका लक्ष्य FQDNs से डोमेन को अलग करने के बजाय उन्हें बनाए रखना है। मुझे लगता है कि समस्या की जड़ यह है कि मेरे ग्राहक पहली जगह में एफक्यूडीएन नहीं भेजते हैं, लेकिन मैं यह नहीं देखता कि उस व्यवहार को कैसे लागू किया जाए।
क्या कोई इस बात पर टिप्पणी कर सकता है कि मुझे क्या याद आ रहा है? मुझे लगता है कि मैं केवल एकमात्र व्यक्ति नहीं हूं जिसे लॉग संदेश में FQDNs को शामिल करने की आवश्यकता है।