ruby-on-rails - 认为 Sphinx 索引在命令行上成功,但在 Cron 作业中失败

标签 ruby-on-rails cron capistrano thinking-sphinx

我承认我已经在 Ubuntu 上使用 Capistrano 从官方文档(似乎过时并做出了很多假设)和各种过时的各种博客文章中拼凑出一个主要工作的生产设置。无论如何,最后一个令人讨厌的挂断是当我手动进行索引时(并且在部署时我很确定),索引工作,但在 Cron 中不起作用。

这是我的 crontab:

$ crontab -l
# m h  dom mon dow   command
* * * * * cd /var/www/app/current && /usr/local/bin/rake RAILS_ENV=production thinking_sphinx:index >> /var/www/app/current/log/cron.log 2>&1

这是日志输出(实际上每次调用出现 3 次):
Sphinx cannot be found on your system. You may need to configure the following
settings in your config/sphinx.yml file:
  * bin_path
  * searchd_binary_name
  * indexer_binary_name

For more information, read the documentation:
http://freelancing-god.github.com/ts/en/advanced_config.html

这是当我手动运行相同的命令时(也适用于记录):
$ cd /var/www/app/current && /usr/local/bin/rake RAILS_ENV=production thinking_sphinx:index
(in /var/www/app/releases/20100729042739)
Generating Configuration to /var/www/app/releases/20100729042739/config/production.sphinx.conf
Sphinx 0.9.9-release (r2117)
Copyright (c) 2001-2009, Andrew Aksyonoff

using config file '/var/www/app/releases/20100729042739/config/production.sphinx.conf'...
indexing index 'app_core'...
collected 5218 docs, 3.9 MB
collected 5218 attr values
sorted 0.0 Mvalues, 100.0% done
sorted 0.7 Mhits, 100.0% done
total 5218 docs, 3898744 bytes
total 0.616 sec, 6328760 bytes/sec, 8470.28 docs/sec
distributed index 'app' can not be directly indexed; skipping.
total 3 reads, 0.008 sec, 1110.2 kb/call avg, 2.6 msec/call avg
total 15 writes, 0.016 sec, 540.4 kb/call avg, 1.0 msec/call avg
rotating indices: succesfully sent SIGHUP to searchd (pid=20101).

也相关:
$ which rake        
/usr/local/bin/rake
$ which indexer
/usr/local/bin/indexer
这个错误有点常见,但它在命令行中运行良好,这听起来很有趣,我怀疑还有一些奇怪的东西。我还有 2 个其他关键任务 cron 作业,它们运行看起来相同且运行良好的 rake 任务,不确定这个有什么不同。任何帮助将不胜感激!

PS-当前 Capistrano 和 TS 版本是否有权威的部署配置?似乎每个人都在推出自己的产品,官方文档似乎与那里的博客文章一样独特。

最佳答案

crontab 与您手动运行时登录的用户是否属于同一用户?

因为这似乎是一个明确的 PATH 问题,并且 cron使用受限制的 PATH(即不是您的 .profile 中的内容)运行,请尝试将其添加到您的 crontab 文件的顶部。

PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin

或者,如果您不想修改 cron 的 PATH,您可以将所需的文件符号链接(symbolic link)到/usr/sbin,默认情况下可能在 PATH 中。

关于ruby-on-rails - 认为 Sphinx 索引在命令行上成功,但在 Cron 作业中失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3375938/

相关文章:

ruby-on-rails - Rails + Carrierwave + Jquery Fileupload +简单表单

ruby-on-rails - 如果通过不匹配的ETag或更早的修改日期,Varnish是否会命中?

ruby-on-rails - 将此文本放入数组中

php - 超出了YouTube API的PHP上传限制

php - 在 2 个 MySQL 表之间复制数据库表行的 Cron 作业

Perl 脚本运行正常,但作为 crontab 它不工作

ruby-on-rails - MongoDB/MongoID 多键专项查询

ruby-on-rails - Rails 部署中的/usr/bin/env 和 Capistrano 3 失败

git - 如何在 Capistrano 的 deploy.rb 中指明 Git 用户名和密码?

deployment - Capistrano 部署如何使用 use_sudo 和 admin_runner