linux下,记录响应时间的脚本,精确到毫秒ms

linux下,记录响应时间的脚本,精确到毫秒ms,第1张

gettimeofday(取得目前的时间

相关函数

time,ctime,ftime,settimeofday

表头文件

#include <sys/time.h>

#include <unistd.h>

定义函数

int gettimeofday ( struct timeval * tv , struct timezone * tz )

函数说明

gettimeofday()会把目前的时间有tv所指的结构返回,当地时区的信息则放到tz所指的结构中。

timeval结构定义为:

struct timeval{

long tv_sec/*秒*/

long tv_usec/*微秒*/

}

timezone 结构定义为:

struct timezone{

int tz_minuteswest/*和Greenwich 时间差了多少分钟*/

int tz_dsttime/*日光节约时间的状态*/

}

上述两个结构都定义在/usr/include/sys/time.h。tz_dsttime 所代表的状态如下

DST_NONE /*不使用*/

DST_USA /*美国*/

DST_AUST /*澳洲*/

DST_WET /*西欧*/

DST_MET /*中欧*/

DST_EET /*东欧*/

DST_CAN /*加拿大*/

DST_GB /*大不列颠*/

DST_RUM /*罗马尼亚*/

DST_TUR /*土耳其*/

DST_AUSTALT /*澳洲(1986年以后)*/

返回值

成功则返回0,失败返回-1,错误代码存于errno。附加说明EFAULT指针tv和tz所指的内存空间超出存取权限。

范例

#include<sys/time.h>

#include<unistd.h>

main(){

struct timeval tv

struct timezone tz

gettimeofday (&tv , &tz)

printf(“tv_sec%d\n”, tv,.tv_sec)

printf(“tv_usec%d\n”,tv.tv_usec)

printf(“tz_minuteswest%d\n”, tz.tz_minuteswest)

printf(“tz_dsttime, %d\n”,tz.tz_dsttime)

}

执行

tv_sec: 974857339

tv_usec:136996

tz_minuteswest:-540

tz_dsttime:0

1、clock --show

Tue 29 Aug 2017 01:14:21 PM CST -0.396903 seconds

2、date

date +%Y%m%d-%H:%M:%S.%N

date命令的功能是显示和设置系统日期和时间。

该命令的一般格式为: date [选项] 显示时间格式(以+开头,后面接格式)

date 设置时间格式

命令中各选项的含义分别为:

-d datestr, --date datestr 显示由datestr描述的日期

-s datestr, --set datestr 设置datestr 描述的日期

-u, --universal 显示或设置通用时间 时间域

% H 小时(00..23)

% I 小时(01..12)

% k 小时(0..23)

% l 小时(1..12)

% M 分(00..59)

% p 显示出AM或PM

% r 时间(hh:mm:ss AM或PM),12小时

% s 从1970年1月1日00:00:00到目前经历的秒数

% S 秒(00..59)

% T 时间(24小时制)(hh:mm:ss)

% X 显示时间的格式(%H:%M:%S)

% Z 时区 日期域

% a 星期几的简称( Sun..Sat)

% A 星期几的全称( Sunday..Saturday)

% b 月的简称(Jan..Dec)

% B 月的全称(January..December)

% c 日期和时间( Mon Nov 8 14:12:46 CST 1999)

% d 一个月的第几天(01..31)

% D 日期(mm/dd/yy)

% h 和%b选项相同

% j 一年的第几天(001..366)

% m 月(01..12)

% w 一个星期的第几天(0代表星期天)

% W 一年的第几个星期(00..53,星期一为第一天)

% x 显示日期的格式(mm/dd/yy)

% y 年的最后两个数字( 1999则是99)

% Y 年(例如:1970,1996等)

需要特别说明的是,只有超级用户才能用date命令设置时间,一般用户只能用date命令显示时间。

下列环境变量将会影响到 date 命令的执行效果。

LANG 确定在 LC_ALL 和相应的环境变量(以 LC_ 开头)都不指定语言环境的时候将要使用的缺省语言环境。

LC_ALL 确定用于覆盖由 LANG 或任何以 LC_ 开头的环境变量设置的任何语言环境类别值的语言环境。

LC_CTYPE 确定文本数据的字节序列解释为字符时使用的语言环境(例如参数中单对多字节字符)。

LC_MESSAGES 决定写信息应使用的语言。

LC_TIME 确定由 date 写入的日期和时间字符串的内容。

NLSPATH 为处理 LC_MESSAGES 决定消息目录的位置。

TZ 指定时间和日期使用的时区,除非指定了 -u 选项。如果未设置 TZ 变量且未指定 -u 标志,则使用非指定的系统缺省时区。

使用示例一:

#date //显示当前日期

#date -s //设置当前时间,只有root权限才能设置,其他只能查看。

#date -s 20061010 //设置成20061010,这样会把具体时间设置成空00:00:00

#date -s 12:23:23 //设置具体时间,不会对日期做更改

#date -s “12:12:23 2006-10-10″ //这样可以设置全部时间

CST:中国标准时间(China Standard Time),这个解释可能是针对RedHat Linux。

UTC:协调世界时,又称世界标准时间,简称UTC,从英文国际时间/法文协调时间”Universal Time/Temps Cordonné”而来。中国大陆、香港、澳门、台湾、蒙古国、新加坡、马来西亚、菲律宾、澳洲西部的时间与UTC的时差均为+8,也就是UTC+8。

GMT:格林尼治标准时间(旧译格林威治平均时间或格林威治标准时间;英语:Greenwich Mean Time,GMT)是指位于英国伦敦郊区的皇家格林尼治天文台的标准时间,因为本初子午线被定义在通过那里的经线。

设置完系统时间后,还需要同步到硬件时钟上

# clock --systohc

硬件时钟与系统时钟同步:

# hwclock --hctosys

或者

# clock --hctosys

上面命令中,--hctosys表示Hardware Clock to SYStem clock。

系统时钟和硬件时钟同步:

# hwclock --systohc

或者

# clock --systohc

使用示例二:

用指定的格式显示时间。

$ date ‘+This date now is =>%x ,time is now =>%X ,thank you !'

This date now is =>11/12/99 ,time is now =>17:53:01 ,thank you !

用预定的格式显示当前的时间。

# date

Fri Nov 26 15:20:18 CST 1999

  设置时间为下午14点36分。

# date -s 14:36:00

Fri Nov 26 14:15:00 CST 1999

  设置时间为1999年11月28号。

# date -s 991128

Sun Nov 28 00:00:00 CST 1999

设置一天前

date --date "1 days ago" +"%Y-%m-%d"

Date 命令参数小技巧

由于Linux对man date -d 参数说的比较模糊,故举例如下:

# -d, --date=STRING display time described by STRING, not `now'

For Linux

[root@linuxso.com ~ ]# date -d next-day +%Y%m%d

20060328

[root@linuxso.com ~ ]# date -d last-day +%Y%m%d

20060326

[root@linuxso.com ~ ]# date -d yesterday +%Y%m%d

20060326

[root@linuxso.com ~ ]# date -d tomorrow +%Y%m%d

20060328

[root@linuxso.com ~ ]# date -d last-month +%Y%m

200602

[root@linuxso.com ~ ]# date -d next-month +%Y%m

200604

[root@linuxso.com ~ ]# date -d next-year +%Y

2007

------------------------------------------

而FreeBSD则不同举例如下:

For FreeBSD

[root@linuxso.com ~]# date -v -1d +%Y%m%d

20060326

[root@linuxso.com ~]# date -v -1m +%Y%m%d

20060227

[root@linuxso.com ~]# date -v -1y +%Y%m%d

20050327

使用示例三:

在linux环境下要取得几天前的时期只要使用

date -d "x days ago" +%Y%m%d

x用数字代替,如果需要几天前的直接写正数,如果要几天后的日期直接写负数即可;

date -d "x weeks ago" +%Y%m%d

x用数字代替,如果需要几周前的直接写正数,如果要几周后的日期直接写负数即可;

date -d "x years ago" +%Y%m%d

x用数字代替,如果需要几年前的直接写正数,如果要几年后的日期直接写负数即可;

看下面例子:

[root@linuxso.com ~]# date +%Y%m%d

20100107

上面是今天的日期20100107

[root@linuxso.com ~]# date -d "2 days ago" +%Y%m%d

20100105

上面是两天前的日期

[root@linuxso.com ~]# date -d "4 days ago" +%Y%m%d

20100103

上面是四天前的日期

[root@linuxso.com ~]# date -d "-1 days ago" +%Y%m%d

20100108

上面是一天后的日期

[root@linuxso.com ~]# date -d "-2 days ago" +%Y%m%d

20100109

上面是两天后的日期

[root@linuxso.com ~]# date -d "1 week ago" +%Y%m%d

20091231

上面是一周前的日期

[root@linuxso.com ~]# date -d "1 year ago" +%Y%m%d

20090107

上面是一年前的日期


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/9000182.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-23
下一篇 2023-04-23

发表评论

登录后才能评论

评论列表(0条)

保存