我正在使用载波和载波背景(https://github.com/lardawge/carrierwave_backgrounder)延迟作业用于在后台上传文件。每当我尝试上传我的文件时,它都会成功上传,我可以看到作业是在后台执行的,但我看不出使用延迟作业和不使用延迟作业有什么区别。没有延迟作业和有延迟作业执行需要相同的时间。不知道哪里出了问题。plz帮助。提前谢谢。
这是我的上传
# encoding: utf-8
class AvatarUploader < CarrierWave::Uploader::Base
# Include RMagick or MiniMagick support:
# include CarrierWave::RMagick
# include CarrierWave::MiniMagick
include ::CarrierWave::Backgrounder::Delay
include Sprockets::Helpers::RailsHelper
include Sprockets::Helpers::IsolatedHelper
# Choose what kind of storage to use for this uploader:
storage :file
# storage :fog
# Override the directory where uploaded files will be stored.
# This is a sensible default for uploaders that are meant to be mounted:
def store_dir
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
end
def cache_dir
""
end
# Provide a default URL as a default if there hasn't been a file uploaded:
def default_url
"rails.png"
end
end
carrierwave-backgrounder.rb 中的carrierwove-backgrounder文件
CarrierWave::Backgrounder.configure do |c|
c.backend :delayed_job, queue: :carrierwave
end
后模型
class Post < ActiveRecord::Base
attr_accessible :description , :avatar, :remote_avatar_url
mount_uploader :avatar, AvatarUploader
process_in_background :avatar
validates_presence_of :description
end
控制器动作后
def create
@post = Post.new(params[:post])
respond_to do |format|
if @post.save
format.html { redirect_to @post, notice: 'Post was successfully created.' }
format.json { render json: @post, status: :created, location: @post }
else
format.html { render action: "new" }
format.json { render json: @post.errors, status: :unprocessable_entity }
end
end
end
这是我的观点
<%= form_for(@post) do |f| %>
<% if @post.errors.any? %>
<div id="error_explanation">
<h2><%= pluralize(@post.errors.count, "error") %> prohibited this post from being saved:</h2>
<ul>
<% @post.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<% end %>
<div class="field">
<%= f.label :description %><br />
<%= f.text_area :description %>
</div>
<div class="field">
<%= f.file_field :avatar %>
</div>
<div class="actions">
<%= f.submit %>
</div>
<% end %>
CarrierWave Backgrounder不在后台进行初始文件传输。它可以做两件事:
process_in_background
让后台任务处理"处理",carrierwave称之为调整图像大小、更改格式、生成缩略图和进行其他自定义操作的步骤。原始图像仍然像往常一样"存储"(如下所述)。
store_in_background
让后台任务处理"存储",carrierwave称之为将上传的图像移动到本地磁盘上的最终位置的步骤,如果您使用的是雾,则移动到S3等远程服务器上。
您已经将模型配置为process_in_background
,但您的上传器没有配置为进行任何处理,因此您没有观察到任何变化,正如预期的那样。如果需要,您可以将模型配置为store_in_background
,但由于您使用的是本地文件存储(文件复制通常很快),因此这对您的应用程序基本上没有影响。
有关处理和存储的更多信息,请参阅Carrierwave自述。
我建议您改用Carrierwave Direct。