广告
返回顶部
首页 > 资讯 > 精选 >如何解决gearman队列持久化引发的问题
  • 798
分享到

如何解决gearman队列持久化引发的问题

2023-06-09 18:06:32 798人浏览 泡泡鱼
摘要

这篇文章主要讲解了“如何解决gearman队列持久化引发的问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何解决gearman队列持久化引发的问题”吧!具体分析如下:一、gearman

这篇文章主要讲解了“如何解决gearman队列持久化引发的问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何解决gearman队列持久化引发的问题”吧!

具体分析如下:

一、gearman 创建Mysql持久化队列的方式如下:

登入Mysql命令行,运行:   

create database gearman;

 2. 启动gearman,命令如下:

/usr/local/gearman/sbin/gearmand -p 4730 -L 0.0.0.0 --log-file=/tmp/gearmand-4730.log --pid-file=/tmp/gearmand-4730.pid -q mysql --mysql-host=localhost --mysql-user=root --mysql-db=gearman --verbose DEBUG -d

具体的参数,根据自己的服务器状况去修改就行了。
 
3. 再次登入mysql命令行,执行:

use gearman; show tables;

就可以看到下面多了个“gearman_queue”的表。

这样,gearman就变成了持久化的方式。
 
二、gearman用mysql持久化之后,会带来如下一些问题:

每个任务都会写入数据库,这样会带来磁盘io的损耗,并且gearman的性能瓶颈又多了一个可能,就是由数据库引起的性能问题。

mysql有个“wait_timeout”的参数,在mysql命令行中运行

show variables like "%timeout%";

可以看到wait_timeout的值,默认是28800。也就是说,如果一个mysql的连接,超过28800s没有任何响应,就会断开。
 
3. gearman持久化的方式,如果超过了mysql的wait_timeouts的时间没有任何响应,和数据库的连接就会被mysql断开,而且gearman目前是没有mysql重新连接的,结果就是,会导致如下错误,必须重启gearman才能重新正常工作。
 
gearman报错:

ERROR 2014-04-01 02:10:02.897899 [ proc ] mysql_stmt_execute failed: -> libgearman-server/plugins/queue/mysql/queue.cc:357ERROR 2014-04-01 02:10:02.897910 [ proc ] gearman_server_job_add gearman_server_run_command(QUEUE_ERROR) -> libgearman-server/server.cc:301

所以,gearman持久化方式带来的缺点显而易见,该方式下,要避免gearman对mysql连接超时断开,可以将mysql的wait_timeout参数改大
 
或者,干脆直接放弃用mysql的持久化方式。

感谢各位的阅读,以上就是“如何解决gearman队列持久化引发的问题”的内容了,经过本文的学习后,相信大家对如何解决gearman队列持久化引发的问题这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: 如何解决gearman队列持久化引发的问题

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

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

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

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

下载Word文档
猜你喜欢
  • 如何解决gearman队列持久化引发的问题
    这篇文章主要讲解了“如何解决gearman队列持久化引发的问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何解决gearman队列持久化引发的问题”吧!具体分析如下:一、gearman ...
    99+
    2023-06-09
  • gearman队列持久化引发的问题及解决方法
    本文简述了gearman用mysql持久化的方法,以及由此引发的一些问题,具体分析如下: 一、gearman 创建Mysql持久化队列的方式如下: 1. 登入mysql命令行,运行: create...
    99+
    2022-06-04
    队列 解决方法 持久
  • 如何解决Flex对象持久化问题
    这篇文章主要为大家展示了“如何解决Flex对象持久化问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决Flex对象持久化问题”这篇文章吧。关于Flex对象持久化关于Flex对象序列化和持...
    99+
    2023-06-17
  • 在Go语言中如何解决并发消息队列问题?
    在Go语言中如何解决并发消息队列问题?消息队列在现代应用程序中被广泛应用,用于处理异步任务、解耦系统组件、实现消息传递等。然而,在高并发情况下,消息队列的性能和并发处理能力成为了关键问题。在Go语言中,我们可以借助Go协程和通道来解决这个问...
    99+
    2023-10-22
    Go语言 并发 消息队列 关键词:
  • 如何解决因@click.stop引发的bug问题
    这篇文章将为大家详细讲解有关如何解决因@click.stop引发的bug问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。问题在项目页面中使用 element popov...
    99+
    2022-10-19
  • vuex持久化插件如何解决浏览器刷新数据消失问题
    小编给大家分享一下vuex持久化插件如何解决浏览器刷新数据消失问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!插件原理vuex...
    99+
    2022-10-19
  • Go json反序列化“null“的问题如何解决
    本文小编为大家详细介绍“Go json反序列化“null“的问题如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“Go json反序列化“null“的问题如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-07-05
  • 如何解决Vue依赖收集引发的问题
    这篇文章主要为大家展示了“如何解决Vue依赖收集引发的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决Vue依赖收集引发的问题”这篇文章吧。问题背景在...
    99+
    2022-10-19
  • 如何解决jackson序列化和feign返回值的问题
    这篇文章给大家分享的是有关如何解决jackson序列化和feign返回值的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。jackson序列化和feign返回值jackson注意点被序列化/反序列化的实体a.必...
    99+
    2023-06-29
  • 如何解决使用Jackson反序列化遇到的问题
    这篇文章主要为大家展示了“如何解决使用Jackson反序列化遇到的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决使用Jackson反序列化遇到的问题”这篇文章吧。Jackson反序列...
    99+
    2023-06-20
  • 如何解决MySQL中因一个双引号错位引发的问题
    小编给大家分享一下如何解决MySQL中因一个双引号错位引发的问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、前言最近经常碰...
    99+
    2022-10-18
  • 如何解决JVMFullGC引发严重线上事故的问题
    今天就跟大家聊聊有关如何解决JVMFullGC引发严重线上事故的问题,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、业务场景介绍先简单说说线上生产系统的一个背景,因为仅仅是文章作为...
    99+
    2023-06-03
  • 如何解决JSON反序列化Long变Integer或Double的问题
    这篇文章主要为大家展示了“如何解决JSON反序列化Long变Integer或Double的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决JSON反序列化Long变Integer或Do...
    99+
    2023-06-26
  • 如何解决HashMap并发时会引起死循环的问题
    这篇文章给大家分享的是有关如何解决HashMap并发时会引起死循环的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。今天研读Java并发容器和框架时,看到为什么要使用ConcurrentHashMap时,其中有...
    99+
    2023-06-15
  • 如何解决css定位position引发的层级关系问题
    这篇文章主要介绍了如何解决css定位position引发的层级关系问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。position定位里的absolute,relative...
    99+
    2023-06-08
  • Python输出列表不带中括号和引号的问题如何解决
    这篇文章主要介绍了Python输出列表不带中括号和引号的问题如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python输出列表不带中括号和引号的问题如何解决文章都会有所收获,下面我们一起来看看吧。正常p...
    99+
    2023-07-05
  • 如何解决Go语言中的并发任务的分布式任务队列和任务调度策略问题?
    如何解决Go语言中的并发任务的分布式任务队列和任务调度策略问题?引言:在分布式系统中,任务的分发和调度是一个关键问题。在Go语言中,通过使用并发技术可以有效地管理和执行任务。本文将介绍如何使用分布式任务队列和任务调度策略来解决Go语言中的并...
    99+
    2023-10-22
    任务调度 分布式任务队列 并发任务
  • Go语言在Spring中的索引并发:如何解决常见问题?
    在现代计算机系统中,数据库是一个必不可少的组件。对于大型应用程序,使用关系型数据库来存储和管理数据是非常常见的。Spring框架是一个非常流行的Java企业应用程序框架,它提供了各种各样的功能和服务,包括数据存储和管理。 在Spring中...
    99+
    2023-10-06
    索引 并发 spring
  • 如何解决EnyimMemcached异步化改造引起的内存泄漏问题
    如何解决EnyimMemcached异步化改造引起的内存泄漏问题,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。6月30日我们发布了异步化改造后的博客程序之后,出现了高内存、高C...
    99+
    2023-06-17
  • 如何解决Go语言中的并发算法优化问题?
    如何解决Go语言中的并发算法优化问题?Go语言是一门强调并发编程的语言,它提供了丰富的并发原语和工具,使得我们能够充分利用多核处理器的能力。然而,并发编程往往会面临一些问题,比如资源竞争、死锁、饥饿等。本文将介绍一些解决并发算法优化问题的方...
    99+
    2023-10-22
    并发 算法优化 关键词:Go语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作