update_device_temp_1_8.py 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. # -*- coding: utf-8 -*-
  2. # !/usr/bin/env python
  3. import datetime
  4. import threading
  5. import time
  6. import uuid
  7. import thread
  8. from django.conf import settings
  9. from base import init_env
  10. import simplejson as json
  11. init_env(interactive = True)
  12. from apps.web.device.models import Device, DeviceDict
  13. from apps.web.core.networking import MessageSender
  14. from apps.web.constant import Const, DeviceCmdCode, DeviceOnlineStatus
  15. from apps.web.core.mqtt_client import MqttClient
  16. output_path = '/root/v1.8'
  17. version = 'v1.8.110'
  18. version_regex = 'v1\.7\.'
  19. version_check = 'v1.7.'
  20. done = open('%s/done_%d.txt' % (output_path, int(time.time())), 'w')
  21. error = open('%s/error_%d.txt' % (output_path, int(time.time())), 'w')
  22. timeout = open('%s/timeout_%d.txt' % (output_path, int(time.time())), 'w')
  23. mqttc1883 = None
  24. mqttc1884 = None
  25. doing_dict = {}
  26. def on_connect(client, userdata, flags, rc):
  27. pass
  28. # client.subscribe('+/+/209', qos = Const.MQTT_QOS)
  29. # print('subscribe topic(%s) success' % '+/+/209')
  30. def on_message(mqttc, obj, msg):
  31. msgDict = json.loads(bytes.decode(msg.payload))
  32. imei = msgDict['IMEI']
  33. _ = Device.get_dev(imei)
  34. print('209 has received. msg = %s' % str(msgDict))
  35. if msgDict['result']:
  36. done.write('%s %s %s\n' % (str(_['devNo']), str(_['logicalCode']), str(_['softVer'])))
  37. else:
  38. error.write('%s %s %s\n' % (str(_['devNo']), str(_['logicalCode']), str(_['softVer'])))
  39. doing_dict.pop(imei, None)
  40. mqttc.subscribe('server/%s/209' % imei)
  41. def on_disconnect(client, userdata, self):
  42. print('exit. client = %s' % str(client))
  43. try:
  44. mqttc1883 = MqttClient(client_id = 'webapp_' + str(uuid.uuid1()))
  45. try:
  46. mqttc1883.on_message = on_message
  47. mqttc1883.on_connect = on_connect
  48. mqttc1883.on_disconnect = on_disconnect
  49. mqttc1883.username_pw_set(settings.MQTT_USER, settings.MQTT_PSWD)
  50. mqttc1883.connect(settings.MQTT_HOSTNAME, 1883, 60)
  51. mqttc1883.loop_start()
  52. except Exception as e:
  53. print(e)
  54. mqttc1884 = MqttClient(client_id = 'webapp_' + str(uuid.uuid1()))
  55. try:
  56. mqttc1884.on_message = on_message
  57. mqttc1884.on_connect = on_connect
  58. mqttc1884.on_disconnect = on_disconnect
  59. mqttc1884.username_pw_set(settings.MQTT_USER, settings.MQTT_PSWD)
  60. mqttc1884.connect(settings.MQTT_HOSTNAME, 1884, 60)
  61. mqttc1884.loop_start()
  62. except Exception as e:
  63. print(e)
  64. objs = Device.get_collection().find(
  65. {'$and': [{'softVer': {'$regex': version_regex}}, {'softVer': {'$ne': version}}]})
  66. count = 0
  67. # 做一下保护, 避免查询语句错误
  68. devNoList = []
  69. for obj in objs:
  70. if str(obj['softVer']).startswith(version_check):
  71. devNoList.append(str(obj['devNo']))
  72. else:
  73. print 'error dev = %s' % str(obj['devNo'])
  74. for devNo in devNoList:
  75. try:
  76. if count >= 1:
  77. break
  78. dev = Device.get_dev(devNo) # type:DeviceDict
  79. if dev.online != DeviceOnlineStatus.DEV_STATUS_ONLINE:
  80. continue
  81. cmdPara = {"IMEI": devNo, "ota_set": {
  82. "fw_url": "http://develop.5tao5ai.com/uploaded/SMART_BOX_1.8.110_Luat_V0033_8955_SSL.bin"}}
  83. result = MessageSender.send(device = dev, cmd = DeviceCmdCode.SET_DEVINFO, payload = cmdPara)
  84. if result['rst'] != 0:
  85. print 'send updating cmd error,imei=%s' % devNo
  86. else:
  87. print 'success for imei=%s,send the message' % devNo
  88. count = count + 1
  89. doing_dict[devNo] = int(time.time())
  90. while True:
  91. if len(doing_dict) > 5:
  92. print('queue is full.')
  93. for imei in list(doing_dict.keys()):
  94. start_time = doing_dict[imei]
  95. if (int(time.time()) - start_time) > 2 * 60:
  96. doing_dict.pop(imei, None)
  97. _ = Device.get_dev(imei)
  98. timeout.write(
  99. '%s %s %s\n' % (str(_['devNo']), str(_['logicalCode']), str(_['softVer'])))
  100. time.sleep(5)
  101. else:
  102. print('queue is not full')
  103. break
  104. except Exception, e:
  105. print 'some exception =%s' % e
  106. finally:
  107. print('finished')
  108. mqttc1883.loop_stop()
  109. mqttc1883.disconnect()
  110. mqttc1883.close()
  111. mqttc1884.loop_stop()
  112. mqttc1884.disconnect()
  113. mqttc1884.close()
  114. while len(doing_dict) > 0:
  115. for imei in list(doing_dict.keys()):
  116. start_time = doing_dict[imei]
  117. if (int(time.time()) - start_time) > 2 * 60:
  118. doing_dict.pop(imei, None)
  119. _ = Device.get_dev(imei)
  120. timeout.write(
  121. '%s %s %s\n' % (str(_['devNo']), str(_['logicalCode']), str(_['softVer'])))
  122. time.sleep(1)
  123. error.close()
  124. timeout.close()
  125. done.close()