热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用Python3.xSocketUDP广播消息(测试大数据流式处理)

使用PythonSocketUDP广播消息(测试大数据流式处理)以下代码基于Python3.8.x;在Window10环境下测试无误。

使用Python Socket UDP广播消息(测试大数据流式处理)

以下代码基于Python 3.8.x;在Window 10环境下测试无误。


Server

发送广播消息;

from socket import *SERV = socket(AF_INET, SOCK_STREAM)
HOST = '127.0.0.1'# port
p = input('set port(default 9999):')
PORT = int(p) if p else 9999SERV.bind((HOST, PORT))
SERV.listen(5)print('server startup, port: %d ..' % PORT)while True:print('waiting ..')sock, addr = SERV.accept()print('[%s:%d]: ready ..' % (addr[0], addr[1]))try:while True:data = input('[%s:%d]: ' % (addr[0], addr[1]))sock.send((data + '\n').encode('utf8'))except:print('disconnected ..')

注意:如果是Java客户端,一定要带上\n这个标记。


Server(可指定端口,同时启动多个端口)

from socket import *SERV = socket(AF_INET, SOCK_STREAM)
HOST = '127.0.0.1'# port
p = input('set port(default 9999):')
PORT = int(p) if p else 9999SERV.bind((HOST, PORT))
SERV.listen(5)print('server startup, port: %d ..' % PORT)while True:print('waiting ..')sock, addr = SERV.accept()print('[%s:%d]: ready ..' % (addr[0], addr[1]))try:while True:data = input('[%s:%d]: ' % (addr[0], addr[1]))sock.send((data + '\n').encode('utf8'))except:print('disconnected ..')

Client(非必须,测试使用)

用于接收消息;

实际场景为Flink或者Spark Streaming接收数据,最优方案为MQ,但测试环境部署较为麻烦,所以用Socket替代。

from socket import *HOST = '127.0.0.1'
PORT = 9999sock = socket(AF_INET, SOCK_DGRAM)
sock.bind((HOST, PORT))while True:try:data = sock.recv(1024)print(data.decode('utf8'))except Exception as e:print(e)

推荐阅读
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • Android工程师面试准备及设计模式使用场景
    本文介绍了Android工程师面试准备的经验,包括面试流程和重点准备内容。同时,还介绍了建造者模式的使用场景,以及在Android开发中的具体应用。 ... [详细]
  • ***byte(字节)根据长度转成kb(千字节)和mb(兆字节)**parambytes*return*publicstaticStringbytes2kb(longbytes){ ... [详细]
  • 本文整理了Java中java.lang.NoSuchMethodError.getMessage()方法的一些代码示例,展示了NoSuchMethodErr ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了为什么要使用多进程处理TCP服务端,多进程的好处包括可靠性高和处理大量数据时速度快。然而,多进程不能共享进程空间,因此有一些变量不能共享。文章还提供了使用多进程实现TCP服务端的代码,并对代码进行了详细注释。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
  • 本文介绍了Android中的assets目录和raw目录的共同点和区别,包括获取资源的方法、目录结构的限制以及列出资源的能力。同时,还解释了raw目录中资源文件生成的ID,并说明了这些目录的使用方法。 ... [详细]
  • 本文介绍了关于Java异常的八大常见问题,包括异常管理的最佳做法、在try块中定义的变量不能用于catch或finally的原因以及为什么Double.parseDouble(null)和Integer.parseInt(null)会抛出不同的异常。同时指出这些问题是由于不同的开发人员开发所导致的,不值得过多思考。 ... [详细]
  • 网址:https:vue.docschina.orgv2guideforms.html表单input绑定基础用法可以通过使用v-model指令,在 ... [详细]
author-avatar
瑞铭与我_109
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有