0

Dotcloudで実行されている Django アプリケーションがあります。サイトの通常の使用法で機能するLogentriesログを追加しようとしましたが、cronジョブがこのエラーで失敗します-
Traceback (most recent call last): File "/home/dotcloud/current/my_project/manage.py", line 10, in <module> execute_from_command_line(sys.argv) File "/home/dotcloud/env/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 399, in execute_from_command_line utility.execute() File "/home/dotcloud/env/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 392, in execute self.fetch_command(subcommand).run_from_argv(self.argv) File "/home/dotcloud/env/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 261, in fetch_command commands = get_commands() File "/home/dotcloud/env/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 107, in get_commands apps = settings.INSTALLED_APPS File "/home/dotcloud/env/local/lib/python2.7/site-packages/django/conf/__init__.py", line 54, in __getattr__ self._setup(name) File "/home/dotcloud/env/local/lib/python2.7/site-packages/django/conf/__init__.py", line 50, in _setup self._configure_logging() File "/home/dotcloud/env/local/lib/python2.7/site-packages/django/conf/__init__.py", line 80, in _configure_logging logging_config_func(self.LOGGING) File "/usr/lib/python2.7/logging/config.py", line 777, in dictConfig dictConfigClass(config).configure() File "/usr/lib/python2.7/logging/config.py", line 575, in configure '%r: %s' % (name, e)) ValueError: Unable to configure handler 'logentries_handler': expected string or buffer

これは、cron から実行されるスクリプトの 1 つです -

#!/bin/bash
echo "Loading definitions - check /var/log/supervisor/availsserver.log for results"
. /etc/profile
/home/dotcloud/env/bin/python /home/dotcloud/current/my_project/manage.py load_definitions

これらは Logentries の私の設定です -
'logentries_handler': { 'token': os.getenv("LOGENTRIES_TOKEN"), 'class': 'logentries.LogentriesHandler' } .... 'logentries': { 'handlers': ['logentries_handler'], 'level': 'INFO', },

私がするとき、LOGENTRIES_TOKENはそこにありますdotcloud env list

これは症状の要約です -
- Logentries のログ記録は、通常の使用ではサイトから機能します。
- スクリプトを手動で実行すると、dotcloud run www ~/current/scripts/load_definitions.sh機能します。
- Logentries 設定を削除するとsettings.py、cron ジョブが機能します。
- Logentries エントリが自分のディレクトリにある場合、cron ジョブは失敗します。settings.py

私は解決策を見つけるのに何時間も費やしました。誰でも助けることができますか?

4

2 に答える 2

0

私はこれを解決しました。
これは以前の crontab で、
0 13 * * * /home/dotcloud/current/scripts/load_definitions.sh 2>&1 | mail -s "Load definitions result" myemail@example.com.au
動作しませんでした。
これが現在の方法です-
0 13 * * * /bin/bash -l -c '/home/dotcloud/current/scripts/load_definitions.sh' 2>&1 | mail -s "Load definitions result" myemail@example.com.au
これは機能します。追加する/bin/bash -l -cと修正されました。おそらく、誰かがなぜそれがうまくいかなかったのか教えてくれるでしょうか?

于 2014-03-30T21:50:17.077 に答える
0

エクスポートされたシェル環境からではなく、~/environment.jsonまたはから直接値を読み取ろうとしましたか?~/environment.yml

于 2014-03-26T20:40:48.947 に答える