操作系统安全:Linux安全审计,Linux日志详解

2024-04-26 10:12

本文主要是介绍操作系统安全:Linux安全审计,Linux日志详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

「作者简介」:2022年北京冬奥会网络安全中国代表队,CSDN Top100,就职奇安信多年,以实战工作为基础对安全知识体系进行总结与归纳,著作适用于快速入门的 《网络安全自学教程》,内容涵盖系统安全、信息收集等12个知识域的一百多个知识点,持续更新。

操作系统有4个安全目标,也就是说想要保证操作系统的安全,就必须实现这4个需求:

  1. 标识系统中的用户和进行身份鉴别。
  2. 依据系统安全策略对用户的操作进行访问控制,防止用户和外来入侵者对计算机资源的非法访问。
  3. 审计系统运行的安全性。
  4. 保证系统自身的安全性和完整性。

安全审计就是用来实现这些需求的安全机制之一。

这一章节需要直到Linux通过哪些日志来做安全审计,日志的格式以及日志内容是什么意思。

Linux日志

  • audit.log
  • boot.log
  • btmp
  • cron
  • dmesg
  • lastlog
  • maillog
  • messages
  • secure
  • wtmp

Linux使用日志文件记录系统事件,实现安全审计,日志由syslog进程记录。

Linux日志存放在 /var/log/

  • audit/audit.log:系统内核、用户进程的行为日志
  • boot.log:开机自检日志
  • btmp:登录失败日志
  • cron:计划任务日志
  • dmesg:内核自检日志
  • lastlog:最后一次登录日志
  • maillog:邮件收发日志
  • messages:内核和应用程序日志
  • secure:系统安全日志
  • wtmp:用户登录/退出、系统启停日志

日志很大,查看的时候太慢,可以使用grep、sed、awk命令查看日志。

audit.log

audit是Linux的审计日志,可以手动配置审计规则,需要启动 /sbin/auditd 进程。

  • ps -ef | grep auditd 查看进程状态。
  • systemctl status auditdservice auditd status 查看服务状态。

使用 auditctl 配置审计规则。

  • auditctl -l 查看审计规则。
  • auditctl -w /home/tom/ -k tom_audit 审计/home/tom/目录下的所有文件操作,标记为tom_audit关键字

使用 ausearch 查看审计日志。本质是搜索 /var/log/audit/audit.log.

  • ausearch -ui 0 根据用户uid搜索
  • ausearch -p 1779 根据进程pid搜索
  • ausearch -f /home/tom/text.txt 根据文件路径搜索

在这里插入图片描述

boot.log

记录系统在引导过程中发生的事件,也就是Linux系统开机自检过程显示的信息。

日志存放在 /var/log/boot.log

在这里插入图片描述

btmp

记录用户登录失败的信息,常用来排查爆破信息。

日志存放在/var/log/btmp ,是二进制文件,可以用lastb命令查看。

在这里插入图片描述
日志字段从左到右依次是:登录用户、登录方式、登录源IP、登录时间。

lastb | awk '{print $3}' |sort| uniq -c | sort -n 过滤IP登录次数

cron

cron是计划任务日志,需要启动 /usr/sbin/crond 进程

  • ps -ef | grep crond 查看进程状态
  • systemctl status crondservice crond status 查看服务状态

使用 crontab 配置计划任务。

  • crontab -l 查看计划任务
  • crontab -e 编辑计划任务,本质上是在 /var/spool/cron/root文件中写计划任务。
  • crontab -r 清空计划任务,如果只删除某条计划任务,用crontab -e手动删除。

计划任务日志存放在 /var/log/cron ,可以直接查看。

在这里插入图片描述

日志类型重点看两种:

  • CROND 表示执行了计划任务
  • crontab 表示配置了计划任务

Apr 20 20:09:01 bogon CROND[3388]: (root) CMD (echo date >> /root/text.txt)

  • (root):执行计划任务的用户是root
  • CMD (echo date >> /root/text.txt):计划任务执行的内容。在这里插入图片描述

Apr 20 20:09:29 bogon crontab[3391]: (root) LIST (root)

  • (root) LIST (root):root用户查看了计划任务,也就是root用户执行了crontab -l。其他crontab类型的日志含义也是类似的逻辑。

root用户修改了计划任务,REPLACE表示计划任务被替换了。

在这里插入图片描述

root用户编辑了计划任务,但没修改。

在这里插入图片描述

dmesg

记录Linux内核日志,包括引导信息、硬件检测、设备驱动程序和系统错误等,用来追踪系统启动过程中的事件,排查故障和问题。

dmesg 查看内核日志,本质上是查看 /var/log/dmesg 文件。

dmesg | grep error 过滤错误日志。

在这里插入图片描述

lastlog

记录所有用户的最后一次登录信息,本质上是读取 /var/log/lastlog

在这里插入图片描述
字段解析:

  1. Username:用户名
  2. Port:端口,或者叫登录方式,pts表示伪终端,比如用xshell远程连接;tty表示串口终端,比如本地登录或用显示器登录。
  3. From:登录使用的源IP
  4. Lastest:最近的登录时间。Never logged in 表示从未登录过。

lastlog -u root 查看指定用户的最后登录信息

maillog

记录邮件日志,比如收发邮件。日志保存在 /var/log/maillog

在这里插入图片描述

messages

记录系统操作和事件,用来监控和调试系统运行情况,日志保存在 /var/log/messages

在这里插入图片描述
字段从左到右依次是:时间、主机名、服务/进程名、进程PID、日志信息。

secure

记录系统安全日志,比如SSH登录、sudo使用等信息,日志保存在 /var/log/secure

在这里插入图片描述

字段从左到右依次是:时间、主机名、服务/进程名、进程PID、日志信息。

wtmp

记录用户登录/推出和系统开机日志。

使用 last 查看日志,本质上是读取 /var/log/wtmp

在这里插入图片描述

从左到右字段依次是:用户名、登录方式(pts远程,tty本地)、登录的源IP、登录/退出时间。

这篇关于操作系统安全:Linux安全审计,Linux日志详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/937300

相关文章

Linux中tar命令解压缩常见用法

可用选项列表 c – create an archive file.x – extract an archive file.v – show the progress of the archive file.f – filename of the archive file.t – viewing the content of the archive file.j – filter archive

视频号小店商品从哪里来?店铺应该怎么获取流量?一篇详解!

大家好,我是电商小V 视频号小店是一个刚推出不久的项目,目前可以说正处于红利期,可谓是正处于风口期的项目,现在也是入驻去做的最好时机,但是对于一个新项目,很多新手玩家都是带着很多的疑问,视频号小店是什么?商品和流量怎么来呢?应该怎么操作呢?关于这个问题咱们就来详细的说一下: 视频号小店就是腾讯推出的电商项目,背靠腾讯平台,也是腾讯进军电商界的踏板,背靠腾讯可以说是不缺少流量的,在这个流

Linux cmake 初窥【3】

1.开发背景         基于上一篇的基础上,已经实现了多个源文件路径调用,但是没有库的实现 2.开发需求         基于 cmake 的动态库和静态库的调用 3.开发环境         ubuntu 20.04 + cmake-3.23.1 4.实现步骤 4.1 准备源码文件 基于上个试验的基础上,增加了动态库 LibShare 和 静态库 LibStatic

Linux网络编程---Web服务器

一、简单Web服务器实现 #include <stdio.h>#include <string.h>#include <stdlib.h>#include <netinet/in.h>#include <arpa/inet.h>#include <sys/wait.h>#include <errno.h>#include <sys/types.h>#include <sys/st

如何在Linux上设置IP

设置动态IP 在Linux上配置动态IP地址,通常是通过DHCP(动态主机配置协议)来实现的。以下是配置动态IP地址的一般步骤: 确认网卡名称: 使用ifconfig或ip addr命令来查看当前系统中的网卡名称。网卡名称通常是以eth、enp或ens开头,例如eth0或enp3s0。 编辑网络配置文件: 使用文本编辑器(如vi、nano等)打开网络接口的配置文件。这个文件的位置和名称取决

linux如何查看websocket的连接

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码: https://gitee.com/nbacheng/ruoyi-nbcio 演示地址:RuoYi-Nbcio后台管理系统 http://218.75.87.38:9666/ 更多nbcio-boot功能请看演示系统  gitee源代码地址 后端代码: https://gitee.com/nbacheng/

编程入门(六)【Linux系统基础操作四】

读者大大们好呀!!!☀️☀️☀️ 🔥 欢迎来到我的博客 👀期待大大的关注哦❗️❗️❗️ 🚀欢迎收看我的主页文章➡️寻至善的主页 文章目录 🔥前言🚀if else条件控制基本的if语句带else的if语句嵌套的if语句具体示例 🚀for 循环具体示例 🚀测试IP地址🚀获取当前主机的IPv4地址列表⭐️⭐️⭐️总结 🔥前言 本系列为Linux基础

操作系统原理与实验——实验十分段存储管理

实验指南 运行环境: Dev c++ 算法思想: 本实验是模拟分段存储管理,系统需要建立两张分区表,分别是已分配和未分配分区表,首先根据装入作业的大小判断是否小于空闲分区的总容量,若满足,则对该作业继续进行分段,每输入一个分段大小就在空闲分区中找到第一个没有使用且足够大的分区,若找到将该分区标记为该作业名和对应的分段号,修改已分配和未分配分区表,并打印内存分配信息。对已分配分区的回收,首先输入

【C/C++】Linux下使用system()函数一定要谨慎

曾经的曾经,被system()函数折磨过,之所以这样,是因为对system()函数了解不够深入。只是简单的知道用这个函数执行一个系统命令,这远远不够,它的返回值、它所执行命令的返回值以及命令执行失败原因如何定位,这才是重点。当初因为这个函数风险较多,故抛弃不用,改用其他的方法。这里先不说我用了什么方法,这里必须要搞懂system()函数,因为还是有很多人用了system()函数,有时你不得不面对

LINUX任务(jobs)详解

转自 :  http://hi.baidu.com/daweilang/item/58db8d308e54f6d56d15e999   LINUX任务(jobs)详解 在用管理员执行一个命令后,用Ctrl+Z把命令转移到了后台。导致无法退出root的。 输入命令:exit 终端显示:There are stopped jobs. 解决方法: 方法一、输入命令:jobs 终端显