首页 > 其他分享 >Daylight Savings Time (DST)

Daylight Savings Time (DST)

时间:2023-07-03 22:32:37浏览次数:60  
标签:set clock DST Linux Daylight system Savings time your


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:
digg this story

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

Unix Epoch.



(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,

Debian Testing,

Debian Unstable,

FreeBSD,

Novell SUSE Linux Enterprise,

Red Hat Linux,

Mac OS, and

Solaris.



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 - like rdate, 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

相关文章

  • 在Androidstudio 中 通过jni java 和c++相互调用实现方法
    在Androidstudio中通过jnijava和c++相互调用实现方法1.创建javanative方法类publicclassNativeAPI{privatestaticfinalStringTAG=APP_TAG+"TestJni";static{System.loadLibrary("testnative");}//从c++so中获取字符串publicna......
  • Dstat 的使用
    概述安装yum-yinstalldstatdstat命令如果不添加参数,会默认添加-cdngy,并会有提示Youdidnotselectanystats,using-cdngybydefault.语法:dstat[-afv][options..][delay][count]参数CPU查看CPU使用率-c,--cpu#查看cpu使用率汇总信息[root@192-168-248-80......
  • findstr /s "AttachedDevice" *.cpp
    findstr/s"AttachedDevice"*.cppchapter22\FileFilter\DriverEntry.cpp:     if(!fido->AttachedDevice||(fido->AttachedDevice->Flags&DO_POWER_PAGABLE))chapter22\FileFilter\DriverEntry.cpp: PDEVICE_OBJECTldo=......
  • cloudstack的重新封装--api调用
    使用python将cloudstack的多个功能进行重新封装形成api调用。#coding=utf-8#!/usr/bin/envpythonimportbase64importhmacimportjsonimportrequestsimportsysimporttimeimporturllibimportreimporthashlibimportloggingLOG=logging.getLogger(__name__......
  • JDBC-API详解-PreparedStatement-原理
    /**PreparedStatement原理讲解*PreparedStatement的预编译功能用useServerPrepStmts=true开启**/@TestpublicvoidPreparedStatement2()throwsException{//1.注册驱动//Class.forName......
  • JDBC-API详解-PreparedStatement-SQL注入演示
       packageTest;importorg.junit.Test;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.ResultSet;importjava.sql.Statement;importjava.util.ArrayList;importjava.util.List;publicclassJDBCdemo5_UserLogin{/*......
  • SoundStream VS Lyra: 谷歌今年新推出的两款AI音频编解码器有何不同?
    作者 |Teresa、王晶技术审校 |王晶、王立众SoundStream 影音探索#001#近日,谷歌又推出了一款基于人工智能的音频编解码器——SoundStream,它是一款端到端的神经音频编解码器,可以提供更高质量的音频,同时编码不同的声音类型,包括干净的语音、嘈杂和混响的语音、音乐和环境声音。......
  • 1.1OpenDaylight的安装
    OpenDaylight的安装任务目的1、了解OpenDaylight的诞生背景和基本架构,能够对OpenDaylight整体架构有一个大体认识,从而更好的理解SDN架构。2、掌握安装、部署OpenDaylight的方法,能够独立解决实验过程中遇到的问题。通过安装OpenDaylight组件,对OpenDaylight组成有一个更具象的认......
  • 1.3OpenDaylight SFC项目基础
    OpenDaylightSFC项目基础任务目的1、了解OpenDaylightSFC项目。2、掌握手动配置SFC的基本操作。任务环境设备名称软件环境(镜像)硬件环境主机Ubuntu14.04桌面版OpenDaylightCarbonCPU:2核内存:4G磁盘:20G注:系统默认的账户为:管理员权限用户名:root,密码:root@......
  • 1.2使用OpenDaylight界面下发流表
    使用OpenDaylight界面下发流表任务目的1、掌握YANGUI下发流表的方式,了解YANGUI的功能特点,以及其在OpenDaylight架构中所起的作用。2、通过下发流表的过程,梳理出数据包处理的简单流程。并且进一步了解单级流表和多级流表的处理过程。任务环境设备名称软件环境(镜像)硬件......