Note that EDT is a daylight saving time/summer time zone. It is generally only used during the summer in the places listed below, during the winter EST is used instead
Note that most places observe daylight saving time/summer time during summer, and are therefore using EDT instead in the summer. See below for details.
协调世界时(=Universal Time Coordinated)(过去曾用格林威治平均时GMT来表示)
http://desktoplinux.com/news/NS3988059943.html
Mar. 09, 2007
Analysis -- "Spring forward; Fall back," That's the way the saying goes. Some years I get it backwards, but I eventually catch on. I've never had to worry about my PCs getting it wrong before, though. Now, with the recent changes in the Daylight Savings Time (DST) rules, I do.
Fortunately, there are ways to make sure that both my Linux computers and I get the new rules right.
Spread the word: |
Until now, most of us in the U.S. would set our clocks forward an hour in April and back an hour in October. However, in 2005, Congress
passed the Energy Policy Act, which amended the Uniform Time Act of 1966. This turned our old, reliable Daylight Savings Time completely inside-out. The change goes into effect this year.
From now on, instead of DST starting on the first Sunday in April, it starts on the second Sunday of March. (This year, that's March 11.) Come Fall, Daylight Savings will end on the first Sunday in November -- November 4, this year -- instead of the last Sunday of October.
That means one big mess for many pre-2005 programs and operating systems, which have the old April/October DST rules hardwired into them.
Now, unlike Windows, Linux and the rest of the Unix operating system family don't have Daylight Savings Time innately. Instead, they use an entirely different way of telling time.
Most Linux systems have two clocks. The hardware clock, a.k.a. the "CMOS clock," is present in most x86-based systems. The CMOS, a battery-backed time clock located on the motherboard, runs 24/7. The system clock, on the other hand, starts when you boot up your system. This is the clock used by most internal Linux programs and Linux applications.
By default, the system clock takes its cue from the CMOS. A far better way to set up the system clock, if you have an Internet connection (and who doesn't?), is to use a program like
ntpd. This program uses the NTP (network time protocol) to obtain the correct time from an NTS (network time server).
Some older Linux and Unix systems required you to use a program called
ntpdate to actually set the time manually. Now, that functionality is included in the ntpd package.
The system clock, no matter how you update it, doesn't keep time the way most of us do. For Linux, the universe began at midnight UTC (a.k.a.
Coordinated Universal Time), or 12:00 a.m. on Jan. 1, 1970. The system clock tells time by counting the number of seconds since the Linux "universe" began. This method of telling time is referred to as the
(As an aside, since most computers store the Epoch's number of seconds as a 32-bit signed integer, the "End of Time" will come at 03:14:07 UTC on Tuesday, Jan. 19, 2038. That, however, is a problem for another day.)
Notice something missing? In all this talk of timekeeping, there's no mention of DST -- or of time zones, for that matter. That's because Linux doesn't track those with its time programs. Instead, Linux stores its time zone and DST information in the specific file, /usr/share/zoneinfo. Older Linux systems may store the information in the file, /usr/lib/zoneinfo, instead. The local time zone and DST are both usually determined by a symbolic link to /etc/localtime.
To make sure your Linux system knows when DST is, this year and ever on, you need to update your zoneinfo file, or replace it with one that contains the new rules.
If you've been keeping your system updated, most modern Linuxes will have automatically updated your computer with the correct DST information. If you haven't updated your computer for a while with the latest patches,
do it now. That may be all you need to do to be ready for the new DST.
Some (but not all) Linux and Unix distributions give instructions on how to use their update tools to set your system up with the new DST. The ones we're aware of at this time are
AIX,
Mac OS, and
Once you've done that, it's time to check to see if you have the right DST settings. How do you make sure? Unfortunately, you can't just look at your zoneinfo files; they're not human-readable.
Instead, you need to use the
zdump command from a shell interface. Zdump prints the current time in each zonename named on the command line. For our purposes, you'll need to run the following command:
-
zdump -v /etc/localtime | grep 2007
If you don't get any result from the zdump command, your system may need you to specify your time zone information.
For example,
-
$ zdump -v /etc/localtime EST5EDT | grep 2007
is what you would use for the U.S. Eastern time zone. If you're in the Central time zone, use CST6CDT; in the Mountain time zone use MST7MDT; and in the Pacific time zone, use PST8PDT.
If your system is set up properly, it will return a display that starts with two lines containing "Sun Mar 11". If, instead, you see a pair of lines with "Sun Apr 1" within them, you'll need to do a manual update.
This will take a little time at your shell interface, but it's not difficult.
First, you need to see exactly how much work you'll need to do. For example, older Linux systems, such as Red Hat 9 and earlier use versions of the glibc library whih are older than 2.3.2-64 (circa July 28 2003). In these older glibc files, the zoneinfo is actually integrated into the library. If that's your situation, you'll also need to upgrade glibc to 2.3.2-65 or later. You may also need to upgrade other associated C files to glibc-common-2.2.4-32.23; glibc-devel-2.2.4-32.23; glibc-profile-2.2.4-32.23 and nscd-2.2.4-32.23.
What version do you have? You can find out by running:
-
$ ls /lib/libc-*
If you have an older version, you'll need to update it. As you might guess, the details vary on how to do this depending upon your distribution. The best thing to do is to see what your Linux provider has to say about fixing up your specific distribution. Another way is to use the code file, tzcode2007c.tar.gz. First though, let's get the timezone data files.
So, use your Web browser to check for the most up-to-date time zone and DST information files at the site:
-
ftp://elsie.nci.nih.gov/pub/
When I checked on it, on March 5, the most current data file was tzdata2007c.tar.gz.
Next, if you don't have a directory you already use for temporary files and downloads, set one up. A good name for such a directory in this case might be tzdata. You can make this directory, and then move to it with the following commands:
-
$ mkdir tzdata
$ cd tzdata
Now, download it to your system with at ftp utility. If nothing else, you almost certainly have a copy of wget. Run:
-
$ wget ftp://elsie.nci.nih.gov/pub/tzdata2007c.tar.gz
Once you have the file in hand, decompress it with an archive utility such as tar:
-
$ tar -xzvf tzdata2007c.tar.gz
Now that you have the chronological information you need, it's time to put it in the proper format. You can either switch to the root user, or use the sudo command, to run the following:
-
# zic -d zoneinfo northamerica
# cd zoneinfo
# cp -r * /usr/share/zoneinfo/
Zic will transform the data into the form Linux needs; and the other commands will copy the new information to the proper directory. If you're using an older version of Linux, you may need to place the file in that directory like so:
-
# cp -r * /usr/lib/zoneinfo/
Some systems do not automatically link from /etc/localtime to either /usr/share/zoneinfo on newer Linuxes or /usr/lib/zoneinfo on older versions of Linux. If you're still not geting the right date, run the following command either as root or by using sudo:
-
ln -fs /usr/share/zoneinfo/CST6CDT /etc/localtime
Insert the appropriate file directory name with your local time zone into your command. This creates the symbolic link to the correct DST setting.
Now, if you have didn't need to update your glibc files, you're good to go. If you're still stuck with older glibc, you need to download tzcode2007c.tar.gz and place it in a temporary directory. I sugest using one called tzdir. Once it's there, decompress it with a command like...
-
$ tar -xzvf tzdata2007c.tar.gz
Within this new directory tree, you'll now find a "Makefile." Read it and make any changes needed to make things right for your system, and then run the commands it gives you. Be certain, of course, to use the installation directory that's right for your system.
All done? Now, let's check to make sure we're set up properly with the new DST by going back and using our zdump routine again:
-
zdump -v /etc/localtime | grep 2007
An amusing way to check is to visit the University of Minnesota's DST time check site. This detects if your system is set up correctly by using JavaScript. This will work with any system that has a JavaScript-enabled Web browser. The site will display a big end-user-friendly green, yellow, or red dot depending on your PC's DST settings.
All set? Great! I told you it wasn't too hard.
The final touch is to make sure all your daemon services know about the DST change. Many important background applications, like sendmail, postfix, MySQL, and BIND named, only load /etc/localtime -- that is, they only check the date and time -- when they're starting up. Rather than track such applications down, the best thing to do is to simply reboot the system. That way, all the services will start fresh, with the correct DST time information safely locked into your CMOS clock.
At this point, your PC should be fine until either Congress changes the DST rules again, or we reach the Epoch. Here's hoping that it will be the Epoch, and not another government mandated time change.
Hey, look on the bright side: at least it's not Y2K and you're not trying to set DST up properly in Windows!
[And a tip of the hat to bill, jimbudler, mikeraz, willi290, keys and others whose suggestions and questions helped improved this revised article. Any mistakes remaining are all mine.]
-- Steven J. Vaughan-Nichols
=================
http://www.linuxsa.org.au/tips/time.html
Linux, Clocks, and Time
Introduction
This document explains how to set your computer's clock from Linux, how to set your timezone, and other stuff related to Linux and how it does its time-keeping.
Your computer has two timepieces; a battery-backed one that is always running (the ``hardware'', ``BIOS'', or ``CMOS'' clock), and another that is maintained by the operating system currently running on your computer (the ``system'' clock). The hardware clock is generally only used to set the system clock when your operating system boots, and then from that point until you reboot or turn off your system, the system clock is the one used to keep track of time.
On Linux systems, you have a choice of keeping the hardware clock in UTC/GMT time or local time. The preferred option is to keep it in UTC because then daylight savings can be automatically accounted for. The only disadvantage with keeping the hardware clock in UTC is that if you dual boot with an operating system (such as DOS) that expects the hardware clock to be set to local time, the time will always be wrong in that operating system.
Setting your timezone
The timezone under Linux is set by a symbolic link from /etc/localtime
[1] to a file in the/usr/share/zoneinfo
[2] directory that corresponds with what timezone you are in. For example, since I'm in South Australia,/etc/localtime
is a symlink to/usr/share/zoneinfo/Australia/South
. To set this link, type:
ln -sf ../usr/share/zoneinfo/your/zone /etc/localtime
Replace your/zone
with something like Australia/NSW
orAustralia/Perth
. Have a look in the directories under/usr/share/zoneinfo
to see what timezones are available.
[1] This assumes that /usr/share/zoneinfo
is linked to/etc/localtime
as it is under Red Hat Linux.
[2] On older systems, you'll find that /usr/lib/zoneinfo
is used instead of/usr/share/zoneinfo
. See also the later section ``The time in some applications is wrong''.
Setting UTC or local time
When Linux boots, one of the initialisation scripts will run the /sbin/hwclock
program to copy the current hardware clock time to the system clock.hwclock
will assume the hardware clock is set to local time unless it is run with the--utc
switch. Rather than editing the startup script, under Red Hat Linux you should edit the/etc/sysconfig/clock
file and change the ``UTC
'' line to either ``UTC=true'' or ``UTC=false'' as appropriate.
Setting the system clock
To set the system clock under Linux, use the date
command. As an example, to set the current time and date to July 31, 11:16pm, type ``date 07312316
'' (note that the time is given in 24 hour notation). If you wanted to change the year as well, you could type ``date 073123161998
''. To set the seconds as well, type ``date 07312316.30
'' or ``date 073123161998.30
''. To see what Linux thinks the current local time is, rundate
with no arguments.
Setting the hardware clock
To set the hardware clock, my favourite way is to set the system clock first, and then set the hardware clock to the current system clock by typing ``/sbin/hwclock --systohc
'' (or ``/sbin/hwclock --systohc --utc
'' if you are keeping the hardware clock in UTC). To see what the hardware clock is currently set to, runhwclock
with no arguments. If the hardware clock is in UTC and you want to see the local equivalent, type ``/sbin/hwclock --utc
''
The time in some applications is wrong
If some applications (such as date
) display the correct time, but others don't, and you are running Red Hat Linux 5.0 or 5.1, you most likely have run into a bug caused by a move of the timezone information from/usr/lib/zoneinfo
to /usr/share/zoneinfo
. The fix is to create a symbolic link from/usr/lib/zoneinfo
to/usr/share/zoneinfo
: ``ln -s ../share/zoneinfo /usr/lib/zoneinfo
''.
Summary
-
/etc/sysconfig/clock
sets whether the hardware clock is stored as UTC or local time. - Symlink
/etc/localtime
to/usr/share/zoneinfo/...
to set your timezone. - Run ``
date MMDDhhmm
'' to set the current system date/time. - Type ``
/sbin/hwclock --systohc [--utc]
'' to set the hardware clock.
Other interesting notes
The Linux kernel always stores and calculates time as the number of seconds since midnight of the 1st of January 1970 UTC regardless of whether your hardware clock is stored as UTC or not. Conversions to your local time are done at run-time. One neat thing about this is that if someone is using your computer from a different timezone, they can set the TZ environment variable and all dates and times will appear correct for their timezone.
If the number of seconds since the 1st of January 1970 UTC is stored as an signed 32-bit integer (as it is on your Linux/Intel system), your clock will stop working sometime on the year 2038. Linux has no inherent Y2K problem, but it does have a year 2038 problem. Hopefully we'll all be running Linux on 64-bit systems by then. 64-bit integers will keep our clocks running quite well until aproximately the year 292271-million.
Other programs worth looking at
-
rdate
- get the current time from a remote machine; can be used to set the system time. -
xntpd
- likerdate
, but it's extremely accurate and you need a permanent 'net connection.xntpd
runs continuously and accounts for things like network delay and clock drift, but there's also a program (ntpdate
) included that just sets the current time like rdate does.
Further information
-
date(1)
-
hwclock(8)
/usr/doc/HOWTO/mini/Clock
标签:set,clock,DST,Linux,Daylight,system,Savings,time,your From: https://blog.51cto.com/u_16174476/6616440