Я проверяю несколько ips в локальной сети, чтобы проверить, является ли он живым или нет.код будет запускаться каждую минуту в соответствии с расписанием. Для проверки нескольких ips я использовал многопроцессорность.Это делается великолепно с помощью многопроцессорной обработки.Одновременно я хочу записать результаты ping в файл json после ping.Но при записи в файл JSON он записывает только выходные данные последнего ip. Я хочу все три.Есть ли способ сделать это
Вот пример кода:
import json
from multiprocessing import Pool
import subprocess
from datetime import datetime
timestamp = datetime.now().strftime("%B %d %Y, %H:%M:%S")
hosts = ["192.168.1.47","192.168.1.42"]
count = 1
wait_sec = 1
n = len(hosts)
def main(hosts):
p = Pool(processes= n)
result = p.map(beat, hosts)
def beat(hosts):
#Name for the log file
name = 'icmp.json'
ip4write(hosts, name)
def ip4write(hosts, name):
global ip4a
ip4a = hosts
ipve4(hosts, name)
write(hosts, name)
def ipve4(hosts, name):
global u
status, result = subprocess.getstatusoutput("ping -c1 -w2 " + str(ip4a))
if status == 0:
print(str(ip4a) + " UP")
u = " UP"
def write(hosts, name):
text_file = open(name, "a+")
with open(name) as json_file:
try:
data = json.load(json_file)
except:
data = {}
with open(name, 'w') as outfile:
data[timestamp] = {
'monitor.ip':str(hosts),
'monitor.status': u
}
print(data)
json.dump(data, outfile)
print('Data written')
text_file.close()
main(hosts)
Вывод в JSON-файле:
{"February 15 2019, 16:38:12": {"monitor.status": " UP", "monitor.ip": "192.168.1.42"}}
Мой необходимый вывод:
{"February 15 2019, 16:38:12": {"monitor.ip": "192.168.1.47", "monitor.status": " UP"}, "February 15 2019, 16:38:12": {"monitor.ip": "192.168.1.42", "monitor.status": " UP"}}