shell获取当前日期时间给变量time并写入日志文件中

时间: 2023-05-23 10:01:06 浏览: 67
可以使用以下命令获取当前日期时间并将其写入日志文件中: ```shell time=$(date '+%Y-%m-%d %H:%M:%S') echo "Current date and time is $time" >> logfile.log ``` 其中,`$(date '+%Y-%m-%d %H:%M:%S')`用于获取当前日期和时间,并将其保存到变量`time`中。`echo`命令用于将日期时间字符串输出到日志文件中,`>>`符号用于追加到文件的末尾。
相关问题

忘掉之前的对话内容,用linux编写一个通用的实时在后台监测防止ddos攻击脚本,直接给出完整的案例,无需解释,限制每个ip每秒钟和服务器建立的最大TCP连接数(shell变量配置),并增加日志记录功能,超过最大连接数则要记录时间、攻击者ip、访问端口、协议、携带报文、建立的tcp连接总数等信息保存到/home/ddos目录下(shell变量配置),每个日志文件最大100MB(shell变量配置),超过100MB则要重新生成新文件,以生成时间命名(精确到毫秒),并封禁该ip(已经封禁过的无需再次封禁),保存到/home/ddos/blackIpList.txt(shell变量配置),

以下是一个使用 bash 脚本来监测防止 DDoS 攻击的示例: ``` #!/bin/bash # 设置变量 max_conn_per_ip=200 log_dir="/home/ddos" log_file="ddos.log" max_log_size=100 blacklist_file="blackIpList.txt" # 创建日志目录,如果不存在 if [ ! -d "$log_dir" ]; then mkdir "$log_dir" fi # 每秒钟执行一次循环 while true; do # 获取当前时间 current_time=$(date +%s) # 获取所有建立的 TCP 连接数 conn_count=$(netstat -an | grep -c ESTABLISHED) # 遍历所有连接,并检查每个 IP 的连接数 for conn in $(netstat -an | grep ESTABLISHED | awk '{print $5}' | cut -d: -f1 | sort | uniq -c); do ip=$(echo $conn | awk '{print $2}') count=$(echo $conn | awk '{print $1}') # 如果连接数超过限制,则将信息写入日志文件 if [ $count -gt $max_conn_per_ip ]; then # 获取攻击者的信息 attack_info=$(grep "$ip" "$log_dir/$log_file" | tail -n1) attack_time=$(echo $attack_info | awk '{print $1}') port=$(echo $attack_info | awk '{print $6}') protocol=$(echo $attack_info | awk '{print $7}') packet=$(echo $attack_info | awk '{print $8}') # 如果超过一分钟,则将信息写入日志 if [ $(($current_time - $attack_time)) -gt 60 ]; then echo "$current_time $ip $port $protocol $packet $count" >> "$log_dir/$log_file" # 如果日志文件大小超过限制,则重新生成新文件 log_size=$(du -m "$log_dir/$log_file" | awk '{print $1}') if [ $log

用linux编写一个通用的实时在后台监测防止ddos攻击脚本,直接给出完整的案例,无需解释,要求有白名单列表,多个白名单用逗号隔开,排除本地所有网卡ip,每20秒钟检测一次(shell变量配置),限制每个ip每秒钟和服务器建立的最大TCP连接数(shell变量配置),并增加日志记录功能,超过最大连接数则要记录时间、攻击者ip、访问端口、协议、携带报文、建立的tcp连接总数等信息保存到/home/ddos目录下(shell变量配置),每个日志文件最大100MB(shell变量配置,自动清理3天以前的日志),超过100MB则要重新生成新文件,以生成时间命名(精确到毫秒),并使用iptables立即封禁该ip(已经封禁过的无需再次封禁),保存到/home/ddos/blackIpList.txt(shell变量配置),以上代码中文件或者目录不存在的需要自动进行创建,灵活发挥,减少人工干预和出错概率

下面是一个示例的脚本,请注意这个脚本是给出的一个实现思路,您可以根据自己的需要做相应的修改: ``` #!/bin/bash # 定义变量 WHITE_LIST="127.0.0.1,172.10.1.1" INTERVAL=20 MAX_TCP_CONN=5 DDOS_DIR="/home/ddos" LOG_FILE_SIZE=100 BLACK_IP_FILE="$DDOS_DIR/blackIpList.txt" # 如果目录不存在,则创建目录 if [ ! -d "$DDOS_DIR" ]; then mkdir "$DDOS_DIR" fi # 清理3天以前的日志 find "$DDOS_DIR" -name "*.log" -mtime +3 -delete # 循环检测 while true; do # 获取当前时间 current_time=$(date "+%Y-%m-%d %H:%M:%S") # 获取所有网卡的IP地址 all_ips=$(ifconfig | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*') # 枚举所有IP地址 for ip in $all_ips; do # 如果是白名单中的IP地址,则跳过 if [[ $WHITE_LIST =~ (^|,)$ip(,|$) ]]; then continue fi # 获取当前IP地址的连接数 conn_count=$(netstat -an | grep "$ip" | wc -l) # 如果连接数大于限制,则记录日志并封禁IP if [ $conn_count -gt $MAX_TCP_CONN ]; then # 获取攻击者的详细信息 attack_info=$(netstat -anp | grep "$ip") # 将信息写入日志文件 log_file="$DDOS_DIR/$(date "+%Y%m%d%H%M%S").log" echo "$current_time $ip $attack_info" >> "$log_file

相关推荐

最新推荐

recommend-type

Shell定时删除指定时间之前的文件

主要介绍了Shell定时删除指定时间之前的文件,本文用来删除一个月之前的备份文件,并加入到crontag定时删除,需要的朋友可以参考下
recommend-type

Shell脚本从文件中逐行读取内容的几种方法实例

今天小编就为大家分享一篇关于Shell脚本从文件中逐行读取内容的几种方法实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
recommend-type

在shell脚本中获取上个月最后一天的日期方法

今天小编就为大家分享一篇在shell脚本中获取上个月最后一天的日期方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Shell脚本中实现切换用户并执行命令操作

主要介绍了Shell脚本中实现切换用户并执行命令操作,看了示例代码就秒懂了,原来如此简单,需要的朋友可以参考下
recommend-type

Linux使用shell脚本定时删除历史日志文件

主要介绍了Linux使用shell脚本定时删除历史日志文件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。