Un*x時間

Unix time

[23] Unix time は、 Unix 系システムを中心に多くの計算機システムで用いられている日時の内部表現形式 (整数時刻系) です。 計算機システム用の時刻系としては最も著名なものです。

意味

[25] Unix time は、 元期 (Unix epochThe Epoch) から経過した単位の時間として表したものです。

[7] の値 (1969年以前) は、環境や文脈によっては扱えないことがあります。 最近は多くの環境がの値も扱えるようになっているようです。

秒未満

[37] 秒未満も含めた小数 (浮動小数点数) に拡張されていることがあります。

閏秒

[15] 閏秒は考えません。

各言語・プロトコルの Unix time

C と POSIX

[6] C には time_t があり、普通 Unix time を表すものとして扱われています。

[11] Perltime などでシステム時刻を使っており、 ほとんどのシステムUnix time です。 Unix timePerl アプリケーションの標準の内部時刻形式と考えられています。

[38] PerlTime::HiRes::time小数Unix time を返します。

gzip の時刻

[55] gzipMTIME は、 Unix time小エンディアンの 4バイト符号無し整数で表したものです。

[56] ただし、0タイムスタンプなしを表します。

PGP の時刻

[5] RFC 4880 - OpenPGP Message Format ( 版) <https://tools.ietf.org/html/rfc4880#section-3.5>

A time field is an unsigned four-octet number containing the number of seconds elapsed since midnight, 1 January 1970 UTC.

DKIM の時刻

[13] RFC 4871 が定義する DKIM-Signature: 頭欄t= タグの値は、 1970年1月1日0時0分0秒 (UTC) からの数とされています。 ただし、閏秒は数えません。 RFC 4871 は、 実装に対して最低 1012 (≒ 紀元後20万年、≒ 40ビット符号無し整数) までの値を扱えることを推奨 (SHOULD) しています。 更に、サービス拒否攻撃防止のために、 12桁以上の値は無限大とみなして構わない (MAY) ともしています。

SQL

[31] SQL では時間帯を持たない日時データ型が使われることも多いですが、 その場合でも Unix time が使われることがあります。ここでの Unix time は、本来の からの秒数ではなく、 地方時からの秒数とされています。

[20] MySQL では、 UNIX_TIMESTAMP日時Unix time に、 FROM_UNIXTIMEUnix time日時に変換できます。

OAuth の時刻

[2] oauth_timestampUnix time 同等の定義となっています。

OpenID の時刻

[3] Final: OpenID Connect Core 1.0 incorporating errata set 1 ( 版) <http://openid.net/specs/openid-connect-core-1_0.html#rfc.section.2>

Its value is a JSON number representing the number of seconds from 1970-01-01T0:0:0Z as measured in UTC until the date/time.

CDNI の時刻

[21] RFC 8006 - Content Delivery Network Interconnection (CDNI) Metadata () <https://tools.ietf.org/html/rfc8006#section-4.3.4>

A time value expressed in seconds since the UNIX epoch (i.e., zero hours, zero minutes, zero seconds, on January 1, 1970) Coordinated Universal Time (UTC) [POSIX].

Type: Integer

Example time representing 09:00:00 01/01/2000 UTC: 946717200

[22] RFC 8007 - Content Delivery Network Interconnection (CDNI) Control Interface / Triggers () <https://tools.ietf.org/html/rfc8007#section-5.2.5>

A JSON number, seconds since the UNIX epoch (00:00:00 UTC on 1 January 1970).

TLS の時刻

[4] RFC 5246 - The Transport Layer Security (TLS) Protocol Version 1.2 ( 版) <http://tools.ietf.org/html/rfc5246#section-7.4.1.2>
gmt_unix_time
The current time and date in standard UNIX 32-bit format (seconds since the midnight starting Jan 1, 1970, UTC, ignoring leap seconds) according to the sender's internal clock. Clocks are not required to be set correctly by the basic TLS protocol; higher-level or application protocols may define additional requirements. Note that, for historical reasons, the data element is named using GMT, the predecessor of the current worldwide time base, UTC.

Java時刻JavaScript時刻

[14] JavaCalendar >>27JavaScriptDate の値も Unix time と同じ元期ですが、ミリ秒単位となっています。 (こちらも閏秒は考えません。)

[24] DOM日時を扱う API (DOMTimeStamp) も、 ミリ秒単位の千倍 Unix time を用いています。

[46] DateTime Wire Format でも使われています。

[27] Calendar (Java Platform SE 7 ) () <http://docs.oracle.com/javase/jp/7/api/java/util/Calendar.html>

特定の時点は、1970 年 1 月 1 日 00:00:00.000 GMT (グレゴリオ暦) を元期とするミリ秒単位のオフセットで表現できます。

Go時刻

[34] GoTime は、ナノ秒単位の Unix time を用いています。

[33] time - The Go Programming Language () <https://golang.org/pkg/time/#Time>

The zero value of type Time is January 1, year 1, 00:00:00.000000000 UTC.

関連

[47] PTP元期も同じくですが、 TAI を使っているので Unix time とは少しずれています。

メモ

[1] スラッシュドット ジャパン | 明日でepochから2^30秒 <http://slashdot.jp/article.pl?sid=04/01/08/172200&mode=flat&commentsort=4&threshold=-1>

[16] time_t - Wikipedia ( ( 版)) <http://ja.wikipedia.org/wiki/Time_t>

[17] Unix time - Wikipedia, the free encyclopedia ( ( 版)) <http://en.wikipedia.org/wiki/Unix_time>

[8] iPhoneを「1970年1月1日」に設定すると利用不能になる問題、Appleがソフト更新で解消へ - ITmedia ニュース ( 版) <http://www.itmedia.co.jp/news/articles/1602/16/news132.html>

[9] iPhoneで「1970年1月1日」に設定すると使用不能に? 実際に試してみた - ITmedia Mobile ( 版) <http://www.itmedia.co.jp/mobile/articles/1602/12/news125.html>

[19] WebDriver () <https://w3c.github.io/webdriver/webdriver-spec.html#dfn-unix-epoch>

[26] 電子機器の時刻 () <http://www.ffortune.net/calen/calen/etime.htm>

2001年9月9日1時46分40秒にこの数字が十進数で9桁から10桁に変わりました。2chなどではこの数字を掲示板のidに使用しているため、この前後での掲示板の並べ替えがうまく行きません。

[28] () <http://cr.yp.to/proto/utctai.html>

What is the epoch? Originally it was defined as the beginning of 1970 GMT. GMT, Greenwich Mean Time, is a traditional term for the time zone in England. Unfortunately, it is ambiguous; it can refer to a variety of astronomical time scales.

Arthur David Olson's popular time library uses an epoch of 1970-01-01 00:00:10 TAI.

[29] perlvms - search.cpan.org () <http://search.cpan.org/dist/perl/pod/perlvms.pod#time>

The value returned by time is the offset in seconds from 01-JAN-1970 00:00:00 (just like the CRTL's times() routine), in order to make life easier for code coming in from the POSIX/Unix world.

[30] File API () <https://w3c.github.io/FileAPI/#UnixEpoch>

[35] time - The Go Programming Language () <https://golang.org/pkg/time/#Time.UnixNano>

UnixNano returns t as a Unix time, the number of nanoseconds elapsed since January 1, 1970 UTC.

[36] SANS Digital Forensics and Incident Response Blog | Understanding EXT4 (Part 2): Timestamps | SANS Institute () <https://digital-forensics.sans.org/blog/2011/03/14/digital-forensics-understanding-ext4-part-2-timestamps>

[39] Add PushSubscription.expirationTime (#248) (beverloo著, ) <https://github.com/w3c/push-api/commit/73da6411aac80de7de9bf5e65ee8eb4cc6a9aa24>

[40] Epoch (astronomy) - Wikipedia () <https://en.wikipedia.org/wiki/Epoch_(astronomy)>

[41] General Concepts () <http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap04.html#tag_04_16>

[42] RFC 7519 - JSON Web Token (JWT) () <https://tools.ietf.org/html/rfc7519#section-2>

NumericDate

A JSON numeric value representing the number of seconds from

1970-01-01T00:00:00Z UTC until the specified UTC date/time,

ignoring leap seconds. This is equivalent to the IEEE Std 1003.1,

2013 Edition [POSIX.1] definition "Seconds Since the Epoch", in

which each day is accounted for by exactly 86400 seconds, other

than that non-integer values can be represented.

[43] RFC 7049 - Concise Binary Object Representation (CBOR) () <https://tools.ietf.org/html/rfc7049#section-2.4.1>

Tag value 1 is for numerical representation of seconds relative to

1970-01-01T00:00Z in UTC time. (For the non-negative values that the

Portable Operating System Interface (POSIX) defines, the number of

seconds is counted in the same way as for POSIX "seconds since the

epoch" [TIME_T].) The tagged item can be a positive or negative

integer (major types 0 and 1), or a floating-point number (major type

7 with additional information 25, 26, or 27). Note that the number

can be negative (time before 1970-01-01T00:00Z) and, if a floating-

point number, indicate fractional seconds.

[44] レシートのフィールド () <https://developer.apple.com/jp/documentation/General/ValidateAppStoreReceipt/Chapters/ReceiptFields.html>

定期購読の有効期限が、1970年1月1日 00:00:00 GMTからのミリ秒単位で表されています。

ASN.1フィールドタイプ:1708

ASN.1フィールド値: IA5STRING(RFC 3339の日付として解釈されます)

JSONフィールド名:expires_date

JSONフィールド値:数値

[48] プログラマーの常識をJavaで身につける(4):OSとプログラミングの「時間」に関する常識 (1/3) - @IT () <http://www.atmarkit.co.jp/ait/articles/0703/28/news135.html>

具体的には、1970年1月1日 00:00:00 GMTからのミリ秒数を表すlong値として表現されています。この原稿では、これを便宜的に「エポックからのミリ秒」と呼ぶことにします。なお、1970年1月1日 00:00:00 GMTについてJava言語APIでは、「エポック」と呼んでいます。

[49] 日付関数またはタイムスタンプ関数の日付部分 - Amazon Redshift () <http://docs.aws.amazon.com/ja_jp/redshift/latest/dg/r_Dateparts_for_datetime_functions.html>

Amazon Redshift の EPOCH の実装は、サーバーのあるタイムゾーンから独立した 1970-01-01 00:00:00.000000 に関連します。

[50] タイムスタンプ型 | CQL for Cassandra 2.x () <https://docs.datastax.com/ja/cql-jajp/3.1/cql/cql_reference/timestamp_type_r.html>

タイムスタンプ型の値は64ビットの符号付き整数としてエンコードされ、エポックとして知られる標準基準時間(1970年1月1日、GMT時間0時0分0秒)からのミリ秒数を表します。

[51] GitHub API v3 | GitHub Developer Guide () <https://developer.github.com/v3/#rate-limiting>

The time at which the current rate limit window resets in UTC epoch seconds.

[52] docker service logs | Docker Documentation () <https://docs.docker.com/engine/reference/commandline/service_logs/#extended-description>

When providing Unix timestamps enter seconds[.nanoseconds], where seconds is the number of seconds that have elapsed since January 1, 1970 (midnight UTC/GMT), not counting leap seconds (aka Unix epoch or Unix time), and the optional .nanoseconds field is a fraction of a second no more than nine digits long.

[53] 取引所APIドキュメント | Coincheck(コインチェック) () <https://coincheck.com/ja/documents/exchange/api>

ACCESS-NONCE 毎リクエストごとに増加する必要のある正の整数。通常はUNIXタイムスタンプを用います。最大値は 9223372036854775807 です。APIキーごとに管理されます。

[54] Make Event's timeStamp use DOMHighResTimeStamp (majido著, ) <https://github.com/whatwg/dom/commit/912d58746bc4c67c2fd210124639f7c34991fce5>

[57] Git - git-commit Documentation () <https://git-scm.com/docs/git-commit#_date_formats>

Git internal format

It is <unix timestamp> <time zone offset>, where <unix timestamp> is the number of seconds since the UNIX epoch. <time zone offset> is a positive or negative offset from UTC. For example CET (which is 1 hour ahead of UTC) is +0100.

[58] Concise Binary Object Representation (CBOR) () <https://cbor-wg.github.io/CBORbis/#datetimesect>

Tag value 1 is for numerical representation of seconds relative to 1970-01-01T00:00Z in UTC time. (For the non-negative values that the Portable Operating System Interface (POSIX) defines, the number of seconds is counted in the same way as for POSIX “seconds since the epoch” [TIME_T].) The tagged item can be a positive or negative integer (major types 0 and 1), or a floating-point number (major type 7 with additional information 25, 26, or 27). Note that the number can be negative (time before 1970-01-01T00:00Z) and, if a floating-point number, indicate fractional seconds.