mysql的time_zone导致性能下降

mysql的 time_zone有哪些

MySQL 的 time_zone 变量可以设置为多种不同的时区值。这些值通常由字母和数字组成,代表世界上不同的地理区域和它们的标准时间。以下是一些常见的 time_zone 设置选项:

UTC:协调世界时,是国际标准时间,不区分夏令时。
EST:北美东部标准时间。
CST:中国标准时间,也用于表示美国中部标准时间。
PST:太平洋标准时间。
MSK:莫斯科标准时间。

除了上述常用的时区外,还有许多其他的时区缩写,它们代表了全球各个地区的时间。在设置 time_zone 时,可以根据所在地理位置选择合适的时区。需要注意的是,当 time_zone 设置为 ‘system’ 时,MySQL 会使用系统时区,即 system_time_zone 的值,这个值是在 MySQL 启动时自动确定的,之后不会改变。如果需要查看当前 MySQL 的 time_zone 设置,可以通过 SHOW VARIABLES LIKE ‘%time_zone%’; 命令来查看。

此外,如果需要修改 time_zone,可以使用 SET GLOBAL time_zone = ‘时区值’; 命令来设置全局时区,或者使用 SET time_zone = ‘时区值’; 来为当前会话设置时区。例如,要将时区设置为东八区,可以使用 SET GLOBAL time_zone = ‘+8:00’;。

mysql的时区如何设置

MySQL的时区设置可以通过几种不同的方式进行修改,具体取决于你想要的是临时变更还是永久变更。

查看当前时区设置
可以使用 SHOW VARIABLES LIKE '%time_zone%'; 命令来查看当前的时区设置。这将返回两行记录,其中 time_zone 变量显示的是 MySQL 的时区设置,而 system_time_zone 显示的是系统时区。

临时修改会话时区
如果想要临时改变当前会话的时区,可以使用 SET time_zone = '+8:00'; 命令。这里的 +8:00 是时区偏移值,表示东八区。这个设置只对当前会话有效,当会话结束时,设置失效。如果需要使设置在会话结束后依然生效,可以使用 SET GLOBAL time_zone = '+8:00'; 命令来设置全局时区,但这需要重新连接 MySQL 才能生效。

永久修改时区
要永久更改 MySQL 的时区设置,需要在 MySQL 配置文件 my.cnf(或 my.ini)中进行修改。在 [mysqld] 部分添加或修改 default-time-zone 配置项,例如设置为 default-time-zone = '+8:00'。修改完成后,需要重启 MySQL 服务以使更改生效。

请注意,在进行任何时区设置更改之前,建议先备份相关配置文件,以防出现意外情况导致配置错误。此外,确保对时区设置有充分的了解,以避免因时区设置不当而导致的数据不一致问题。

mysql的time_zone 设置会什么问题

表字段时间戳是timestamp类型时,MySQL 在访问 timestamp 字段时会做时区转换,当 time_zone 设置为system时,MySQL 访问每一行的 timestamp 字段时,都会通过 libc 的时区函数,获取 Linux 设置的时区,在这个函数中会持有mutex,当大量并发SQL需要访问 timestamp 字段时,会出现 mutex 竞争。MySQL 访问每一行都会做这个时区转换,转换完后释放mutex,所有等待这个 mutex 的线程全部唤醒,结果又会只有一个线程会成功持有 mutex,其余又会再次sleep,这样就会导致 context switch 非常高但 qps 很低,系统吞吐量急剧下降,导致连接数堆积爆满。

如何解决这个问题

  1. 将 time_zone 设置为 UTC,这样 MySQL 在访问 timestamp 字段时就不会进行时区转换,从而避免 mutex 竞争。可以通过以下 SQL 语句设置:

    SET GLOBAL time_zone = '+00:00';
    
  2. 如果需要保留 system 时区设置,可以考虑使用 MySQL 的内置函数 CONVERT_TZ() 来进行时区转换。这样可以避免在访问 timestamp 字段时进行时区转换,从而减少 mutex 竞争。例如:

    SELECT CONVERT_TZ(timestamp_field, @@session.time_zone, '+00:00') FROM your_table;
    
  3. 考虑优化查询,尽量减少并发 SQL 对 timestamp 字段的访问。例如,可以使用索引来加速查询,或者将常用的计算结果缓存起来,避免重复计算。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/732817.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024年3月ZZUACM 招新赛题解

2024年3月ZZUACM 招新赛 题号题目A区间次大值B上课签到C魔法森林(一)D魔法森林(二)ELOPF跳格子G猜数字H抽卡记录I安达的二维矩阵J安达的数字手术K跳楼梯L前缀和 A 区间次大值—循环/签到题 题目描述 给定一个 n n n的全排列 a i…

顶顶通呼叫中心中间件(基于FreeSWITCH)对接mrcp asr 和 tts配置

介绍 顶顶通呼叫中心中间件通过asrproxy程序对接各种asr和tts,本文主要讲解 asrproxy程序 对接 mrcp v1 和 mrcp v2的配置。 asrproxy.json配置 asr配置 "asr":{"interface": {"mrcp": {"count": 0,"fault_threshold": 0…

外包干了10天,技术退步明显···

先说一下自己的情况,本科生,通过校招进入杭州某软件公司,干了接近3年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试&…

【鸿蒙开发】第十七章 Web组件(一)

1 Web概述 Web组件用于在应用程序中显示Web页面内容,为开发者提供页面加载、页面交互、页面调试等能力。 页面加载:Web组件提供基础的前端页面加载的能力,包括:加载网络页面、本地页面、html格式文本数据。 页面交互&#xff1a…

Java必须掌握的clear【】(含面试大厂题和源码)

面试题:“如何在Java中清除一个数组中的所有元素?” 在Java中,清除一个数组中的所有元素并不意味着逐个删除数组的每个元素,因为这在数组中是不可能做到的。数组的大小在初始化之后是固定的,无法改变。因此&#xff0…

IOS面试题object-c 1-10

1、简述Object-C的理解与特性? OC 作为一门 面向对象 的语言,自然具有面向对象的语言特性:封装、继承、多态。 它既具有 静态语言的特性(如C),又有 动态语言的效率(动态绑定、动态加载等&#…

JAVA使用的工具类-Hutool

文章目录 Hutool工具类简介1:身份证工具类相关方法1.1 身份证脱敏处理 字符串补零处理(此处是JAVA类的方法,并无引用StrUtil)springboot前后端分离,后端返回json字符串带斜杠问题处理 在这里整理一下博主常用的工具类方法-hutool工具类,这里囊…

制定一份完美的测试计划,让您的产品质量更上一层楼!

大家好,我是彭于晏。今天学习测试计划如何书写。 虽然很多人日常工作中都知道测试计划是什么,但是写好测试计划,其实并不容易。今天就来一起学习下测试计划如何书写。 什么是测试计划? 测试计划是一份为软件产品所准备的详细文档…

目标检测——监控下打架检测数据集

一、简述 首先,监控下打架检测是维护公共安全的重要手段。在公共场所、学校、监狱等地方,打架事件往往难以避免。通过安装打架检测监控系统,可以实时监控并准确识别打架事件,及时采取必要的应对措施,有效地减少打架事…

RNN预测正弦时间点

import torch.nn as nn import torch import numpy as np import matplotlib matplotlib.use(TkAgg) from matplotlib import pyplot as plt # net nn.RNN(100,10) #100个单词,每个单词10个维度 # print(net._parameters.keys()) #序列时间点预测num_time_steps 50…

消息中间件面试题-参考回答

面试官:RabbitMQ-如何保证消息不丢失 候选人: 嗯!我们当时MYSQL和Redis的数据双写一致性就是采用RabbitMQ实现同步 的,这里面就要求了消息的高可用性,我们要保证消息的不丢失。主要从三 个层面考虑 第一个是开启生产者…

学习SVN

学习SVN 摘要1.简介2.下载安装3.SVN生命周期4.SVN Server搭建5.SVN Client使用6.git与SVN的区别 SVN 官网 Github SVN 源码 摘要 本篇博客对SVN的基础使用进行总结,以便加深理解和记忆 1.简介 SVN是Apache Subversion的缩写,是一个开源的源码版本控制…

java-ssm-jsp-基于ssm的宝文理学生社团管理系统

java-ssm-jsp-基于ssm的宝文理学生社团管理系统 获取源码——》公主号:计算机专业毕设大全

应对高并发的软件架构之道

在去年年终总结的时候,我提出了这样的困惑,究竟什么是真正的技术能力,是对于各种底层技术的钻研吗?钻研是好事,但实践下来,深入钻研并不在实际工作中有用,且钻研的越深,忘得越快&…

AIGC安全研究简述(附资料下载)

2023 AIGC技术实践及展望资料合集(29份).zip 2023 AIGC大型语言模型(LLM)实例代码合集.zip 2023大模型与AIGC峰会(公开)PPT汇总(25份).zip AIGC的安全研究是一个复杂且重要的领域,涉及多个关键…

Leetcode : 1137. 高度检查器

学校打算为全体学生拍一张年度纪念照。根据要求,学生需要按照 非递减 的高度顺序排成一行。 排序后的高度情况用整数数组 expected 表示,其中 expected[i] 是预计排在这一行中第 i 位的学生的高度(下标从 0 开始)。 给你一个整数…

一篇搞懂什么是LRU缓存|一篇搞懂LRU缓存的实现|LRUCache详解和实现

LRUCache 文章目录 LRUCache前言项目代码仓库什么时候会用到缓存(Cache)缓存满了,怎么办?什么是LRUCacheLRUCache的实现LRUCache对应的OJ题实现LRUCache对应的STL风格实现 前言 这里分享我的一些博客专栏,都是干货满满的。 手撕数据结构专栏…

什么是测试用例?如何设计?

在学习或者实际的测试工作中经常都会提到“测试用例”这个词,没错,测试用例是测试工作的核心,不管要做的是什么样的测试,在真正动手执行测试之前,我们都需要先根据软件需求来设计测试用例,之后再依据设计好…

动态加权平衡损失:深度神经网络的类不平衡学习和置信度校准

系列文章目录 文章目录 系列文章目录前言一、研究目的二、研究方法创新点处理类不平衡的大多数方法交叉熵损失函数Brier Score 三、DWB Loss总结 前言 Dynamically Weighted Balanced Loss: ClassImbalanced Learning and Confidence Calibration of Deep Neural Networks 下载…

2024年3月10日 十二生肖 今日运势

小运播报:2024年3月10日,星期日,农历二月初一 (甲辰年丁卯月癸酉日),法定节假日。 红榜生肖:龙、牛、蛇 需要注意:鸡、狗、兔 喜神方位:东南方 财神方位:…