日常异常(10)

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

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 关注

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖
  • 电影

    这是一个不能说的秘密。

    125 引用 • 610 回帖
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 44 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    20 引用 • 37 回帖 • 577 关注
  • Office

    Office 现已更名为 Microsoft 365. Microsoft 365 将高级 Office 应用(如 Word、Excel 和 PowerPoint)与 1 TB 的 OneDrive 云存储空间、高级安全性等结合在一起,可帮助你在任何设备上完成操作。

    6 引用 • 35 回帖
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • IDEA

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

    182 引用 • 400 回帖 • 1 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1062 引用 • 3456 回帖 • 124 关注
  • C++

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

    110 引用 • 153 回帖
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖 • 16 关注
  • OpenCV
    15 引用 • 36 回帖 • 1 关注
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 8 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    167 引用 • 408 回帖 • 494 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    173 引用 • 1559 回帖
  • 大数据

    大数据(big data)是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。

    91 引用 • 113 回帖
  • 笔记

    好记性不如烂笔头。

    315 引用 • 790 回帖
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    502 引用 • 1397 回帖 • 241 关注
  • OneDrive
    2 引用 • 2 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    45 引用 • 44 回帖 • 2 关注
  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    文档地址:sillot.db.sc.cn

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    3. ⚠️ 汐洛绞架基于思源笔记,开发者尽最大努力与思源笔记保持兼容,但无法实现 100% 兼容
    29 引用 • 25 回帖 • 152 关注
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 563 关注
  • Word
    13 引用 • 41 回帖 • 1 关注
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3206 引用 • 8217 回帖
  • CAP

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

    12 引用 • 5 回帖 • 660 关注
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    56 引用 • 85 回帖 • 1 关注