我试图在shell脚本中创建一个时间戳变量,以使日志记录更容易一些。我想在脚本的开头创建变量,并让它在发出echo $timestamp时打印出当前时间。事实证明这比我想象的要困难得多。以下是我尝试过的一些方法:
timestamp="(date +"%T")"回显输出(date +"%T")
timestamp="$(date +"%T")"回显变量初始化的时间。
我尝试过的其他方法都只是细微的变化,效果并不好。有人知道我要怎么做吗?
我试图在shell脚本中创建一个时间戳变量,以使日志记录更容易一些。我想在脚本的开头创建变量,并让它在发出echo $timestamp时打印出当前时间。事实证明这比我想象的要困难得多。以下是我尝试过的一些方法:
timestamp="(date +"%T")"回显输出(date +"%T")
timestamp="$(date +"%T")"回显变量初始化的时间。
我尝试过的其他方法都只是细微的变化,效果并不好。有人知道我要怎么做吗?
当前回答
GNU bash的时间戳格式化技巧,版本4.4.20(1)-release (x86_64-pc-linux-gnu)
echo "$(date +%Y-%m-%d_%H:%M:%S.%6N) Info >>> enter main"
输出:
2023-01-08_23:08:48.013592 Info >>> enter main
如果你想用空格替换'_',请执行以下操作(w/o '\'得到错误消息)
echo "$(date +%Y-%m-%d\ %H:%M:%S.%6N) Info >>> enter main"
echo "$(date +%Y-%m-%d\ %T.%6N) Info >>> enter main"
输出:
2023-01-08 23:10:40.692674 Info >>> enter main
其他回答
下面将给出当地的日期和时间-但它确实需要互联网访问。根据所记录的内容,这可能是有益的—监视和记录连接状态?
curl -i --silent https://google.com/ 2>&1 | grep date
date: Fri, 03 Jun 2022 17:39:19 GMT
我使用的是ubuntu 14.04。
在我的系统中,正确的方法应该是date +%s。
日期+%T的输出类似于12:25:25。
GNU bash的时间戳格式化技巧,版本4.4.20(1)-release (x86_64-pc-linux-gnu)
echo "$(date +%Y-%m-%d_%H:%M:%S.%6N) Info >>> enter main"
输出:
2023-01-08_23:08:48.013592 Info >>> enter main
如果你想用空格替换'_',请执行以下操作(w/o '\'得到错误消息)
echo "$(date +%Y-%m-%d\ %H:%M:%S.%6N) Info >>> enter main"
echo "$(date +%Y-%m-%d\ %T.%6N) Info >>> enter main"
输出:
2023-01-08 23:10:40.692674 Info >>> enter main
避免叉! !
必须为每一行日志运行日期是多余的!!
尽可能使用bash的内置。
更新2023
在提出这个问题时,bash版本是bash-4.2。
在这个版本中,纯bash打印当前时间的方式是:
printf '%(%T)T\n' -1
or
printf '%(%T)T\n' -1
所以一个简短的函数登录每一行的时间戳可以是:
logLine() {
printf '%(%T)T %s\n' -1 "$*"
}
Then
$ logLine Hello world.
10:11:32 Hello world.
今天,我使用bash-5.1.4…
从bash版本5.0-alpha开始,(2018-05-22):
b.变量EPOCHSECONDS扩展为以秒为单位的时间 从Unix时代开始。 c.有一个EPOCHREALTIME变量,扩展为以秒为单位的时间 从Unix时代开始的微秒粒度。
所以如果你想使用微秒粒度,函数可以变成:
logLine() {
local now=$EPOCHREALTIME
printf '%(%T)T.%s %s\n' ${now%.*} ${now#*.} "$*"
}
Then
$ logLine Hello world.
10:15:56.862732 Hello world.
重要提示:不要混淆EPOCHREALTIME和EPOCHSECONDS!!
如果你想获取unix时间戳,那么你需要使用:
timestamp=$(date +%s)
T会给你刚好的时间;与%H:%M:%S相同(通过http://www.cyberciti.biz/faq/linux-unix-formatting-dates-for-display/)