0

私は2つのサーバーで実行されているpython zabbix trapperスクリプトを実行していますが、そのうちの1つで正常に動作します。30 秒ごとに実行されます。これは、「ss」から time_wait ステータスを読み取るコードの一部です。

file_log = "/tmp/tcpstate.log"
proc = open(file_log,"a")

file = "/var/log/safesquid/safesquid/performance/performance.log"
time_wait_cmd = subprocess.Popen("ss -o state time-wait | grep webcache | wc -l",shell=True,stdout=subprocess.PIPE)
ssquid_time = time_wait_cmd.communicate()[0]
proc_string = datetime.datetime.now().strftime("%d-%m-%y %H:%M:%S") + " " + "Time_WAIT: " + ssquid_time  + "\n"
proc.write(proc_string)
proc.close()

server1 からの出力: (OK)

01-05-12 17:40:50 Time_WAIT: 286
01-05-12 17:41:20 Time_WAIT: 251
01-05-12 17:41:50 Time_WAIT: 366
01-05-12 17:42:20 Time_WAIT: 335
01-05-12 17:42:50 Time_WAIT: 287
01-05-12 17:43:20 Time_WAIT: 375
01-05-12 17:43:51 Time_WAIT: 386
01-05-12 17:44:21 Time_WAIT: 383

Server2 からの出力: (問題)

01-05-12 17:44:03 Time_WAIT: 368
01-05-12 17:44:32 Time_WAIT: 388
01-05-12 17:45:01 Time_WAIT: 0
01-05-12 17:45:01 Time_WAIT: 339
01-05-12 17:45:31 Time_WAIT: 311
01-05-12 17:46:00 Time_WAIT: 400
01-05-12 17:46:01 Time_WAIT: 0
01-05-12 17:46:29 Time_WAIT: 411
01-05-12 17:46:58 Time_WAIT: 448

30秒ごとに呼び出されるため、Server2で「0」値を取得してすぐに正しい値を読み取る理由がわかりません。

なぜこれが起こっているのですか?

4

1 に答える 1

0

どちらのプロセスもシグナルを受信して​​いますか?これにより、システムコールが予想よりも早く終了する可能性があります。

于 2012-05-01T18:42:23.663 に答える