gpt4 book ai didi

mysql - 在 Ruby on Rails 中使用 fork 创建并行进程

转载 作者:IT老高 更新时间:2023-10-29 00:14:21 28 4
gpt4 key购买 nike

我有一个 Rails 3 应用程序正在使用 Apache 上的Passenger 进行生产。我有这个代码:

class Billing < ActiveRecord::Base
after_save :sendEmails

private
def sendEmails
fork do
UserMailer.clientBilling(self.user, self).deliver
end
end
end

在本地主机中,当应用程序创建帐单时,保存后,应用程序会向用户发送一封电子邮件,一切正常。但是在服务器中,应用程序创建帐单后,它会向我抛出与 gem MySQL2 相关的错误,例如“MySQL 服务器已消失”或“连接丢失”等错误,并且应用程序不会发送电子邮件。如果我删除 fork 它工作正常,但我想使用 fork ,我想创建一个单独的进程,因为发送电子邮件需要很长时间。可能是什么问题?

最佳答案

问题在于 fork 的进程继承了其父进程的一些资源,例如其文件描述符。特别是这样的一种共享资源是 MySQL 连接。当子进程完成其电子邮件发送并退出时,它会关闭 MySQL 连接,从而关闭父进程的连接。

如果您确实继续沿着这条路走下去(并且充满了类似的微妙之处),那么您需要执行以下操作:

# Clear existing connections before forking to ensure they do not get inherited.
::ActiveRecord::Base.clear_all_connections!

fork do
# Establish a new connection for each fork.
::ActiveRecord::Base.establish_connection

# The rest of the code for each fork...
end

如果你使用 memcached 或 mongodb 等服务,你将不得不做类似的事情。

关于mysql - 在 Ruby on Rails 中使用 fork 创建并行进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8913476/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com