Active::Job和Shoryuken在SIGTERM信号上没能执行操作。
创始人
2024-07-24 04:30:53
0

在默认情况下,当一个程序接收到 SIGTERM 信号时,它将尽快停止并退出。但是,一些后台任务可能需要在退出之前完成一些操作。Active::Job 和 Shoryuken 都为这种情况提供了下面的解决方法。

对于 Active::Job,您可以使用 before_perform 和 after_perform 钩子来执行一些任务。例如,以下代码将在执行任务之前打印一个消息并在执行任务之后更新任务状态并再次打印一个消息。

class SampleJob < ActiveJob::Base
  before_perform do |job|
    Rails.logger.info "Starting job #{job.job_id}"
  end

  after_perform do |job|
    Rails.logger.info "Completed job #{job.job_id}"
    job.update(status: "completed")
  end

  def perform(*args)
    # Do some work here...
  end
end

对于 Shoryuken,您可以使用 Signal.trap 方法来注册一个信号处理程序。例如,以下代码将在 SIGTERM 信号上打印一个消息和在退出之前清理所有资源。

require 'shoryuken'

Signal.trap('TERM') do
  puts "Received SIGTERM. Shutting down gracefully..."
  Shoryuken.stop
end

class SampleWorker
  include Shoryuken::Worker

  shoryuken_options queue: 'default'

  def perform(sqs_msg, body)
    # Do some work here...
  end
end

这样,当接收到 SIGTERM 信号时,Signal.trap 中的代码将执行,然后会执行 Shoryuken.stop 方法来优雅地停止 Shoryuken 工作进程。

希望这个解决方案对您有用!

相关内容

热门资讯

Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...
Aksnginxdomainb... 在AKS集群中,可以使用Nginx代理服务器实现根据域名进行路由。以下是具体步骤:部署Nginx i...
AddSingleton在.N... 在C#中创建Singleton对象通常是通过私有构造函数和静态属性来实现,例如:public cla...
Alertmanager中的基... Alertmanager中可以使用repeat_interval选项指定在一个告警重复发送前必须等待...