ユーザー モデルがあり、新しいユーザー モデルを作成するときに、ユーザーの作成後にネットワーク/バックグラウンド タスクを実行する必要がある新しいスレッドを生成するとします。
def create
  @user = User.new(params[:user])
  collect_info_async(@user)
  respond_to do |format|
    if @user.save
      format.html { redirect_to @user, notice: 'User created.' }
    else
      format.html { render action: "new" }
    end
  end
end
def collect_info_async(user)
  Thread.new do
    logger.info "Thread starting" #Gets logged correctly
    #Do some network requests, perform calculations, etc.
    usr = User.find_by_id(user.id).update_attributes(:info => gathered_info)
    logger.info "Thread finishing"
   end
end
新しいユーザーを作成すると、ログに「スレッドの開始」が表示されますが、実際に終了すると同時に「スレッドの終了」が表示されません。コンソールから User.find を実行するか、しばらくしてからユーザー ページを更新する必要があります。その後、「スレッドの終了」ログを確認できます。では、非同期タスクが実際に終了するのはいつでしょうか? そして、スレッドを使用するのは正しい選択ですか? Ruby 1.9.3 と Rails 3.2.8 を使用しています。