UDP和TCP的对比
--UDP处理的细节比TCP少。
--UDP不能保证消息被传送到目的地。
--UDP不能保证数据包的传递顺序。
--TCP处理UDP不处理的细节。
--TCP是面向连接的协议
--UDP是无连接协议
--TCP保持一个连接
--UDP只是把数据发送出去而已
TCP的优点
--TCP提供以认可的方式显示的创建连接和终止连接。
--TCP保证可靠的,顺序的以及不会重复的数据传输。
--TCP处理流控制。
--TCP允许数据优先。
--如果数据没有传送到,TCP套接字会返回出错提示。
--TCP通过保持连接并将数据块分成更小的分片来处理大数据,而无需程序员编码处理。
TCP的缺点
--TCP需要创建并保持一个连接,给系统带来很大开销。
--TCP数据传输效率低。
并发机制
.增加server数量
.多层结构
一台server同事支持1000个client
中间件对于普通用户来讲是server,对于server是client,一个中间件同时支持1000个client
中间件会遍历自己管理的1000个client,发现client需要连接server,才会将请求发送给server,不需要连接server的client就不向server发送请求
多层结构的原理:利用不是client在同一时间内都需要向server发送请求,永远只有部分用户需要发送请求。
UDP的优点
--UDP不要求保持一个连接
--UDP没有因接收方没有收到数据包重传而带来开销。
--设计UDP目的是用于短应用和控制消息。
--在一个数据包接一个数据包基础上,UDP要求的网络带宽比TCP小。
UDP的缺点
--程序员必须创建代码监测数据包的正确性,必要时重传。
--程序员必须把大数据包分片。
选择使用哪一种协议?
--一些消息重要程度不高,或者有规律重复,可以使用UDP。
--如果要传输一个重要的数据,丢失一点就会破坏整个数据,那么需要选择TCP。
--telnet,ssh,http等基本都基于TCP。
--流媒体为了保证很窄的网络带宽来传送更多的数据,基本采用UDP。
多数游戏中,丢失来自某个用户的状态更新可能不会引起注意,所以采用UDP。
设计用在局域网的应用可以采用UDP,因为在局域网中丢失数据包的可能性很低。
使用UDP与TCP所用的代码基本类似,唯一的区别在于socket函数调用的时候的一个参数不同
int socket(int domain,int type,int protocol);
参数type为SOCK_STREAM代表TCP,SOCK_DGRAM代表UDP。
对于TCP和UDP都可以使用recvfrom函数,但recv只能TCP使用。
使用UDP发送数据。
ssize_t sendto(int s,const void *buf,size_t len,int flags,const struct sockaddr *to,socklen_t tolen);
参数s是指套接字描述符
参数buf是发送数据buf内存地址指针
参数len是发送数据的长度
参数flags一般传0
参数to是结构sockaddr的内存地址指针
参数tolen是结构sockaddr的大小
UDP不需要握手机制,也不需要确认另一个系统是否有服务端在listen。
成功返回发送的字节数,失败返回-1,并且设置errno
使用UDP接收数据
ssize_t recvfrom(int s,void * buf,size_t blen,int flags,struct sockaddr * from,socklen_t * fromlen);
成功返回接收字节数,失败返回-1,并且设置errno;UDP不同于TCP/IP,就算发送端关闭,recvfrom也不会返回0,因为UDP是无连接协议。
UDP不需要listen,bind之后就可以接受数据了。
recv函数只是从UDP缓存中读数据(此时数据已经在自己的电脑上了),不是直接从网络中读数据,什么时候UDP缓存区满了,另一边的send函数才会停止发送数据。
UDP发送广播消息
IP地址由四个字节组成,每个字节十进制是0时,表示本机,十进制是255就是广播消息,
例如:192.168..255这就是在 192.168..x这个局域网中广播消息
但是255.255.255.255并无法在全世界广播消息,因为路由器会屏蔽局域网中广播消息,不会传递到公网上。
代码如下
int on = ;
if (setsockopt(st, SOL_SOCKET, SO_BROADCAST, &on, sizeof(on)) == -)
{
  printf("setsockopt failed ! error message :%s\n", strerror(errno));
  return -;
}
sendto和recvform
在UDP中,当UDP接收端,只要bind端口号,sendto发送的数据就会缓存到接收端的UDP缓存区中,如果缓存区已满,那么sendto函数便会报错(信息过长错误)。
将域名转化为IP地址
const char *getIPAddrbvHostname(const char *hostname)
{
static char s[]={};
struct hostent *h;
h=gethostbyname(hostname);
strcpy(s,inet_ntoa(*((struct in_addr *)h->h_addr)));
return s;
}
将struct sockaddr_in转化为IP地址
const char *getIPAddrbvaddr(struct sockaddr_in *client_addr)
{
return inet_ntoa(client_addr->sin_addr);
}
void sockaddr_toa(const struct sockaddr_in *addr,char *IPAddr)
{
unsigned char *p=(unsiged char *)&(addr->sin_addr.s_addr);
sprintf(IPAddr,"%u.%u.%u.%u",p[],p[],p[],p[]);
}
inet_ntoa()函数是一个线程不安全函数,这个函数返回的是字符串,
而参数并没有传递字符指针(不是当前函数分配内存),这说明这个函数返回的字符串一定不在线程的栈上,不在本线程的栈上,就有可能被其他线程修改,导致错误。
获取socket自身的sockaddr
int getsockname(int sockfd,struct sockaddr *addr,socklen_t *addrlen);
获取socket连接的远端sockaddr
int getpeername(int sockfd,struct sockaddr *addr,socklen_t *addrlen);

Linux 网络编程五(UDP协议)的更多相关文章

  1. Linux网络编程(五)

    /*Linux网络编程(五)——多路IO复用之select() 网络编程中,使用IO复用的典型场合: 1.当客户处理多个描述字时(交互式输入以及网络接口),必须使用IO复用. 2.一个客户同时处理多个 ...

  2. Linux网络编程:UDP Socket编程范例

    TCP协议提供的是一种可靠的,复杂的,面向连接的数据流(SOCK_STREAM)传输服务,它通过三段式握手过程建立连接.TCP有一种"重传确认"机制,即接收端收到数据后要发出一个肯 ...

  3. 网络编程(UDP协议-聊天程序)

    网络编程中的UDP协议中聊天程序,发送端口,和接受端口. 发送端口(Send): <span style="font-size:18px;">package cn.it ...

  4. 网络编程(基于udp协议的套接字/socketserver模块/进程简介)

    一.基于UDP协议的套接字 TCP是建立可靠连接,并且通信双方都可以以流的形式发送数据.相对TCP,UDP则是面向无连接的协议. 使用UDP协议时,不需要建立连接,只需要知道对方的IP地址和端口号,就 ...

  5. JAVA基础知识之网络编程——-基于UDP协议的通信例子

    UDP是一种不可靠的协议,它在通信两端各建立一个socket,这两个socket不会建立持久的通信连接,只会单方面向对方发送数据,不检查发送结果. java中基于UDP协议的通信使用DatagramS ...

  6. UNIX网络编程——基于UDP协议的网络程序

    一.下图是典型的UDP客户端/服务器通讯过程 下面依照通信流程,我们来实现一个UDP回射客户/服务器: #include <sys/types.h> #include <sys/so ...

  7. java 网络编程基础 UDP协议的Socket:DatagramSocket;广播Socket:MulticastSocket

    什么是UDP协议: UDP协议是一种不可靠的网络协议,它在通信实例的两端各建立一个Socket 但这两个 Socket之间并没有虚拟链路,这两个Socket只是发送.接收数据报的对象.Java 提供了 ...

  8. Java学习笔记52(网络编程:UDP协议案例)

    InetAddress类: 表示互联网中的IP地址,示例: package demo; import java.net.InetAddress; import java.net.UnknownHost ...

  9. 网络编程: 基于UDP协议的socket

    udp是无链接的,启动服务之后可以直接接受消息,不需要提前建立链接 UDP协议的通信优势: 允许一个服务器同时和多个客户端通信, TCP不行 服务端 import socket sk = socket ...

随机推荐

  1. iOS didReceiveMemoryWarning 的处理

    当iOS触发didReceiveMemoryWarning这个方法的时候,我们一般会做一些手动处理,强制清理掉一些目前不用的数据.但是这个方法并不只是单纯的通知开发者你的内存已经吃紧了,系统通知你的同 ...

  2. 谷歌的网页排序算法(PageRank Algorithm)

    本文将介绍谷歌的网页排序算法(PageRank Algorithm),以及它如何从250亿份网页中捞到与你的搜索条件匹配的结果.它的匹配效果如此之好,以至于“谷歌”(google)今天已经成为一个被广 ...

  3. HDFS主要特性和体系结构

    引言 Hadoop分布式文件系统(HDFS)被设计成适合运行在通用硬件(commodity hardware)上的分布式文件系统.它和现有的分布式文件系统有很多共同点.但同时,它和其他的分布式文件系统 ...

  4. iOS多线程-03-NSOperation与NSOperationQueue

    简介 通过NSOperation与NSOperationQueue的组合也能实现多线程 通常将任务封装成NSOperation对象,并将对象添加到NSOperationQueue中实现 NSOpera ...

  5. linux NFS服务器安装与配置 思路

    一,nfs服务优缺点 NFS 是Network File System的缩写,即网络文件系统,可以让不同的客户端挂载使用同一个目录,作为共享存储使用,这样可以保证不同的节点客户端数据一致性,在集群架构 ...

  6. 如何解决"应用程序无法启动,因为应用程序的并行配置不正确"问题

    应用程序事件日志中: "C:\windows\system32\test.exe"的激活上下文生成失败.找不到从属程序集 Microsoft.VC80.MFC,processorA ...

  7. 【故障处理】IMP-00010错误 12C的dmp文件导入11G

    [故障处理]IMP-00010错误 12C的dmp文件导入11G 1  BLOG文档结构图 2  前言部分 2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其 ...

  8. java微信接口之五—消息分组群发

    一.微信消息分组群发接口简介 1.请求:该请求是使用post提交地址为: https://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_t ...

  9. 《HeadFirst设计模式》读后感——对学习设计模式的一些想法

    最近看完了<HeadFirst设计模式>,GOF的<设计模式——可复用面向对象软件的基础>的创建型模式也读完了,经历了从一无所知到茅塞顿开再到充满迷惑的过程. 不得不说< ...

  10. 观nginx与lvs负载均衡的较量

    在技术工作者中,常用到的就是lvs负载均衡和Nginx负载均衡了.这两者也是比较普及的.那么,根据不同的需求,两者存在着不同的优势.具体选择哪一个,还要看您的要求了.那么我们在此为大家分享一篇文章,对 ...