jjq_support_1.py 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. #!/usr/bin/env python3
  2. import json
  3. import redis
  4. import asyncio
  5. import tracemalloc
  6. from asyncua import Client
  7. from datetime import datetime
  8. opc_server_url = "opc.tcp://10.71.208.71:8098/TM.LongWallMind.OPCUAServer4.x" # OPC UA服务器的URL
  9. redis_ip = '127.0.0.1'
  10. tracemalloc.start()
  11. point_arr = [f"OPC.电液控.支架集.{num:03d}.立柱压力.后柱压力" for num in range(1, 138)]
  12. async def connect_and_read_opcua_data():
  13. ns = 2
  14. result_arr = {
  15. "sys_id": "support",
  16. "sys_name": "130306工作面支架压力",
  17. "data_time": "",
  18. "sys_point": {
  19. "support": []
  20. }
  21. }
  22. try:
  23. async with Client(url=opc_server_url, timeout=1) as client:
  24. await client.connect()
  25. for i in range(len(point_arr)):
  26. try:
  27. data = point_arr[i]
  28. node = f"ns={ns};s={data}"
  29. tag = client.get_node(node)
  30. value = await tag.read_value()
  31. res = {
  32. "key": data,
  33. "name": f"{i}号立柱压力",
  34. "unit": "Mpa",
  35. "val": round(value, 2)
  36. }
  37. result_arr["sys_point"]["support"].append(res)
  38. finally:
  39. continue
  40. now = datetime.now().strftime('%Y-%m-%d %H:%M:%S.%f')
  41. result_arr["data_time"] = now
  42. json_data = json.dumps(result_arr, indent=4)
  43. return json_data
  44. except TimeoutError:
  45. msg = "连接超时,请检查网络、服务器状态和连接参数。"
  46. error = {
  47. "code": -1,
  48. "msg": msg
  49. }
  50. return error
  51. except Exception as e:
  52. msg = f"发生其他错误: {e}"
  53. error = {
  54. "code": -2,
  55. "msg": msg
  56. }
  57. return error
  58. if __name__ == '__main__':
  59. loop = asyncio.get_event_loop()
  60. result = loop.run_until_complete(connect_and_read_opcua_data())
  61. redis_conn = redis.StrictRedis(host=redis_ip, port=6379, decode_responses=True)
  62. redis_conn.set("jinjiaqu_support", result)