当前位置: 首页 > news >正文

linux 13-2day 日志轮转 日志目录 轮转参数

目录

  • 日志系统rsyslog
  • 一、处理日志的进程
  • 二、常见的日志文件(系统、进程、应用程序)
    • 日志优先级
  • 三、logrotate日志轮转
    • 1、配置日志轮转的路径
    • 2、日志配置路径
    • 四 、案例

日志系统rsyslog

Linux 系统内核和许多程序会产生各种错误信息、告警信息和其他的提示信息,

这些各种信息都应该记录到日志文件中,完成这个过程的程序就是 rsyslog,rsyslog

可以根据日志的类别和优先级将日志保存到不同的文件中。

日志对于运维工程师的作用:用于排查错误 ,用于排查被攻击的风险


日志管理基础
rsyslog 日志管理
logrotate日志轮转

一、处理日志的进程

ps aux |grep rsyslogd

二、常见的日志文件(系统、进程、应用程序)

tail -f /var/log/messages		        	#动态查看日志文件的尾部,系统主日志文件tail -f /var/log/secure		            	#记录认证、安全的日志(谁登录了我们的系统)tail /var/log/maillog			            #跟邮件postfix相关tail /var/log/cron			                #crond、at进程产生的日志 (计划任务相关的)tail /var/log/dmesg			              	#和系统启动相关 tail /var/log/yum.log                       #yum的日志tail -f /var/log/mysqld.log                 #MySQL日志tail /var/log/xferlog                  		#和访问FTP服务器相关tail /var/log/boot.log                      #系统启动过程日志记录存放w					   						#当前登录的用户 /var/log/wtmplast				   						#最近登录的用户 /var/log/btmplastlog                                      #最近登录的用户 /var/log/btmp
第一列,用户名;
第二列,终端位置,/pts/0 (伪终端)意味着从诸如ssh或者telnet的远程链接的用户,
tty(teletypewriter)意味着直接连接到计算机或者本地链接的用户;
第三列,登录的ip或者内核。
第四列,开始时间;
第五列,结束时间(still login in 还未退出 down 直到正常关机 crash 直到强制关机)[root@linux-server ~]#lastlog			   #所有用户的登录情况 /var/log/lastlog
rsyslog

日志优先级

日志级别分为:7种日志级别代号0-70 debug             #有调试信息的,日志信息最多1 info              #一般信息的日志,最常用2 notice            #最具有重要性的普通条件的信息3 warning           #警告级别4 err               #错误级别,阻止某个功能或者模块不能正常工作的信息5 crit              #严重级别,阻止整个系统或者整个软件不能工作的信息6 alert             #需要立刻修改的信息7 emerg             #内核崩溃等严重信息none                #什么都不记录

三、logrotate日志轮转

因为日志的数量巨大,日志程序会把日志切割成多分,把旧的删除
这样处理,对于磁盘储存,大文件的读写,都更为合理

1、配置日志轮转的路径

/etc/logrotate.conf

2、日志配置路径

配置日志轮转
[root@linux-server ~]# vim /etc/logrotate.conf	/var/log/qianfeng{
#daily weekly monthly yearly
prerotate								# 轮转之前执行中间的命令chattr -a /var/log/qianfeng 	# 用于
endscript								# 表达式解决 开始进行轮转 missingok			              	#丢失不提示    daily              安天轮转dateext            使用日期作为后缀 weekly     	#轮转的周期,一周轮转,单位有年,月,日 #daily(天) weekly(周) monthly(月) yearly(年)compress  			delaycompress      转储的日志 在下一次转储的时候压缩rotate  5          转储了五份missingok          丢失不通知size   50M         达到五十兆 就轮转notifempty         空文件不轮转postrotate								# 轮转结束 再其实 这个文件里的权限chattr +a /var/log/qianfeng
endscript									# 表达式结束
}

四 、案例

手动轮转

/usr/sbin/logrotate /etc/logrotate.conf
/usr/sbin/logrotate 为轮转命令
/etc/logrotate.conf  轮转文件
logrotate -f /etc/logrotate.conf  # -f 是强制轮转
# 指定日志的位置
/var/log/newbee{
# 在日志轮转前要做的事
prerotate# 取消隐藏权限achattr -a /var/log/newbee
# 结束脚本
endscript
# weekly daily monthly yearly
# 以日期为后缀
dateext
# 轮转周期为 1天
daily
# 保留5份日志
rotate 5
# 设置属主属组 权限
create 0644 root root
# 设置压缩
compress
# 轮转之后要做的事情
postrotate# 再次添加a权限 (注意制表符)chattr +a /var/log/newbee
# 结束脚本
endscript
}例1:轮转文件/var/log/yum.log[root@linux-server ~]# vim /etc/logrotate.d/yum	   
/var/log/yum.log {missingok                                #丢失不提醒#notifempty                              #空文件不轮转 #size 30k									#只要到了30k就轮转#yearlydaily                                     #每天轮转一次   rotate 3      create 0644 root root 
}测试:
[root@linux-server ~]# /usr/sbin/logrotate /etc/logrotate.conf	  #手动轮转
[root@linux-server ~]# ls /var/log/yum*
/var/log/yum.log  /var/log/yum.log-20191110[root@linux-server ~]# grep yum /var/lib/logrotate/logrotate.status #查看记录所有日志文件最近轮转的时间
"/var/log/yum.log" 2019-11-10-21:26:142:日志安全,操作日志的隐藏权限
[root@localhost log]# cd /etc/logrotate.d/
[root@localhost logrotate.d]# vim syslog
建议测试时先把/etc/logrotate.d/syslog中messages删除,然后在下面添加如下:
/var/log/messages{prerotatechattr -a /var/log/messagesendscript#notifemptydailycreate 0600 root rootmissingokrotate 3postrotatechattr +a /var/log/messagesendscript
}/usr/sbin/logrotate /etc/logrotate.conf  #手动轮转cd /var/log/
ls mess*
messages  messages-20200805  messages-20200806参数解释:
prerotate/endscript - 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行
postrotate/endscript - 在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行size
触发分割的条件是:1.日志大小达到这个值,和时间周期没有关系。
minsize
触发分割的条件是:1.时间周期到了,2.日志大小达到这个值;两个条件都要满足。
maxsize
触发分割的条件是:1.时间周期到了,2. 日志大小大于这个值;两个条件任何一个满足。

相关文章:

  • 计算机病毒判定专家系统原理与设计《文字提取人工修正》
  • Docker安装与使用
  • vue-loader是如何工作的?
  • 财务机器人(RPA)会影响会计人员从业吗?
  • 《opencv实用探索·十四》VideoCapture播放视频和视像头调用
  • 720度vr虚拟家居展厅提升客户的参观兴致
  • 轻量封装WebGPU渲染系统示例<43>- PBR材质与阴影实(源码)
  • WT588F02B-8S语音芯片助力破壁机:智能声音播放提示IC引领健康生活新潮流
  • 透析跳跃游戏
  • Unity优化——批处理的优势
  • SAP UI5 walkthrough step6 Modules
  • Vue3.3.4中watch无法监测props的更改
  • [ffmpeg] av_opt_set 解析
  • Guava本地环境设置
  • 如何基于Akamai IoT边缘平台打造一个无服务器的位置分享应用
  • [rust! #004] [译] Rust 的内置 Traits, 使用场景, 方式, 和原因
  • __proto__ 和 prototype的关系
  • Bootstrap JS插件Alert源码分析
  • go append函数以及写入
  • HTTP中的ETag在移动客户端的应用
  • Java Agent 学习笔记
  • javascript从右向左截取指定位数字符的3种方法
  • js如何打印object对象
  • Laravel Mix运行时关于es2015报错解决方案
  • Python学习之路13-记分
  • React中的“虫洞”——Context
  • Synchronized 关键字使用、底层原理、JDK1.6 之后的底层优化以及 和ReenTrantLock 的对比...
  • Tornado学习笔记(1)
  • UMLCHINA 首席专家潘加宇鼎力推荐
  • 从零搭建Koa2 Server
  • 多线程 start 和 run 方法到底有什么区别?
  • 解析 Webpack中import、require、按需加载的执行过程
  • 京东美团研发面经
  • 移动端唤起键盘时取消position:fixed定位
  • [Shell 脚本] 备份网站文件至OSS服务(纯shell脚本无sdk) ...
  • ​​​​​​​​​​​​​​汽车网络信息安全分析方法论
  • ​水经微图Web1.5.0版即将上线
  • # 达梦数据库知识点
  • #{}和${}的区别?
  • #我与Java虚拟机的故事#连载11: JVM学习之路
  • (14)目标检测_SSD训练代码基于pytorch搭建代码
  • (2)STL算法之元素计数
  • (android 地图实战开发)3 在地图上显示当前位置和自定义银行位置
  • (C语言)求出1,2,5三个数不同个数组合为100的组合个数
  • (Demo分享)利用原生JavaScript-随机数-实现做一个烟花案例
  • (k8s中)docker netty OOM问题记录
  • (搬运以学习)flask 上下文的实现
  • (二)c52学习之旅-简单了解单片机
  • (二)Linux——Linux常用指令
  • (附源码)SSM环卫人员管理平台 计算机毕设36412
  • (附源码)流浪动物保护平台的设计与实现 毕业设计 161154
  • (生成器)yield与(迭代器)generator
  • (十八)SpringBoot之发送QQ邮件
  • (转)【Hibernate总结系列】使用举例
  • (转)可以带来幸福的一本书