ResqueMailer 技术文档
1. 安装指南
1.1 安装 Gem
首先,您需要安装 resque_mailer
这个 Gem。您可以通过以下命令直接安装:
gem install resque_mailer
如果您使用 Bundler 来管理依赖,可以在 Gemfile
中添加以下内容:
gem 'resque' # 或者使用兼容的替代品/分支
gem 'resque_mailer'
然后运行 bundle install
来安装依赖。
1.2 配置 Resque
确保您已经安装并配置了 Resque,因为 resque_mailer
依赖于 Resque 来处理异步邮件发送任务。
2. 项目的使用说明
2.1 在 ActionMailer 中使用 Resque::Mailer
在您的 ActionMailer 子类中,包含 Resque::Mailer
模块:
class MyMailer < ActionMailer::Base
include Resque::Mailer
end
2.2 异步发送邮件
当您调用 MyMailer.subject_email(params).deliver
时,邮件发送任务会被添加到 Resque 的任务队列中。Resque 的 worker 会处理这些任务并发送邮件。默认情况下,任务会被添加到名为 mailer
的队列中。
启动 Resque worker 时,确保指定 mailer
队列:
QUEUE=mailer rake environment resque:work
2.3 同步发送邮件
如果您需要同步发送邮件,可以使用 deliver!
方法:
MyMailer.subject_email(params).deliver!
2.4 自定义队列名称
如果您希望使用不同的默认队列名称,可以在初始化文件中设置:
# config/initializers/resque_mailer.rb
Resque::Mailer.default_queue_name = 'application_specific_mailer'
启动 worker 时,使用新的队列名称:
QUEUE=application_specific_mailer rake environment resque:work
2.5 错误处理
您可以通过设置 error_handler
来处理邮件发送过程中出现的错误:
Resque::Mailer.error_handler = lambda { |mailer, message, error, action, args|
if error.is_a?(Resque::TermException)
Resque.enqueue(mailer, action, *args)
else
raise error
end
}
3. 项目API使用文档
3.1 自定义参数序列化器
默认情况下,传递给 mailer 的参数会直接传递给 Resque。如果您希望传递数据库对象,可以编写自定义的序列化器:
class MySerializer
def self.serialize(*args)
# 自定义序列化逻辑
end
def self.deserialize(data)
# 自定义反序列化逻辑
end
end
Resque::Mailer.argument_serializer = MySerializer
3.2 使用 Active Record 序列化器
resque_mailer
提供了 Active Record 序列化器,允许您直接传递 AR 模型作为参数:
Resque::Mailer.argument_serializer = Resque::Mailer::Serializers::ActiveRecordSerializer
3.3 使用 Resque Scheduler
如果您安装了 resque-scheduler
,可以使用 deliver_at
和 deliver_in
方法来安排邮件在未来某个时间发送:
# 在 2014 年 12 月 25 日发送
MyMailer.reminder_email(params).deliver_at(Time.parse('2014-12-25'))
# 在 7 天后发送
MyMailer.reminder_email(params).deliver_in(7.days)
# 取消计划发送
MyMailer.reminder_email(params).unschedule_delivery
4. 项目安装方式
4.1 使用 Bundler
在 Gemfile
中添加以下内容:
gem 'resque'
gem 'resque_mailer'
然后运行 bundle install
。
4.2 直接安装 Gem
使用以下命令直接安装 resque_mailer
:
gem install resque_mailer
4.3 配置环境
在测试环境中,您可能不希望实际发送邮件。可以通过以下配置来排除特定环境:
# config/initializers/resque_mailer.rb
Resque::Mailer.excluded_environments = [:test, :cucumber]
如果您在非 Rails 项目中使用 resque_mailer
,可以定义 current_env
:
Resque::Mailer.current_env = :production
5. 贡献与反馈
如果您希望为项目贡献代码,请遵循以下步骤:
- Fork 项目。
- 添加新功能或修复 bug。
- 添加测试。
- 提交 pull request。
感谢您的贡献!
- PDFMathTranslatePDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/DockerPython03
- topiam-eiam开源IDaas/IAM平台,用于管理企业内员工账号、权限、身份认证、应用访问,帮助整合部署在本地或云端的内部办公系统、业务系统及三方 SaaS 系统的所有身份,实现一个账号打通所有应用的服务。Java00
- 每日精选项目🔥🔥 12.23日推荐:跨平台终端工具,终端中实现编辑、运行、预览,无需来回切换🔥🔥 每日推荐行业内最新、增长最快的项目,快速了解行业最新热门项目动态~~017
- Cangjie-Examples本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。Cangjie039
- 毕方Talon工具本工具是一个端到端的工具,用于项目的生成IR并自动进行缺陷检测。Python039
- advanced-javaAdvanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。JavaScript0102
- taro开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发微信/京东/百度/支付宝/字节跳动/ QQ 小程序/H5/React Native 等应用。 https://taro.zone/TypeScript010
- Yi-CoderYi Coder 编程模型,小而强大的编程助手HTML012
- CommunityCangjie-TPC(Third Party Components)仓颉编程语言三方库社区资源汇总05
- Bbrew🍺 The missing package manager for macOS (or Linux)Ruby01