centos时区参考,centos9出来了吗

centos7安装root密码不正确怎么办

按照 cent os7安装详解的步骤安装以后,重启动,输入自己设置的root密码,总是被提示 incorrect login,就是无法登陆。之后看到网友提供的各种办法,比如注意大小写,您是不是密码忘了,甚至使用忘记密码的办法强行启动到单用户模式去重置root密码,事实是即使重置了密码还是无效。怎么试都不爽。

我觉得这可能是cent os一个bug。

解决的办法是,在安装时一定要选上我们中国时区,中文语言以及中文的键盘布局,不要按照详解的默认只选择美国时区和英语键盘布局。

具体步骤截图如下,供大家参考:

1、时区选择

Region,选择 Asia,City选择我们上海,时间选中当前时间,然后点击【Done】;

2、键盘布局的选择

点击【+】,将Chinese添加到上图列表,然后点击【Done】;

3、语言选择

将【中文】选中,右侧的【简体中文】选中,然后点击【Done】;

4、其他步骤同【】。

5、重启后,登陆界面:

出现localhost login:root

Password:【输入密码】回车即可。

CentOS服务器系统如何修改时区

修改CentOS服务器系统的时区,需遵循以下步骤。

首先,使用命令“tzselect”打开时区选择界面。

随后,依据界面上的提示,输入数字5,选择时区类别。

紧接着,输入数字9,进入特定时区列表。

之后,输入1,选择目标时区。

最后,输入数字1完成时区选择。

如图所示,操作流程清晰可见。

接着,执行“rm/etc/localtime”命令,删除原有时区链接。

删除后,重新建立正确的时区链接,使用命令“ln-s/usr/share/zoneinfo/Asia/Shanghai/etc/localtime;”。

完成链接后,通过输入“date”命令验证时区修改是否成功。

至此,CentOS服务器系统的时区修改完成,时间显示已调整至所选时区。

【UTC】CentOS7修改时区的正确姿势

整个地球分为二十四时区,每个时区都有自己的本地时间。在国际无线电通信场合,为了统一起见,使用一个统一的时间,称为通用协调时(UTC,Universal Time Coordinated)。

格林威治标准时间(Greenwich Mean Time)指位于英国伦敦郊区的皇家格林尼治天文台的标准时间,因为本初子午线被定义在通过那里的经线。(UTC与GMT时间基本相同,本文中不做区分)

中国标准时间(China Standard Time)【GMT + 8 = UTC + 8 = CST】

夏令时(Daylight Saving Time)指在夏天太阳升起的比较早时,将时钟拨快一小时,以提早日光的使用。(中国不使用)

RTC(Real-Time Clock)或CMOS时钟,一般在主板上靠电池供电,服务器断电后也会继续运行。仅保存日期时间数值,无法保存时区和夏令时设置。

一般在服务器启动时复制RTC时间,之后独立运行,保存了时间、时区和夏令时设置。

在CentOS 6版本,时间设置有date、hwclock命令,从CentOS 7开始,使用了一个新的命令timedatectl。

Centos7修改系统时区timezone ,解决快、慢8小时问题

如果服务器用非 UTC的时间,时区转换很容易不一致,而且对于有 daylight saving的时区,每年多一小时少一小时的那两天,系统就会出现各种诡异现象。

服务器使用UTC时间,如要显示用户所在时区的本地时间,在客户端转化即可。

# timedatectl

我们可以看到,服务器使用的CST时间

# timedatectl set-timezone UTC

# timedatectl set-time"YYYY-MM-DD HH:MM:SS"

# timedatectl set-time "HH:MM:SS"

# timedatectl

我们可以看到,服务器时间类型更改为UTC了

# ll /etc/locatime

lrwxrwxrwx. 1 root root 25 1月 14 08:30 /etc/localtime->../usr/share/zoneinfo/UTC

实际上是做了一个将 

 文件 /etc/localtime 做了一个软连接到 /usr/share/zoneinfo/UTC

# ln -s /usr/share/zoneinfo/UTC  /etc/localtime

ln:无法创建符号链接"/etc/localtime":文件已存在

# ln -sf /usr/share/zoneinfo/UTC   /etc/localtime

做软连接时,需要加-f参数,强制覆盖,不然会显示软链接已存在

# timedatectl set-time"YYYY-MM-DD HH:MM:SS"

# timedatectl set-time "HH:MM:SS"   //只设置时分秒

# timedatectl

# clock -w

# date -u  //显示UTC时间

CentOS7修改时区的正确姿势

CentOS7上运行Java程序,发现程序生成的时间与当前时间匹配不上,还以为是数据停止更新了,后来发现没有正确使用修改时区的姿势,导致程序时区错误。

正确的修改CentOS7时区的姿势:

#  ln -sf/usr/share/zoneinfo/Asia/Shanghai  /etc/localtime

其他系统的修改文件可能是/var/etc/localtime.

错误的姿势:通过cp命令覆盖/etc/localtime时间

 # cp-f /usr/share/zoneinfo/Asia/Shanghai  /etc/localtime

通过cp命令修改时区,通过date, data-R命令显示的时区都是正确的,可是对于java程序而言,是错误的。

具体原因在于Java访问系统时区的方式上,可参见文章:

Java TimeZone和 Linux TimeZone问题

该文章很好的说明了Java访问系统时区的方式:

1.如有环境变量 TZ设置,则用TZ中设置的时区

2.在/etc/sysconfig/clock文件中找“ZONE”的值

3.如何2)都没,就用/etc/localtime和/usr/share/zoneinfo下的时区文件进行匹配,如找到匹配的,就返回对应的路径和文件名。 

问题在于,如果使用cp命令来修改/etc/localtime文件,那么可能就会导致修改的不是/etc/localtime文件,而是原时区的文件内容。

/etc/localtime是通过符号链接链接/usr/share/zoneinfo下的文件,而java是通过文件名来确认时区的,data命令是通过文件内容确认时区的,这样就导致了data命令时区正确,而java的时区是错误的!

如上图所示:CentOS7是通过符号链接到/usr/share/zoneinfo/下的时区文件的,如果通过cp指令只会修改原时区文件内容,这样,通过date的系统命令,查看时间是OK的,可是java是通过读取文件名的方式确认时区信息的。所以时区还是纽约。

阅读剩余
THE END