iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >如何解决MySQL中timestamp时区转换导致CPU %sy高的问题
  • 658
分享到

如何解决MySQL中timestamp时区转换导致CPU %sy高的问题

2024-04-02 19:04:59 658人浏览 安东尼
摘要

本篇文章给大家分享的是有关如何解决Mysql中timestamp时区转换导致CPU %sy高的问题,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧

本篇文章给大家分享的是有关如何解决Mysql中timestamp时区转换导致CPU %sy高的问题,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

一、问题展示

下面是问题当时的系统负载如下:

如何解决MySQL中timestamp时区转换导致CPU %sy高的问题

我们可以看到40.4%sy 正是系统调用负载较高的表现,随即朋友采集了perf如下:

如何解决MySQL中timestamp时区转换导致CPU %sy高的问题

接下来朋友采集了pstack给我,我发现大量的线程处于如下状态下:

Thread 38 (Thread 0x7fe57a86f700 (LWP 67268)):
#0  0x0000003Dee4f82ce in __lll_lock_wait_private () from /lib64/libc.so.6
#1  0x0000003dee49df8d in _L_lock_2163 () from /lib64/libc.so.6
#2  0x0000003dee49dd47 in __tz_convert () from /lib64/libc.so.6
#3  0x00000000007c02e7 in Time_zone_system::gmt_sec_to_TIME(st_mysql_time*, long) const ()
#4  0x0000000000811df6 in Field_timestampf::get_date_internal(st_mysql_time*) ()
#5  0x0000000000809ea9 in Field_temporal_with_date::val_date_temporal() ()
#6  0x00000000005f43cc in get_datetime_value(THD*, Item***, Item**, Item*, bool*) ()
#7  0x00000000005e7ba7 in Arg_comparator::compare_datetime() ()
#8  0x00000000005eef4e in Item_func_gt::val_int() ()
#9  0x00000000006fc6ab in evaluate_join_record(JOIN*, st_join_table*) ()
#10 0x0000000000700e7e in sub_select(JOIN*, st_join_table*, bool) ()
#11 0x00000000006fecc1 in JOIN::exec() ()

我们可以注意一下__tz_convert 这正是时区转换的证据。

二、关于timestamp简要说明

timestamp:占用4字节,内部实现是新纪元时间(1970-01-01 00:00:00)以来的秒,那么这种格式在展示给用户的时候就需要做必要的时区转换才能得到正确数据。下面我们通过访问ibd文件来查看一下内部表示方法,使用到了我的两个工具innodb和bcview,详细参考 https://www.jianshu.com/p/719f1bbb21e8。

timestamp的内部表示

建立一个测试

mysql> show variables like '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone | CST    |
| time_zone        | +08:00 |
+------------------+--------+
mysql> create table tmm(dt timestamp);
Query OK, 0 rows affected (0.04 sec)
mysql> insert into tmm values('2019-01-01 01:01:01');
Query OK, 1 row affected (0.00 sec)

我们来查看一下内部表示如下:

[root@gp1 test]# ./bcview tmm.ibd 16 125 25|grep 00000003
current block:00000003--Offset:00125--cnt bytes:25--data is:000001ac3502000000070d52c80000002f01105c2a4b4d0000

整理一下如下:

  • 000001ac3502:rowid

  • 000000070d52:trx id

  • c80000002f0110:roll ptr

  • 5c2a4b4d:timestamp类型的实际数据十进制为1546275661

我们使用linux命令如下:

[root@gp1 ~]# date -d @1546275661
Tue Jan  1 01:01:01 CST 2019

因为我的Linux也是CST +8时区这里数据也和MySQL中显示一样。下面我们调整一下时区再来看看取值如下:

mysql> set time_zone='+06:00';
Query OK, 0 rows affected (0.00 sec)
mysql> select * from tmm;
+---------------------+
| dt                  |
+---------------------+
| 2018-12-31 23:01:01 |
+---------------------+
1 row in set (0.01 sec)

这里可以看到减去了2个小时,因为我的时区从+8变为了+6。

三、timestap转换

在进行新纪元时间(1970-01-01 00:00:00)以来的秒到实际时间之间转换的时候MySQL根据参数time_zone的设置有两种选择:

  • time_zone:设置为SYSTEM的话,使用sys_time_zone获取的OS会话时区,同时使用OS api进行转换。对应转换函数 Time_zone_system::gmt_sec_to_TIME

  • time_zone:设置为实际的时区的话,比如‘+08:00’,那么使用使用MySQL自己的方法进行转换。对应转换函数 Time_zone_offset::gmt_sec_to_TIME

实际上Time_zone_system和Time_zone_offset均继承于Time_zone类,并且实现了Time_zone类的虚函数进行了重写,因此上层调用都是Time_zone::gmt_sec_to_TIME。

注意这种转换操作是每行符合条件的数据都需要转换的。

四、问题修复方案

我们从问题栈帧来看这个故障使用的是 Time_zone_system::gmt_sec_to_TIME 函数进行转换的,因此可以考虑如下:

  • time_zone:设置为指定的时区,比如‘+08:00’。这样就不会使用OS API进行转换了,而转为MySQL自己的内部实现 调用 Time_zone_offset::gmt_sec_to_TIME函数。但是需要注意的是,如果使用MySQL自己的实现那么us%会加剧。

  • 使用datetime代替timestamp,新版本datetime为5个字节,只比timestamp多一个字节。

五、修复前后sy%使用量对比

据朋友说他大概在上午11点多完成了修改,做的方式是将 time_zone修改为‘+08:00’,下面展示修改前后CPU使用率的对比:

修复前:
如何解决MySQL中timestamp时区转换导致CPU %sy高的问题

修复后:

如何解决MySQL中timestamp时区转换导致CPU %sy高的问题

六、备用栈帧

  • time_zone=‘SYSTEM’转换栈帧

    #0  Time_zone_system::gmt_sec_to_TIME (this=0x2e76948, tmp=0x7fffec0f3ff0, t=1546275661) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/tztime.cc:1092
    #1  0x0000000000f6b65c in Time_zone::gmt_sec_to_TIME (this=0x2e76948, tmp=0x7fffec0f3ff0, tv=...) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/tztime.h:60
    #2  0x0000000000f51643 in Field_timestampf::get_date_internal (this=0x7ffe7ca66540, ltime=0x7fffec0f3ff0)
      at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/field.cc:6014
    #3  0x0000000000f4ff49 in Field_temporal_with_date::val_str (this=0x7ffe7ca66540, val_buffer=0x7fffec0f4370, val_ptr=0x7fffec0f4370)
      at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/field.cc:5429
    #4  0x0000000000f11d7b in Field::val_str (this=0x7ffe7ca66540, str=0x7fffec0f4370) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/field.h:866
    #5  0x0000000000f4549d in Field::send_text (this=0x7ffe7ca66540, protocol=0x7ffe7c001e88) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/field.cc:1725
    #6  0x00000000014dfb82 in Protocol_text::store (this=0x7ffe7c001e88, field=0x7ffe7ca66540)
      at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/protocol_classic.cc:1415
    #7  0x0000000000fb06c0 in Item_field::send (this=0x7ffe7c006ec0, protocol=0x7ffe7c001e88, buffer=0x7fffec0f4760)
      at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/item.cc:7801
    #8  0x000000000156b15c in THD::send_result_set_row (this=0x7ffe7c000b70, row_items=0x7ffe7c005d58)
      at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/sql_class.cc:5026
    #9  0x0000000001565758 in Query_result_send::send_data (this=0x7ffe7c006e98, items=...) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/sql_class.cc:2932
    #10 0x0000000001585490 in end_send (join=0x7ffe7c007078, qep_tab=0x7ffe7c0078d0, end_of_records=false)
      at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/sql_executor.cc:2925
    #11 0x0000000001582059 in evaluate_join_record (join=0x7ffe7c007078, qep_tab=0x7ffe7c007758)
  • time_zone=‘+08:00’转换栈帧

#0  Time_zone_offset::gmt_sec_to_TIME (this=0x6723d90, tmp=0x7fffec0f3ff0, t=1546275661) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/tztime.cc:1418
#1  0x0000000000f6b65c in Time_zone::gmt_sec_to_TIME (this=0x6723d90, tmp=0x7fffec0f3ff0, tv=...) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/tztime.h:60
#2  0x0000000000f51643 in Field_timestampf::get_date_internal (this=0x7ffe7ca66540, ltime=0x7fffec0f3ff0)
    at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/field.cc:6014
#3  0x0000000000f4ff49 in Field_temporal_with_date::val_str (this=0x7ffe7ca66540, val_buffer=0x7fffec0f4370, val_ptr=0x7fffec0f4370)
    at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/field.cc:5429
#4  0x0000000000f11d7b in Field::val_str (this=0x7ffe7ca66540, str=0x7fffec0f4370) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/field.h:866
#5  0x0000000000f4549d in Field::send_text (this=0x7ffe7ca66540, protocol=0x7ffe7c001e88) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/field.cc:1725
#6  0x00000000014dfb82 in Protocol_text::store (this=0x7ffe7c001e88, field=0x7ffe7ca66540)
    at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/protocol_classic.cc:1415
#7  0x0000000000fb06c0 in Item_field::send (this=0x7ffe7c006ec0, protocol=0x7ffe7c001e88, buffer=0x7fffec0f4760)
    at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/item.cc:7801
#8  0x000000000156b15c in THD::send_result_set_row (this=0x7ffe7c000b70, row_items=0x7ffe7c005d58)
    at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/sql_class.cc:5026
#9  0x0000000001565758 in Query_result_send::send_data (this=0x7ffe7c006e98, items=...) at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/sql_class.cc:2932
#10 0x0000000001585490 in end_send (join=0x7ffe7c007078, qep_tab=0x7ffe7c0078d0, end_of_records=false)
    at /root/mysqlall/percona-server-locks-detail-5.7.22/sql/sql_executor.cc:2925
#11 0x0000000001582059 in evaluate_join_record (join=0x7ffe7c007078, qep_tab=0x7ffe7c007758)

以上就是如何解决MySQL中timestamp时区转换导致CPU %sy高的问题,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: 如何解决MySQL中timestamp时区转换导致CPU %sy高的问题

本文链接: https://www.lsjlt.com/news/62847.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何解决MySQL中timestamp时区转换导致CPU %sy高的问题
    本篇文章给大家分享的是有关如何解决MySQL中timestamp时区转换导致CPU %sy高的问题,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧...
    99+
    2024-04-02
  • 详解MySQL中timestamp和datetime时区问题导致做DTS遇到的坑
    目录MySQL中如何表示当前时间?结论验证坑MySQL中如何表示当前时间? 其实,表达方式还是蛮多的,汇总如下: Data T...
    99+
    2024-04-02
  • mysql的timestamp存在时区问题怎么解决
    本篇内容介绍了“mysql的timestamp存在时区问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有...
    99+
    2024-04-02
  • mysql的timestamp存在的时区问题怎么解决
    这篇文章主要讲解了“mysql的timestamp存在的时区问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql的timestamp存在的时...
    99+
    2024-04-02
  • 如何解决CPU超频导致Win7蓝屏的问题
      超频是一项电脑DIYer热爱的活动,通过超频可以让硬件发挥出潜藏着的性能。但是超频也有不少风险,就拿CPU超频来说,它可能导致电脑出现蓝屏。下面就讲解一下CPU   CPU超频后系统蓝屏如何来解决?   CPU超频...
    99+
    2023-06-09
    CPU 超频 Win7 蓝屏 问题
  • 如何解决Mybatis导致的问题
    本篇内容介绍了“如何解决Mybatis导致的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!背景前段时间...
    99+
    2024-04-02
  • 如何解决MySQL大小写敏感导致的问题
    小编给大家分享一下如何解决MySQL大小写敏感导致的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!MYSQL对大小写敏感见字...
    99+
    2024-04-02
  • 如何解决Mysql导入导出时遇到的问题
    这篇文章给大家分享的是有关如何解决Mysql导入导出时遇到的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。背景自从把我手上的任务全部转换成docker运行和管理之后,遇到了一...
    99+
    2024-04-02
  • 如何解决使用stream将list转map时key重复导致报错的问题
    这篇文章将为大家详细讲解有关如何解决使用stream将list转map时key重复导致报错的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。要将List对象集合转为map集合,可以通过stream流的形...
    99+
    2023-06-15
  • 怎么解决Mysql tools中orztop导致的错误问题
    这篇文章主要介绍“怎么解决Mysql tools中orztop导致的错误问题”,在日常操作中,相信很多人在怎么解决Mysql tools中orztop导致的错误问题问题上存在疑惑,小编查阅了各式资料,整理出...
    99+
    2024-04-02
  • 如何解决服务器大量php-cgi.exe进程导致CPU占用100%的问题
    本篇内容主要讲解“如何解决服务器大量php-cgi.exe进程导致CPU占用100%的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决服务器大量php-cgi.exe进程导致CPU占用...
    99+
    2023-06-20
  • 如何解决docker中mysql时间与系统时间不一致问题
    这篇文章将为大家详细讲解有关如何解决docker中mysql时间与系统时间不一致问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。最近在Docker中装mysql时,发现数据库时间与系统时间相差8个小时。...
    99+
    2023-06-22
  • 如何解决磁盘写满导致MySQL复制失败的问题
    小编给大家分享一下如何解决磁盘写满导致MySQL复制失败的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!案例场景     &nb...
    99+
    2023-06-14
  • 解决使用stream将list转map时,key重复导致报错的问题
    要将List对象集合转为map集合,可以通过stream流的形式快速实现转换: //三个Users对象组成一个List集合 List<Users> list = ne...
    99+
    2024-04-02
  • 如何解决MySQL存储时间出现不一致的问题
    小编给大家分享一下如何解决MySQL存储时间出现不一致的问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!用Java在获取了系统时间后,存入MySQL数据库时,当时间的类型为datetime或Timestamp时发现数据库...
    99+
    2023-06-14
  • 如何解决多个Tab页点击切换功能所导致的问题
    本篇内容主要讲解“如何解决多个Tab页点击切换功能所导致的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决多个Tab页点击切换功能所导致的问题”吧!大...
    99+
    2024-04-02
  • 如何解决Android中webview旋转屏幕导致页面重新加载问题
    这篇文章给大家分享的是有关如何解决Android中webview旋转屏幕导致页面重新加载问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Android webview旋转屏幕导致页面重新加载问题解决办法1. 在...
    99+
    2023-05-30
    android webview
  • 如何解决springmvc不进入Controller导致404的问题
    这篇文章主要为大家展示了“如何解决springmvc不进入Controller导致404的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决springmvc不进入Controller导...
    99+
    2023-06-29
  • mysql中string和number的转换问题怎么解决
    本篇内容介绍了“mysql中string和number的转换问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!mysql中strin...
    99+
    2023-07-02
  • 如何解决cpu使用率忽高忽低的问题
    小编给大家分享一下如何解决cpu使用率忽高忽低的问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!首先要明白在哪里查看CPU使用率,鼠标右键点击桌面的底部工具栏,然后选择启动任务管理器。在弹出的Windows任务管理器选项...
    99+
    2023-06-28
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作