策展人版本与shell和cron之间存在差异

时间:2016-09-26 14:54:56

标签: elasticsearch cron elasticsearch-curator

我最近将elasticsearch-curator从3.4.1升级到4.1.0。我还创建了一个新的配置文件和操作文件,用于执行与3.4.1相同的操作。会发生什么,当cron运行脚本时,它显示为3.4.1。如果我sudo手动运行脚本,它将显示为4.1.0

我删除了apt包并迁移到pip包。这是我能想到的唯一可能导致这种情况的事情。

这是脚本,它将从cron.daily运行(暂时转移到cron.hourly进行测试,不负责任地设置为每分钟运行一次):

#!/bin/sh
/usr/local/bin/curator --version
/usr/local/bin/curator --config /etc/curator/curator.yml /etc/curator/actions/01-nightly-close
/usr/local/bin/curator --config /etc/curator/curator.yml /etc/curator/actions/02-nightly-optimize

我可以将脚本作为sudo运行,版本号显示为4.1.0:

/etc/cron.hourly/curator
curator, version 4.1.0

如果我让cron运行该作业,它会显示版本3.4.1:

/etc/cron.hourly/curator
curator, version 3.4.1
Error: no such option: --config
Error: no such option: --config
run-parts: /etc/cron.hourly/curator exited with return code 2

此外,当我运行which curator时,它指向/usr/local/bin/curator

编辑:回答untergeek的问题,以下是/usr/local/bin/curator的内容

#!/usr/bin/python

# -*- coding: utf-8 -*-
import re
import sys

from curator.curator import main

if __name__ == '__main__':
    sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
    sys.exit(main())

1 个答案:

答案 0 :(得分:1)

管理让它工作 - 我最终从我的节点清除所有curator实例,包括pip和apt版本,然后按https://www.elastic.co/guide/en/elasticsearch/client/curator/current/installation.html运行以下命令:

wget -qO - https://packages.elastic.co/GPG-KEY-elasticsearch | sudo apt-key add -
echo "deb http://packages.elastic.co/curator/4/debian stable main" >> /etc/apt/sources.list.d/curator.list
sudo apt-get update && sudo apt-get install python-setuptools python-elasticsearch-curator