博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
应用程序的日志通过rsyslog推送到syslog服务器
阅读量:7021 次
发布时间:2019-06-28

本文共 4463 字,大约阅读时间需要 14 分钟。

目前最新版rsyslog为8.27.0,rsyslog从8.5.0后对imfile模块进行重构,文件名中可以支持通配符。


rsyslog官网:

升级rsyslog需要配置yum源,centos默认的升级不到最新的版本。

1、配置yum

为了能够使用RPM存储库,您需要一个.repo文件。使用您的webbrowser,请访问http://rpms.adiscon.com。在这里,可以下载rsyslogall.repo文件,或者转到所需版本的子文件夹(例如v8-stable),然后从中下载rsyslog.repo文件。(google翻译来的)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
[root@localhost yum.repos.d]
# pwd
/etc/yum
.repos.d
[root@localhost yum.repos.d]
# ls
dvd.repo  packagekit-media.repo  rhel-
source
.repo  rsyslog.repo
[root@localhost yum.repos.d]
# cat rsyslog.repo 
[rsyslog_v8]
name=Adiscon CentOS-$releasever - 
local 
packages 
for 
$basearch
baseurl=http:
//rpms
.adiscon.com
/v8-stable/epel-
$releasever/$basearch
enabled=1
gpgcheck=0
gpgkey=http:
//rpms
.adiscon.com
/RPM-GPG-KEY-Adiscon
protect=1
[root@localhost yum.repos.d]
# rpm -qa|grep -i rsyslog
rsyslog-5.8.10-10.el6_6.x86_64
[root@localhost yum.repos.d]
# yum -y install rsyslog
[root@localhost yum.repos.d]
# rpm -qa|grep -i rsyslog
rsyslog-8.27.0-2.el6.x86_64
[root@localhost yum.repos.d]
#

根据官方网文档如果复制以上配置可能解析变量不正确导致安装不成功,此时需要替换第三行中的变量“$ releasever”,$releasever的值表示当前系统的发行版本,可以通过rpm -qi centos-release命令查看,其中的Version:6就是我们系统的版本号;$basearch是我们的系统硬件架构(CPU指令集),使用命令arch得到。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[root@localhost yum.repos.d]
# rpm -qi centos-release
Name        : centos-release               Relocations: (not relocatable)
Version     : 6                                 Vendor: CentOS
Release     : 5.el6.centos.11.1             Build Date: Wed 27 Nov 2013 07:53:33 PM CST
Install Date: Thu 27 Apr 2017 06:39:55 PM CST      Build Host: c6b9.bsys.dev.centos.org
Group       : System Environment
/Base       
Source RPM: centos-release-6-5.el6.centos.11.1.src.rpm
Size        : 32670                            License: GPLv2
Signature   : RSA
/SHA1
, Wed 27 Nov 2013 09:26:58 PM CST, Key ID 0946fca2c105b9de
Packager    : CentOS BuildSystem <http:
//bugs
.centos.org>
Summary     : CentOS release 
file
Description :
CentOS release files
[root@localhost yum.repos.d]
# arch
x86_64
[root@localhost yum.repos.d]
#

2、配置rsyslog

rsyslog默认只可以传送系统的日志,比如DHCP,cron、kern等,现在要传送一个服务的日志到远端的rsyslog服务器,要使用rsyslog的imfile模块。该模块提供将任何标准文本文件转换为syslog消息的功能。该文件逐行读取,任何读取的行都传递给rsyslog的规则引擎。

官方文档:

http://www.rsyslog.com/doc/v8-stable/configuration/modules/imfile.html

上图为配置样例,各参数可以参考文中的对应模块参数说明,module参考文中Module Parameters说明;input参考文中Input Parameters说明。

1
2
3
4
5
6
[root@localhost yum.repos.d]
# cp /etc/rsyslog.conf{,.20170613bak}
[root@localhost yum.repos.d]
# vim /etc/rsyslog.conf
module(load=
"imfile" 
PollingInterval=
"10"
)
input(
type
=
"imfile" 
File=
"/opt/CalculationUnit/java/sh/logs/bigada.log" 
Tag=
"CalculationUnit" 
Severity=
"info" 
Facility=
"local0" 
freshStartTail=
"on" 
deleteStateOnFileDelete=
"on"
)
local0.* @10.10.15.175:514
[root@localhost yum.repos.d]
# /etc/init.d/rsyslog restart

module

      load="imfile"    加载imfile模块

      PollingInterval="10"     轮询文件的频率,单位秒,默认10秒,

input

     type="imfile" 

     File="/opt/CalculationUnit/java/sh/logs/bigada.log"    发送到syslog的文件绝对路径

     Tag="CalculationUnit" 

     Severity="info"     

     Facility="local0" 

     freshStartTail="on"    设置为on每次重启rsyslog时只读取最新的数据丢弃旧日志,默认关

     deleteStateOnFileDelete="on" 如此文件会重新生成需要开启次参数,例如bigdata.log每天凌晨会重命名为bigdata%YYYY%mm%dd%.log,然后重新生成bigdata.log

local0.* @10.10.15.175:514   定义syslog服务器地址

错误:Permission denied 

1
2
3
Jun 27 18:33:46 localhost rsyslogd: imfile warning: directory 
'/opt/CalculationUnit/java/sh/logs'
: Permission denied [v8.27.0 try http:
//www
.rsyslog.com
/e/2046 
]
Jun 27 18:33:46 localhost rsyslogd:  [origin software=
"rsyslogd" 
swVersion=
"8.27.0" 
x-pid=
"19409" 
x-info=
"http://www.rsyslog.com"
] start
Jun 27 18:33:46 localhost rsyslogd: imfile: error with inotify API, ignoring 
file 
'/opt/CalculationUnit/java/sh/logs/bigada.log'
: Permission denied  [v8.27.0]

检查selinux

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
[root@localhost ~]
# sestatus
SELinux status:                 enabled
SELinuxfs 
mount
:                
/selinux
Current mode:                   enforcing
Mode from config 
file
:          enforcing
Policy version:                 24
Policy from config 
file
:        targeted
[root@localhost ~]
# getenforce 
Enforcing
[root@localhost ~]
# setenforce 0
[root@localhost ~]
# getenforce 
Permissive
[root@localhost ~]
# sestatus
SELinux status:                 enabled
SELinuxfs 
mount
:                
/selinux
Current mode:                   permissive
Mode from config 
file
:          enforcing
Policy version:                 24
Policy from config 
file
:        targeted
[root@localhost ~]
# vim /etc/sysconfig/selinux 
[root@localhost ~]
# /etc/init.d/rsyslog restart
Shutting down system logger:                               [  OK  ]
Starting system logger:                                    [  OK  ]
[root@localhost ~]
#

现在可以在syslog服务端数据库里查看到信息

本文转自 justin_peng 51CTO博客,原文链接:http://blog.51cto.com/ityunwei2017/1934910,如需转载请自行联系原作者

你可能感兴趣的文章
设计中的道理_6
查看>>
MFC——AfxParseURL用法
查看>>
关于综合布线系统线缆挑选方法
查看>>
面向过程,面向对象,函数式对同一个问题的思考方式
查看>>
盘点:抵御网络攻击哪国强?世界20强国排名
查看>>
混合“白+黑”名单方法是如何帮助企业加强安全的?
查看>>
中国网速竟不到泰国一半、香港的1/4!名副其实"华囧"
查看>>
4G和5G不配物联网 不过死撑
查看>>
SAP宣布将投资22亿美元发展物联网业务
查看>>
他用10年前的攻击手法感染了17000多名开发者的电脑
查看>>
IBM秀出并行训练肌肉:256个GPU还能有95%的拓展效率,顺便刷新ImageNet-22K记录
查看>>
报告称云计算可能会阻碍IT支出
查看>>
《程序员度量:改善软件团队的分析学》一公平和一致性
查看>>
移动医疗行业6大值得关注的玩家解析
查看>>
Facebook 开源 FAISS;MIT 开发 SDV 系统,将合成数据用于机器学习等 | AI 开发者头条...
查看>>
联合光伏一季度太阳能发电站发电44.45万兆瓦时 同比增长67.8%
查看>>
如何建立一个正确的安全架构去做正确的防御?
查看>>
《程序员度量:改善软件团队的分析学》一可重复的成功
查看>>
《Android应用开发攻略》——3.7 用Log.d和LogCat进行调试
查看>>
微软Windows 10浏览器上个月份额再度下跌
查看>>