【Windows运维系列1】查询Windows服务器登录的记录和IP地址(附Shell命令)

23年12月底的时候,客户的一台在Hostease购买的Windows美国服务器客户投诉网站打不开,在登陆服务器检查问题的时候发现文件都被加密了,我也有几台在Hostease的服务器,一直都很稳定。不过这件事情想想也比较蹊跷,都23年了,居然还会中勒索病毒??!!

还好我们都会建议客户给重要的服务器顺带配备R1Soft服务器备份,前后差不多花了1天时间把整台服务器恢复到1周前没有被黑的状态。我买的R1Soft最多只保留一周的数据,不然服务器上的数据就没有了,也幸亏客户当时听我们的建议,购买了R1Soft备份,不然想想还有点后怕。

这个客户服务器是客户自己来做的系统配置,好在服务器被黑后,这个客户请我们协助他做了一些事后的恢复重建工作和安全加固,在排查中发现,客户的操作系统在配置的时候对于安全部分的疏忽导致了这一问题,近期也闲下来,整理了事情的全部过程,以及修复如何验证并解决的过程,因为内容较多,所以我们拆分几篇文章来说,本文主要来说明一下,如何查询Windows的登陆日志。

查询Windows的登陆日志

方法一

在Windows中,所有的登陆日志都会被记录在事件查看器当中,你可以通过下面的步骤来访问事件查看器:

1.在Windows系统中使用快捷键Win+R或者开始菜单打开“运行”程序

2.输入“eventvwr.msc”启动事件管理器

3.在左侧的“Windows日志”下找到“安全”,在右侧安全列表中就可以看到所有和安全有关的日志,我们可以通过下面的不同的事件ID代表找到不同的事件:

4624 - 帐户已成功登录
4625 - 帐户登录失败
4634 - 帐户被注销
4647 - 用户发起注销
4648 - 试图使用明确的凭证登录(可以查看远程登陆的相关信息,比如IP地址等)

登录失败的事件ID为4625,登陆成功的事件ID为4624和4648,你可以在下图步骤3中替换不同的ID找到Windows登陆的是日志和IP地址

通过Windows事件管理器查看登录日志

方法二

你也可以通过下面的代码来快速获取登陆失败或者登陆失败的日期和IP,你也可以替换下面代码中的“Id=4625”来获取其他登陆状态的日期和IP

$StartTime = (Get-Date).AddDays(-1)
$AllEntries = Get-WinEvent -FilterHashtable @{ LogName='Security';StartTime = $StartTime;Id=4625}
$AllEntries | Foreach {$entry = [xml]$_.ToXml();[array]$Output += New-Object PSObject -Property @{TimeCreated = $_.TimeCreated;IPAddress = $entry.SelectSingleNode("//*[@Name='IpAddress']").innerxml}}
$Output | Select TimeCreated, IPAddress | Out-Host -Paging

输出的结果:

通过bash脚本输出登陆成功的事件与IP地址可以看到137.xxx.226.31结尾的服务器最近在频繁的登陆服务器,如果是已知设备,那么我们就可以去了解最近为何这个设备频繁的登陆,如果是位置的IP地址,那么我们可以在防火墙内将这个IP地址给Block掉。
接下去文章我们将分享如何将查询到的IP地址给Block掉。如果我的文章对你在排查故障时有帮助,欢迎点赞关注。有问题欢迎私信或留言。

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: Linux运维常见的Shell脚本有很多,以下是其中几个常见的: 1. 自动备份脚本:用于定期备份重要数据和文件。通过Shell脚本可以实现自动化备份的操作,可以指定备份的目录和文件,以及备份的频率和存储位置。这样可以节省管理员手动备份的时间和精力。 2. 日志分析脚本:用于对系统日志进行分析和统计。通过Shell脚本,可以编写脚本来检索系统日志中的特定信息,比如错误日志或者登录日志,并可以进行分析和生成报告,帮助管理员找出系统中的问题和异常。 3. 系统监控脚本:用于监控服务器的性能和资源。通过Shell脚本可以实现对服务器资源的监控,比如CPU利用率、内存使用情况、磁盘空间等。当资源达到预设阈值时,可以触发报警或者自动化的操作。 4. 系统部署脚本:用于快速部署和配置服务器。通过Shell脚本可以编写自动化的脚本来安装和配置应用程序或者服务器环境,比如搭建Web服务器或者数据库服务器。这样可以提高部署的效率和一致性。 5. 定时任务脚本:用于定期执行特定的任务。通过Shell脚本可以编写定时任务,比如定期清理临时文件、定时发送邮件等。这样可以实现一些常规性的操作,并减轻管理员的工作负担。 这些是Linux运维中常见的几个Shell脚本,当然实际应用可能还有其他的脚本,根据具体需求会有所不同。通过编写Shell脚本,可以提高运维工作的自动化程度和效率,同时减少出错的可能性。 ### 回答2: Linux运维通常会使用一些常见的Shell脚本来简化和自动化一些重复的任务。以下是一些常见的Linux运维脚本: 1. 系统备份脚本:用于执行服务器的完全备份或增量备份,包括文件和数据的备份、压缩和存储。通过定期运行备份脚本可以确保数据的安全性。 2. 日志文件分析脚本:用于对系统日志进行分析和报告,通过提取关键信息、统计特定事件的发生次数和分析日志文件的大小等指标,帮助系统管理员及时发现问题,并进行相应的故障排除。 3. 定时任务脚本:用于定期执行某些任务,比如系统状态监控、磁盘空间检查、服务启动和停止等。通过设置定时任务脚本,可以在预定时间自动执行相应的操作,提高工作效率。 4. 监控脚本:用于监控系统的各项指标,如CPU利用率、内存占用率、磁盘空间使用情况和网络带宽等。通过定期运行监控脚本,可以及时发现系统的异常情况并采取相应措施。 5. 安全检查脚本:用于检查系统的安全性,包括密码强度、账户权限、开放的端口等。通过运行安全检查脚本,可以发现系统的安全漏洞并采取相应措施,增强系统的安全性。 6. 网络设置脚本:用于配置和管理网络设置,包括IP地址、子网掩码、网关、DNS等。通过运行网络设置脚本,可以快速配置和修改系统的网络设置,提供便利性和灵活性。 以上是一些常见的Linux运维脚本,通过使用这些脚本,系统管理员可以更高效地管理和维护Linux服务器,提高工作效率和系统安全性。 ### 回答3: Linux运维常见的Shell脚本有很多,以下是一些常见的例子: 1. 自动备份脚本:用于定期备份重要数据或文件,可以设置定时任务,自动执行备份任务,并将备份文件按照日期存储。 2. 系统资源监控脚本:可以通过Shell脚本编写一个用于监控系统资源使用情况的脚本,包括CPU使用率、内存使用量、磁盘空间等,并将结果输出到日志文件或发送邮件进行监控。 3. 日志分析脚本:用于分析日志文件,提取关键信息,如错误日志分析、访问日志统计等。 4. 系统自动安装脚本:可以编写一个脚本,自动安装各种软件或配置系统环境,简化系统部署过程。 5. 监控进程脚本:编写一个Shell脚本来监控某个进程的运行状态,当进程停止运行时,自动重启或发出警报。 6. 网络检测脚本:可以编写一个用于检测网络连通性的脚本,通过ping命令检测网络连通性,并将结果记录下来。 7. 系统性能优化脚本:用于自动优化系统性能,例如调整内核参数、清理无用进程、释放缓存等。 8. 定时任务脚本:使用crontab命令结合Shell脚本可以编写定时任务,如每天自动备份、每周清理日志等。 总之,Shell脚本在Linux运维中扮演了重要的角色,可以帮助管理人员自动化执行各种任务,提高效率,减少人工操作的工作负担。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值