日常异常(10)

本贴最后更新于 2509 天前,其中的信息可能已经斗转星移

tomcat+ubuntu 时差问题

前言:虚拟机上玩的 ubuntu,配了 java 环境,装了 ftp、ssh、tomcat、nginx;部署了项目,启动 tomcat,发现 tomcat 打的日志时间和 windows 时间不对。还有 ubuntu 的时间也不对。

先把 ubuntu 的时间修改,然后修改 tomcat 的时间差;


以下方法适用于所有 Linux 发行版。首先打开一个终端窗口,输入下面的命令。

sudo ln -sf /usr/share/zoneinfo

先不要按 Enter 键,我们需要按一下 Tab 键。终端会列出许多地理位置。

sudo ln -sf /usr/share/zoneinfo/{your-geographic-area}/{your-city} /etc/localtime

现在按 Enter 键运行这个命令。它会创建一个软链接,将/etc/localtime 文件指向对应的时区文件。你的系统时间会立即发生改变,可以用 date 命令查看。但有一些桌面环境,如 XFCE,任务栏的时间不会改变,用户需要重新登录才能看到变化。


在低版本的 ubuntu 里面以下命令失效

Real Time Clock

RTC 的全称是 Real Time Clock,也叫做硬件时钟(hardware clock). RTC 时间是由主板的 CMOS 电池驱动的。即使你关闭电脑,RTC 时钟也会一直运转,除非 CMOS 电池没电了。很多情况下,RTC 时间并不准确。

要查看你的 RTC 时间,输入以下命令

timedatectl

输出结果

Local time: Wed 2016-03-02 17:47:19 CST
Universal time: Wed 2016-03-02 09:47:19 UTC
RTC time: Wed 2016-03-02 09:47:19
Time zone: Asia/Shanghai (CST, +0800)
Network time on: yes
NTP synchronized: yes
RTC in local TZ: no

你可以看见,我的本地时间是**17:49:19, **但 RTC 时间是 09:47:19。RTC 时间与本地时间不相同。有时候这会给系统的程序带来问题。RTC 时间是不可靠的。

RTC 时间默认没有时区。要让系统以 UTC 时区读取 RTC 时间,执行下面的命令

timedatectl set-local-rtc 0

要让系统以本地时区读取 RTC 时间,运行这个命令。

timedatectl set-local-rtc 1

推荐以 UTC 时区读取 RTC 时间,这可以减少麻烦。


让系统时间与本地时区时间自动同步

有时候,即使你正确设置好了时区,你的系统时间仍然有可能不准确。我们可以使用 NTP 协议来让系统时间与本地时区时间自动同步。

许多程序需要准确的时间才能发挥应有的功能。而 NTP 可以为网络上的机器提供精确的时间。NTP 是一个应用层协议,使用 UDP 作为传输层协议。NTP 时间服务器从原子钟(atomic clock)获取精确的时间。

使用 Systemd 的 Linux 系统可以用以下命令启用 NTP 网络时间自动同步。

timedatectl set-ntp true

这条命令会启动 systemd-timesyncd 服务。查看 NTP 状态 。

timedatectl status

输出结果:

Local time: Wed 2016-03-02 18:30:35 CST
Universal time: Wed 2016-03-02 10:30:35 UTC
RTC time: Wed 2016-03-02 10:30:35
Time zone: Asia/Shanghai (CST, +0800)
Network time on: yes
NTP synchronized: yes
RTC in local TZ: no

**网络时间(network time)**为 Yes 就表示启用了 NTP 时间同步,**NTP 同步(NTP synchronized)**有两个状态:Yes 或 No。如果 Network time 没有启用,那么 NTP 同步的状态一定为 No。现在可以查看 systemd-timesyncd 的状态。

sudo systemctl status systemd-timesyncd

输出结果:

● systemd-timesyncd.service - Network Time Synchronization
Loaded: loaded (/usr/lib/systemd/system/systemd-timesyncd.service; enabled; vendor preset: enabled)
Active: active (running) since Wed 2016-03-02 18:30:29 CST; 1h 37min ago
Docs: man:systemd-timesyncd.service(8)
Main PID: 2243 (systemd-timesyn)
Status: "Synchronized to time server 202.112.29.82:123 (0.arch.pool.ntp.org)."
Tasks: 2 (limit: 512)
CGroup: /system.slice/systemd-timesyncd.service
└─2243 /usr/lib/systemd/systemd-timesyncd

可以发现,系统与 202.112.29.82 这台时间服务器同步成功了


修改到这里机器的时间正常了,但是 tomcat 的时间依旧不正常,继续。

tomcat 的时间修改:

1.通过启动参数,通过 ide 修改启动参数就不说了,在服务器上是没有 ide 的,修改 tomcat 的启动文件 catalina.bat/sh

${catalina_home}/bin/catalina.sh 文件中的 JAVA_OPTS 启动参数中做了以下调整:

JAVA_OPTS=" -Duser.timezone=GMT+08"

即增加了时区选项-Duser.timezone=GMT+08,重新启动 Tomcat,log 日志的时间正确了。

为什么时间需要同步,时间不一致会导致很奇怪的问题,奇怪到你解决不了。

参考资料:https://www.linuxdashen.com/linux%E7%B3%BB%E7%BB%9F%E7%94%A8%E5%91%BD%E4%BB%A4%E9%85%8D%E7%BD%AE%E6%97%B6%E5%8C%BA%E5%B9%B6%E5%90%8C%E6%AD%A5%E7%B3%BB%E7%BB%9F%E6%97%B6%E9%97%B4

Tomcat7.x时区问题导致时间获取不正确 - 千山独行 - ITeye博客

  • 后端
    44 引用 • 126 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 54 回帖 • 49 关注
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 75 关注
  • SEO

    发布对别人有帮助的原创内容是最好的 SEO 方式。

    35 引用 • 200 回帖 • 27 关注
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    89 引用 • 345 回帖 • 1 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 76 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    107 引用 • 153 回帖
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    545 引用 • 672 回帖
  • CAP

    CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。

    11 引用 • 5 回帖 • 612 关注
  • 反馈

    Communication channel for makers and users.

    123 引用 • 913 回帖 • 250 关注
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 5 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    135 引用 • 190 回帖
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 394 关注
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖 • 1 关注
  • V2Ray
    1 引用 • 15 回帖 • 1 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    28 引用 • 108 回帖
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 653 关注
  • sts
    2 引用 • 2 回帖 • 197 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 483 关注
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 172 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 779 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    98 引用 • 344 回帖
  • abitmean

    有点意思就行了

    27 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 2 关注
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    86 引用 • 122 回帖 • 626 关注