利用Docker技术实现UDP广播效果(网络编程python版)
docker的安装见官方文档 我使用的系统为Ubuntu16.04
Ubuntu系统安装docker文档地址:https://docs.docker.com/engine/installation/linux/ubuntulinux/
Ubuntu的版本必须和文档中提到的要一致
-----------------------------------------------------------------
1.查找相关的Ubuntu镜像
可以去docker镜像官网:https://hub.docker.com 点击第一个查看
也可以使用docker命令查看镜像: sudo docker search ubuntu
2.用docker命令下拉自己想要的镜像 sudo docker pull ubuntu:16.04
因为我这里已经下载好了,所以直接显示了状态信息。如果没有该images(镜像)的话,会从镜像官网下载,请耐心等待。
下载成功后可以用命令 sudo docker images 查看自己下载的镜像
这里有我下载的其他镜像, 我们下载的镜像REPOSITORY是ubuntu, TAG为16.04
3.利用下载的ubuntu镜像安装容器: sudo docker run -it --name h1 ubuntu:16.04
这里的--name指明了自己所要创建的容器的名字,ubuntu16.04为我们的镜像
因为我在这里要创建两个容器,第二个容器h2和h1步骤完全一样,这里不做阐述。
sudo docker run -it --name h2 ubuntu:16.04
创建成功后会自动进入容器里面,使用命令exit可以退出当前容器。
退出后可以使用 sudo docker start h1
sudo docker attach h1(输完命令完后点一两下回车)
输完这两个命令后就可以再次进入容器。
进入容器后首先更新系统的源: apt-get update
更新完成后,安装vim方面后面编写代码: apt install vim -y
该ubuntu是没有ifconfig和ping命令的,如果需要的可以选择安装(见我上一篇博客)
4.好了,到这里所有的准备已经完成了。现在开始使用python编写UDP Broadcast了并查看相应的结果。
udp_broadcast.py
#!/usr/bin/env python3
# UDP client and server for broadcast messages on a local LAN import argparse, socket BUFSIZE = 65535 def server(interface, port):
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
# sock.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1)
sock.bind((interface, port))
print('Listening for datagrams at {}'.format(sock.getsockname()))
while True:
data, address = sock.recvfrom(BUFSIZE)
text = data.decode('ascii')
print('The client at {} says {}'.format(address, text)) def client(network, port):
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
sock.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1)
text = 'Broadcast datagram!'
sock.sendto(text.encode('ascii'), (network, port)) if __name__=='__main__':
choices = {'client':client, 'server':server}
parser = argparse.ArgumentParser(description='Send and receive UDP broadcast.')
parser.add_argument('role', choices=choices, help='which role to play.')
parser.add_argument('host', help='interface the server listen at network the client sends to')
parser.add_argument('-p', metavar='POST', type=int, default=1060, help='UDP port(default 1060)')
args = parser.parse_args()
function = choices[args.role]
function(args.host, args.p)
因为对docker技术也是刚刚入门,所以只会简单的用法。在使用scp命令实现文件传输会提示失败,
所以我干脆使用了一个笨办法,在本机(docker:172.17.0.1)和h1(172.17.0.2)和h2(172.17.0.3)中
都写了一遍udp_broadcast.py .
查看效果
本机输入: sudo python udp_broadcast.py server ""
h2输入 : sudo python udp_broadcast.py server ""
h1输入 : sudo python udp_broadcast.py client "<broadcast>"
ok效果和预想的一样, h1作为客户端发送udp 广播, 本机和h2作为服务器都有收到h1发送的udp广播信息。
利用Docker技术实现UDP广播效果(网络编程python版)的更多相关文章
- 初识Socket通信:基于TCP和UDP协议学习网络编程
学习笔记: 1.基于TCP协议的Socket网络编程: (1)Socket类构造方法:在客户端和服务器端建立连接 Socket s = new Socket(hostName,port);以主机名和端 ...
- 网络编程+Python
一.网络编程(模块:socket,from socket import *): 1. 网络层的IP地址可以唯一标识网络中的主机,传输层的"协议+端口"则可以唯一标识主机中应用程序( ...
- 《Java从入门到放弃》JavaSE入门篇:网络编程(入门版)
要进行网络编程,首先要搞清楚目的是什么. 网络编程说简单点就是在网络上的计算机进行数据的交互. 既然要进行数据交互,那就需要有一个发送方和一个接受方. 按网络上的说法,就是一个攻一个受· 当然,现阶段 ...
- 基于UDP协议的网络编程
UDP协议是一种不可靠的网络协议,它在通信实例的两端各建立一个Socket,但这两个Socket之间并没有虚拟链路,这两个Socket只是发送.接收数据报的对象. Java使用DatagramSock ...
- 网络编程-python实现-UDP(1.1.2)
@ 目录 1.UDP是什么 2.代码实现 1.UDP是什么 Internet 协议集支持一个无连接的传输协议,该协议称为用户数据报协议(UDP,User Datagram Protocol).UDP ...
- UDP协议的网络编程
public class UDPTest { //发送端@Testpublic void sender() throws IOException { DatagramSocket socket = n ...
- 网络编程-python实现-socket(1.1.1)
@ 目录 1.不同电脑进程之间如何通信 2.什么是socket 3.创建socket 1.不同电脑进程之间如何通信 利用ip地址 协议 端口 标识网络的进程,网络中的进程通信就可以利用这个标志与其他进 ...
- python 网络编程 代码版
写博客最怕写什么? 系统原理,框架内核... #!/usr/bin/env python # -*- coding:utf-8 -*- import socket sk = socket.socket ...
- 网络编程-python实现-TCP(1.1.3)
@ 目录 1.TCP是什么 2.代码实现 1.TCP是什么 传输控制协议(TCP,Transmission Control Protocol)是一种面向连接的.可靠的.基于字节流的传输层通信协议,由I ...
随机推荐
- 干货分享:让你分分钟学会 JS 闭包
闭包,是 Javascript 比较重要的一个概念,对于初学者来讲,闭包是一个特别抽象的概念,特别是ECMA规范给的定义,如果没有实战经验,很难从定义去理解它.因此,本文不会对闭包的概念进行大篇幅描述 ...
- 强强联合,Testin云测&云层天咨众测学院开课了!
Testin&云层天咨众测学院开课了! 共享经济时代,测试如何赶上大潮,利用碎片时间给女票或者自己赚点化妆品钱? 2016年12月13日,Testin联手云层天咨带领大家一起推开众测的大门 ...
- Java类变量和成员变量初始化过程
一.类的初始化 对于类的初始化:类的初始化一般只初始化一次,类的初始化主要是初始化静态成员变量. 类的编译决定了类的初始化过程. 编译器生成的class文件主要对定义在源文件中的类进行了如下的更改: ...
- [原创]关于Hibernate中的级联操作以及懒加载
Hibernate: 级联操作 一.简单的介绍 cascade和inverse (Employee – Department) Casade用来说明当对主对象进行某种操作时是否对其关联的从对象也作类似 ...
- java springMVC SSM 操作日志 4级别联动 文件管理 头像编辑 shiro redis
A 调用摄像头拍照,自定义裁剪编辑头像 B 集成代码生成器 [正反双向](单表.主表.明细表.树形表,开发利器)+快速构建表单; 技术:313596790freemaker模版技术 ,0个代码不用写 ...
- 将css和js缓存到localStorage缓存,提高网页响应速度
适用于小站点,这很极致,很快速~~ /** * Created by SevenNight on 2016/9/21 0021. * 插件功能:使用localStorage缓存js和css文件,减少h ...
- centos6.X使用Apache+Mono搭建asp.net 环境
mark 一下时间 2016年1月19日09:42:49 mono是指由Novell公司(由Xamarin发起,并由Miguel de lcaza领导的,一个致力于开创·NET在Linux上使用的开 ...
- RCP:ISourceLocator翻译
org.eclipse.debug.core.model.ISourceLocator A source locator locates source elements for stack frame ...
- 锤子OneStep及BigBang使用体验
令人期待的Smartisan OS v3.1.2终于推送了,第一时间下载了更新.几乎花了半个小时才升级完毕,捧着还热乎的手机,赶忙体验一下传说中的两大杀器:OneStep以及BigBang. 先说On ...
- MongoDB Java Driver操作指南
MongoDB为Java提供了非常丰富的API操作,相比关系型数据库,这种NoSQL本身的数据也有点面向对象的意思,所以对于Java来说,Mongo的数据结构更加友好. MongoDB在今年做了一次重 ...