日志:

    日志是历史时间

    

    按时间序列将发生的事件予以记录的文件


    日志记录:事件发生的时间,事件内容


    日志级别:事件的关键性程度,log level


    

Linux:哪些进程需要记录日志?


syslog: 日志系统

syslogd: 系统进程的相关日志

klogd: 内核事件相关的日志


我们这里使用rsyslog来记录日志。    



rsyslog特点:      
        支持多线程
        支持:TCP,SSL,TLS,RELP
        支持:MySQL, PGSQL, Oracle等多种关系型数据中
        有强大的过滤器,可实现过滤系统信息中的任意部分
        支持自定义输出格式
        适用于企业级别日志记录需求
        模块化程序
    
    rsyslog主配置文件:/etc/rsyslog.conf

    rsyslog的选项:facility(设施),priority(级别),Target(路径)
    
    facility: 设施,从功能或程序上对日志进行分类,并由专门的工具负责记录其日志
		auth:跟认证相关的
		authpriv:跟认证授权相关的
		cron:跟周期性任务相关的
		daemon:帮守护进程相关的
		kern:帮内核记录日志的
		lpr:帮打印组记录日志
		mail:帮邮件服务记录日志
		mark:防火墙标记记录日志的
		news: 新闻组
		security:跟安全相关的
		syslog:syslong自己的日志
		user:跟用户相关的
		uucp:unix日志
		local0 through local7: 8 customed facility(8个自定义的facility)
			
		指定设施时可以使用通配符:指定日志选项
			* :所有
			,:列表,f1,f2,f3,f4...
			! : 取反
			; :记录多个日志信息
			- :启用异步功能
			
	priority: 级别,如果不用=号会记录比自己更高的级别
		debug
		info
		notice
		warn, warning
		err, error
		crit
		alert
		emerg,panic
			
			通配符:
				* :所有级别
				none :没有任何级别,不记录日志信息
				; :记录多个日志信息
				- :启用异步功能
				
	Target:
		文件路径:例如/var/log/messages
		用户:*,所有用户
		日志服务器:@SERVER_IP
		管道:|COMMAND
    
    
    
    rsyslog的格式:
        facility.priority    Target
        
        例如1:mail.info		/var/log/maillog
		比指定级别更高的所有级别,包括指定的级别本身
		
	例如2:mail.=info	/var/log/maillog	:只记录info级别的日志
		明确指定级别
	
	例如3:mail.!info	/var/log/maillog
		除了指定级别
			
	例如4:*.info		/var/log/log
		所有facility的info级别
	
	例如5: mail.*		/var/log/maillog
		mail的所有级别
		
	例如6:mail,news.info	/var/log/maillog
		mail与news的info级别
	
	例如7:mail.notice, new.info		/var/log/log
		mial的notice级别和new的info级别
			
	例如8:mail.info		*
		mail的日志发送给当前系统上已登录的所有用户info级别及以上的日志
			
	例如9:mail.=info		@192.168.1.1	
		将mail的info日志发送给192.168.1.1这个日志服务器
		
	例如10:mail.!info		| COMMAND
		将mail除info之外的其他级别日志发送给一个命令,如gerp
		
	例如11:*.info;mail.none
		记录所有设施的info及其他更高级别日志,但是mail不记录
	
	例如12:mail.*		-/var/log/maillog
		记录mail的所有级别日志,但是日志是异步同步的
		
    查看日志信息:
        tail /etc/log/messages
        
        日志信息格式:
	    	时间	主机	进程(PID):时间



    

启用接受其他服务器发送来的日志文件功能:启用日志服务器功能



vim /etc/rsyslog.conf
			修改配置之后重启才会生效
			
			
	MODULES:	模块
		#没跟空格的都是可启用功能
			ModLoad imudp		:装载一个udp模块
			UDPServerRun 514
				监听在UDP的514端口接收其他服务器发来的日志信息
				--------------------------------------------------
			ModLoad imtcp		:装载一个tcp模块
			InputTCPserverRun	:
			监听在TCP的514端口接收其他服务器发来的日志信息
						
				--------------------------------------------------
				
			GLOBAL DIRECTIVES:	全局指令
			
				--------------------------------------------------
			
			RULES:	规则




    

rsyslog支持将日志存储于MySQL服务器中:



vim /etc/rsyslong.conf
		
		yum install rsyslog-mysql	: 安装rsyslog-mysql模块
			rpm -ql  rsyslog-mysql
				/lib/rsyslog/ommysql.so	: om代表输出模块im代表输入模块
				/usr/share/doc/rsyslog-mysql-5.8.10/createDB.sql		:日志输出模版
			
			begin forwarding rule
				
		MODULES
		#Log event to MySQL
			$ModLoad ommysql	: 装载mysql模块
		
			
		RULES
		mail.*	:ommysql:127.0.0.1,Syslog,sysloguser,syslogpass
		facility.priority :ommysql:SERVER_IP,DATABASE,USERNAME,PASSWD
		
		将日志模版重定向输入到mysql数据库
		mysql < /usr/share/doc/rsyslog-mysql-5.8.10/createDB.sql	
		
		mysql : 进入mysql数据库
			SHOW DATABASES; : 查看是否已经将模版导入
			use Syslog; : 将Syslog设为默认数据库
			SHOW TABLES; : 查看默认数据库的表
			GRANT ALL ON Syslog.* TO sysloguser@127.0.0.1 IDENTIFIED BY 'syslogpass';
				设置sys的用户名与密码并切拥有syslog的所有权限
			FLUSH PRIVILEGES;	: 刷新权限
			
		service rsyslog restart	:重启服务
		
		做一个服务访问让其生成日志
		
		SELECT * FROM SystemEvents;	:查看日志信息






转载于:https://blog.51cto.com/kmk0226/1693931