UDP介绍

  udp协议又称用户数据报协议

  在OSI七层模型中,它于TCP共同存在于传输层

  仅用于不要求可靠性,不要求分组顺序且数据较小的简单传输,力求速度

UDP结合socket用法

1、创建socket对象

2、收发消息(发消息时需要指定服务器的ip及端口)

from socket import *        # 导入socket模块里所有功能
client = socket(AF_INET,SOCK_DGRAM) # 这里要指定SOCK_DGRAM,为UDP数据报协议 while True:
msg = input('>>(q:退出):').strip()
if msg == 'q':
break
if not msg:
continue
# 发送信息也是发送二进制数据,用sendto()函数 ,括号里加入数据以及服务器的ip及端口
client.sendto(msg.encode('utf-8'),('127.0.0.1',8080))
# 接收数据用recvfrom()函数,括号里指定的缓存区大小,经计算1472最合适,
# 不会超过MTU的大小,所以也不会被切分发送,返回的一个是元组,包括数据还有对方的ip及端口
# 如果对面发过来的数据报大小比指定的缓存区大,就会报错
data,addr = client.recvfrom(1472)
print(data)

客户端

1、创建socket对象

2、绑定ip及端口地址

3、收发消息(发消息时需要指定对方的ip及端口)

from socket import * # 导入socket模块
server = socket(AF_INET,SOCK_DGRAM)
server.bind(('127.0.0.1',8080)) # 服务器需要绑定自己的ip及端口,让别人能找到你 while True:
# 接收数据
data,addr = server.recvfrom(1472)
# 发送数据
server.sendto(data.upper(),addr)

服务器端

UDP于TCP的区别  ******

特性上的区别

#1、传输不可靠

#2、不需要建立连接

#3、不会粘包

#4、单词数据报不能太大

代码上的区别

1、服务器端

  --1、服务器端不需要监听  listen

  --2、不需要接收请求  accept

  --3、收数据  recvfrom(缓冲区大小)

  --4、发数据 sendto(二进制数据,地址)

2、客户端

  --1、不需要建立连接

  --2、收数据 recvfrom(缓冲区大小)

  --3、发数据 sendto(二进制数据,地址)

DNS服务器(了解)

1、dns全程:域名解析服务器

2、dns作用:将域名转换为IP地址  想要连接服务器,就一定要知道IP地址才能访问

3、使用dns原因:单独的ip地址不方便记忆,所以把ip地址和域名绑定在一起,通过域名可以找到ip地址从而访问网站

4、dns的形式:dns是cs结构的server端,使用的是udp协议,因为传输的数据小,对速度要求高

        dns本质就是一个数据库,里面就存储域名和ip的对应关系

5、域名的结构:

  拿news.cctv.com来说

    .com :顶级域名

    cctv  :二级域名

    news :三级域名

操作系统概念

1、进程概念:正在运行的程序   进程来自于操作系统,没有操作系统就没有进程

2、操作系统概念: 操作系统也是一套软件

3、操作系统功能:

  1)控制硬件,隐藏复杂的硬件细节

  2)将无序的硬件竞争变得有序

多道技术

1、产生原因:

  早些年,计算机同一时间只能运行一个程序,这时候是不可能并发的

  要并发,就需要不同的应用程序,如何使多个应用程序同时被运行,这就需要多道技术

2、多道技术的原理: (多道技术主要是为了提高计算机的利用率)

  --1、空间复用:把内存分割为不同区域,每个区域装入不同的程序

  --2、时间复用:当一个程序执行IO操作时,切换到另一个程序来执行

         光切换还不行,必须在切换前保存当前状态,以变恢复执行

3、注意点:

  并不是多道就一定提高了效率

  如果多个任务都是纯计算 ,那么切换反而降低了效率

  遇到IO操作才应该切换,这样才能提高效率

UDP及操作系统理论的更多相关文章

  1. 4月23日 python学习总结 套接字UDP和 操作系统理论,多道理论

    一.套接字UDP udp是无链接的,先启动哪一端都不会报错 UDP(user datagram protocol,用户数据报协议)是无连接的,面向消息的,提供高效率服务.不会使用块的合并优化算法,, ...

  2. udp套接字及利用socketserver模块实现并发以及并发编程

    一:基于udp协议(数据报协议)的套接字:和tcp协议的套接字对比而言,由于udp是无链接的,所以先启动哪一端都不会报错,而且udp也不会有粘包 现象,所以对比下来,tcp协议的话传输数据更加可靠,但 ...

  3. 基于udp协议的套接字,socketserver模块,多道技术,进程理论

    进程指的是一个正在进行/运行的程序,进程是用来描述程序执行过程的虚拟概念 进程vs程序 程序:一堆的代码 进程:程序执行的过程 进程的概念起源于操作系统,进程是操作系统最核心的概念,操作系统的其他所有 ...

  4. TCP与UDP比较 以及并发编程基础知识

    一.tcp比udp真正可靠地原因 1.为什么tcp比udp传输可靠地原因: 我们知道在传输数据的时候,数据是先存在操作系统的缓存中,然后发送给客户端,在客户端也是要经过客户端的操作系统的,因为这个过程 ...

  5. 探索UDP套接字编程

    UDP和TCP处于同一层网络模型中,也就是运输层,基于二者之上的应用有很多,常见的基于TCP的有HTTP.Telnet等,基于UDP有DNS.NFS.SNMP等.UDP是无连接,不可靠的数据协议服务, ...

  6. RUDP之一 —— UDP VS TCP

    原文链接 原文:http://gafferongames.com/networking-for-game-programmers/udp-vs-tcp/ 介绍 大家好,我是Glenn Fiedler, ...

  7. 【转】 探索UDP套接字编程

    UDP和TCP处于同一层网络模型中,也就是运输层,基于二者之上的应用有很多,常见的基于TCP的有HTTP.Telnet等,基于UDP有DNS.NFS.SNMP等.UDP是无连接,不可靠的数据协议服务, ...

  8. UNIX网络编程——UDP回射服务器程序(初级版本)以及漏洞分析

    该函数提供的是一个迭代服务器,而不是像TCP服务器那样可以提供一个并发服务器.其中没有对fork的调用,因此单个服务器进程就得处理所有客户.一般来说,大多数TCP服务器是并发的,而大多数UDP服务器是 ...

  9. 【RL-TCPnet网络教程】第16章 UDP用户数据报协议基础知识

    第16章      UDP用户数据报协议基础知识 本章节为大家讲解UDP(User Datagram Protocol,用户数据报协议),需要大家对UDP有个基础的认识,方便后面章节UDP实战操作. ...

随机推荐

  1. Qt kdChart 甘特图案例

    KDChart  甘特图在Qt中的加载使用案例,代码来自官方 mainwindow.h /******************************************************* ...

  2. HBase里配置SNAPPY压缩以后regionserver启动不了的问题

    配置了HBase的SNAPPY压缩以后,出现regionserver启动不了的问题.分析应该是属性配置错了! 官网上的是:<name>hbase.regionserver.codecs&l ...

  3. 算法习题---3.01猜数字游戏提示(UVa340)

    一.题目 实现一个经典“猜数字”游戏.给定答案序列和用户猜的序列,统计有多少数字位置正确(A),有多少数字在两个序列都出现过但位置不对(B). 输入包含多组数据.每组输入第一行为序列长度n,第二行是答 ...

  4. Python与C/C++相互调用(python2 调c++那个试了ok)

    一.问题 Python模块和C/C++的动态库间相互调用在实际的应用中会有所涉及,在此作一总结. 二.Python调用C/C++ 1.Python调用C动态链接库 Python调用C库比较简单,不经过 ...

  5. Window和Linux文件共享

    一.先设置window上的目录共享 1.1.右击文件要共享的文件夹,选择属性 1.2.设置要共享给的用户和设置用户操作权限 二.安装CIFS共享服务 sudo yum -y install cifs- ...

  6. ContextCleaner ——Spark 应用程序的垃圾回收器

    ContextCleaner是一个Spark服务,负责在应用程序范围内清除 shuffles, RDDs, broadcasts, accumulators和checkpointed RDDs,目的是 ...

  7. java中byte数组,二进制binary安装chunk大小读取数据

    int CHUNKED_SIZE = 8000; public void recognizeText(byte[] data) throws InterruptedException, IOExcep ...

  8. Python网络编程之TCP套接字简单用法示例

    Python网络编程之TCP套接字简单用法示例 本文实例讲述了Python网络编程之TCP套接字简单用法.分享给大家供大家参考,具体如下: 上学期学的计算机网络,因为之前还未学习python,而jav ...

  9. Apache配置优化之开启GZip传输

    1.确保apache已经编译的模块里有mod_deflate模块 2.确保apache的配置文件里引入了压缩的模块 3.确保要开启Gzip压缩的虚拟主机配置里有如下配置,并重启apache服务:如果要 ...

  10. linux cron计划任务防止多个任务同时运行

    使用linux flock 文件锁实现任务锁定,解决冲突格式:flock [-sxun][-w #] fd#flock [-sxon][-w #] file [-c] command选项-s, --s ...