我最近将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())
答案 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