Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

51 рядки
1.2 KiB

  1. import asyncio
  2. import logging
  3. import random
  4. logging.basicConfig(level = logging.INFO, format = '{asctime} {levelname} {message}', style = '{')
  5. class EchoServerProtocol(asyncio.Protocol):
  6. def __init__(self, loop = None):
  7. self.loop = loop or asyncio.get_event_loop()
  8. def send(self, data):
  9. logging.info(f'Send: {data!r}')
  10. self.transport.write(data)
  11. def connection_made(self, transport):
  12. peername = transport.get_extra_info('peername')
  13. logging.info('Connection from {}'.format(peername))
  14. self.transport = transport
  15. self.connected = True
  16. asyncio.create_task(self.pingloop())
  17. async def pingloop(self):
  18. while self.connected:
  19. self.send(b'PING :' + str(random.randint(0, 10000)).encode('ascii') + b'\r\n')
  20. await asyncio.sleep(10)
  21. def data_received(self, data):
  22. logging.info('Data received: {!r}'.format(data))
  23. def connection_lost(self, exc):
  24. logging.info(f'Connection to {self.transport.get_extra_info("peername")} lost')
  25. self.connected = False
  26. async def main():
  27. # Get a reference to the event loop as we plan to use
  28. # low-level APIs.
  29. loop = asyncio.get_running_loop()
  30. server = await loop.create_server(
  31. lambda: EchoServerProtocol(),
  32. '127.0.0.1', 8888)
  33. async with server:
  34. await server.serve_forever()
  35. asyncio.run(main())