对自己正在运行的盐州的反省?

时间:2014-04-03 14:48:58

标签: salt-stack

我一直在试验Salt,而且我设法锁定了我的高阶命令。它已经运行了好几个小时了,尽管没有什么可以保证那段时间。

我做的最后一次更改是修改nginx的service.watch状态。目前的内容如下:

nginx:
  pkg.installed:
    - name: nginx
  service:
    - running
    - enable: True
    - restart: True
    - watch:
      - file: /etc/nginx/nginx.conf
      - file: /etc/nginx/sites-available/default.conf
      - pkg: nginx

我做的最后一项更改是将第二个file:参数添加到watch

在让它运行一整夜,状态没有变化后,我随后按Ctrl-C进行处理。 sudo salt -v 'web*' state.highstate -l debug的最后一项输出是:

[DEBUG   ] Checking whether jid 20140403022217881027 is still running
[DEBUG   ] get_returns for jid 20140403103702550977 sent to set(['web1.mysite.com']) will timeout at 10:37:04
[DEBUG   ] jid 20140403103702550977 found all minions
Execution is still running on web1.mysite.com
^CExiting on Ctrl-C
This job's jid is:                                                                                                                                     
20140403022217881027
The minions may not have all finished running and any remaining minions will return upon completion. To look up the return data for this job later run:
salt-run jobs.lookup_jid 20140403022217881027

立即再次运行,我得到了这个:

$ sudo salt -v 'web*' state.highstate -l debug
[DEBUG   ] Reading configuration from /etc/salt/master
[DEBUG   ] Missing configuration file: /home/eykd/.salt
[DEBUG   ] Configuration file path: /etc/salt/master
[DEBUG   ] Reading configuration from /etc/salt/master
[DEBUG   ] Missing configuration file: /home/eykd/.salt
[DEBUG   ] LocalClientEvent PUB socket URI: ipc:///var/run/salt/master/master_event_pub.ipc
[DEBUG   ] LocalClientEvent PULL socket URI: ipc:///var/run/salt/master/master_event_pull.ipc
Executing job with jid 20140403103715454952
-------------------------------------------

[DEBUG   ] Checking whether jid 20140403103715454952 is still running
[DEBUG   ] get_returns for jid 20140403103720479720 sent to set(['web1.praycontinue.com']) will timeout at 10:37:22
[INFO    ] jid 20140403103720479720 minions set(['web1.mysite.com']) did not return in time
[DEBUG   ] Loaded no_out as virtual quiet
[DEBUG   ] Loaded json_out as virtual json
[DEBUG   ] Loaded yaml_out as virtual yaml
[DEBUG   ] Loaded pprint_out as virtual pprint
web1.praycontinue.com:
    Minion did not return

然后我运行了相同的命令,并收到 this

$ sudo salt -v 'web*' state.highstate -l debug
[DEBUG   ] Reading configuration from /etc/salt/master
[DEBUG   ] Missing configuration file: /home/eykd/.salt
[DEBUG   ] Configuration file path: /etc/salt/master
[DEBUG   ] Reading configuration from /etc/salt/master
[DEBUG   ] Missing configuration file: /home/eykd/.salt
[DEBUG   ] LocalClientEvent PUB socket URI: ipc:///var/run/salt/master/master_event_pub.ipc
[DEBUG   ] LocalClientEvent PULL socket URI: ipc:///var/run/salt/master/master_event_pull.ipc
Executing job with jid 20140403103729848942
-------------------------------------------

[DEBUG   ] Loaded no_out as virtual quiet
[DEBUG   ] Loaded json_out as virtual json
[DEBUG   ] Loaded yaml_out as virtual yaml
[DEBUG   ] Loaded pprint_out as virtual pprint
web1.mysite.com:
    Data failed to compile:
----------
    The function "state.highstate" is running as PID 4417 and was started at 2014, Apr 03 02:22:17.881027 with jid 20140403022217881027

PID 4417下没有进程正在运行。正在运行sudo salt-run jobs.lookup_jid 20140403022217881027不显示任何内容。

不幸的是,我无法通过ssh连接到minion,因为salt还没有配置我的authorized_keys。 :\

所以,对于我的问题:这到底是什么问题,以及我在世界上如何找到它?

2 个答案:

答案 0 :(得分:1)

因此,经过大量调试后,这是Nginx服务配置不正确的结果。 service nginx start悬挂着,因此盐奴隶也是如此。

答案 1 :(得分:0)

当我使用Ctrl-C中止salt-master上的state.highstate时,我发生了这种情况。事实证明,错误消息中引用的PID实际上是minion机器上的salt-minion进程的PID

我能够通过重新启动minion上的salt-minion进程来解决问题,然后在master上重新执行state.highstate。