Linux Socket - UDP链接包

LINUX UDP SOCKET

01

UDP号绑定会报错吗?

会的,提示Address is using,本地的没有区别

UDP不需要发起链接,不知道是不是连接成功

client的IP地址和端口号不正确都不会报错,包一直向外抛

但是通过抓包工具,IP不正确

可以得到network unreachable的网关回答

端口不正确

可以得到对方主机拒绝端口的回答(图中端口错了)

运行终止后再次绑定端口号能否成功?

可以!因为UDP是未知状态下的抛送包,TCP下是不行的,要等握手链接告别表示已经空了可以断线,之后才能绑上,而UDP没有链接,只有包。

阻塞接通UDP包

在Server端kill掉进程

客户端没有任何反应

在Client端kill掉进程

服务端没有任何反应

总结:UDP链接不锁死端口号(没有握手过程不需要确认告别),kill掉任何一段另一端都没有反应(收不到信号)

02

阻塞方法和非阻塞方法没有区别

因为UDP对网络的状态是未知的,想获得报错信息,只能在程序里想办法抓到网关或者对方主机的refused包

非阻塞方法接通socket

03

阻塞方法一次读取20字节

读取到的内容只有20字节,每次都是前20字节

阻塞方法发送2字节//没有意义

每次都是前两字节

04

非阻塞方法法20字节

效果同阻塞方法

非阻塞方法发送2字节//没有意义

效果同阻塞方法

为什么UDP中缓冲区长度没有意义?

在UDP中调整缓冲区来保证字节数本身就是没有价值的

因为UDP的包本身不保证连续,不保证能够送达(送不到直接回信refused)有可能是缓冲区满,有可能丢包了。因此每个包就是一个完整的数据

05

Server端和Client端都具备双路收发

其他问题

UDP能否只绑定一个IP?

可以的,我所有的代码都是绑定第二个IP(一般第一个是回环IP,第二个是ens33通外网的IP,直接使用之前写的GET IP LIST即可

UDP Server之间能否收发数据?

可以,UDP不需要设置监听链接,没有accept和connect关系,Server和Client之间是等位的,两个Server之间也可以传递UDP包

UDP中的client端口号可以绑定吗?

可以绑定,但是没有绑定的意义。链接都不存在,指定端口也不能接听到什么内容。

UDP的端口号netstat能不能看到?

看不到的。试过无数次了,只能通过抓包工具看包的来源和去向(IP:PORT)

Client端是否一定需要connect?不使用connect的情况下有什么区别?

对于Server端来说没有区别,对于client端来说connect在自己主机给sockfd固定一个addr,这样可以直接写recv和send而不用每次都执行recvfrom和sendto。但是只影响到内核中的sockfd文件和地址族绑定,UDP协议还是UDP协议,收发包没有任何区别

持续写能否写满缓冲区?阻塞和非阻塞有区别吗?

有区别!阻塞的方法写满了缓冲区直接报错回弹了,非阻塞的一直发包,另一边缓冲区满了包直接扔了不读

UDP收发缓冲区可以设置?

可以的,setsockopt,但是没有任何价值,UDP的包本身是不连续的,除非为了接受一个硕大无比的UDP包,才去调整缓冲区,但是UDP本身丢包是不知道的,UDP包也没有长度指示符。

原文地址:https://www.cnblogs.com/liutianchen/p/8503556.html

时间: 2024-10-12 12:14:40

Linux Socket - UDP链接包的相关文章

linux 系统 UDP 丢包问题分析思路

转自:http://cizixs.com/2018/01/13/linux-udp-packet-drop-debug?hmsr=toutiao.io&utm_medium=toutiao.io&utm_source=toutiao.io 最近工作中遇到某个服务器应用程序 UDP 丢包,在排查过程中查阅了很多资料,总结出来这篇文章,供更多人参考. 在开始之前,我们先用一张图解释 linux 系统接收网络报文的过程. 首先网络报文通过物理网线发送到网卡 网络驱动程序会把网络中的报文读出来放到

linux系统内核UDP丢包原因分析

1.UDP校验和错误 现象:可以用netstat -su 查看到有UDP错包. tcpdump捕包,在wireshark打开捕获的udp报文,开启校验和选项,有错包. 方案:查找链路故障  www.ahlinux.com 2.防火墙开启 现象:特定端口的包收不到 方案:使用service iptables stop关闭. 3.rp_filter开启 现象:tcpdump有包,协议栈收不到.某个地址发送的包一个包都收不到,而另一地只发过来的没问题. 方案:将/etc/sysctl.conf中rp_

Linux Socket - 基本socket链接

0x0000 Linux Socket 函数 bind listen connect accept send recv read write 0x0001 Server绑不上ip 报错位置在bind函数 [[email protected] 01]# ./server 191.168.80.151 1588 191.168.80.151 : 1588 Bind: Cannot assign requested address port已被占用 报错位置在bind函数 [[email protec

Linux 网络编程——原始套接字实例:发送 UDP 数据包

以太网报文格式: 详细的说明,请看<MAC 头部报文分析>. IP 报文格式: 详细的说明,请看<IP 数据报格式详解>. UDP 报文格式: 详细的说明,请看<UDP 数据报格式详解>. 校验和函数: /******************************************************* 功能: 校验和函数 参数: buf: 需要校验数据的首地址 nword: 需要校验数据长度的一半 返回值: 校验和 ********************

Linux Socket编程

Linux Socket编程 一.Socket编程具体函数解析参考网址 http://www.cnblogs.com/skynet/archive/2010/12/12/1903949.html(本文转载于此网址,转载请注明源链接) 二.Socket编程的基本知识 2.1 基本TCP客户/服务器程序套接字函数 图2.1 TCP服务器/客户端响应方式 2.2 TCP三次握手 图2.2 TCP 三次握手建立连接 2.3 TCP断开连接 图2.3 TCP 四次握手断开连接 三.Socket编程细节知识

Linux Socket 原始套接字编程

对于linux网络编程来说,可以简单的分为标准套接字编程和原始套接字编程,标准套接字主要就是应用层数据的传输,原始套接字则是可以获得不止是应用层的其他层不同协议的数据.与标准套接字相区别的主要是要开发之自己构建协议头.对于原始套接字编程有些细节性的东西还是需要注意的. 1. 原始套接字创建 原始套接字的编程和udp网络编程的流程有点类似,但是原始套接字编程中不需要bind操作,因为在数据接收和发送过程中使用sendto和recvfrom函数实现数据的接收和发送.不过不是说原始套接字不能使用bin

Linux socket编程 DNS查询IP地址

本来是一次计算机网络的实验,但是还没有完全写好,DNS的响应请求报文的冗余信息太多了,不只有IP地址.所以这次的实验主要就是解析DNS报文.同时也需要正确的填充请求报文.如果代码有什么bug,欢迎指正啊.代码排版有点乱... 本文有以下内容 DNS报文的填充和解析 利用socket API传输信息 一.填充DNS请求报文 随便百度一下,就可以知道DNS报文的格式.所以这里只介绍如何填充DNS报文. 首先是填充报文首部: ? 1 2 3 4 5 6 7 8 9 /* 填充首部的格式大致相同,下面的

浅谈UDP(数据包长度,收包能力,丢包及进程结构选择)

UDP数据包长度 UDP数据包的理论长度 udp数据包的理论长度是多少,合适的udp数据包应该是多少呢?从TCP-IP详解卷一第11章的udp数据包的包头可以看出,udp的最大包长度是2^16-1的个字节.由于udp包头占8个字节,而在ip层进行封装后的ip包头占去20字节,所以这个是udp数据包的最大理论长度是2^16-1-8-20=65507. 然而这个只是udp数据包的最大理论长度.首先,我们知道,TCP/IP通常被认为是一个四层协议系统,包括链路层.网络层.运输层.应用层.UDP属于运输

linux查看网络链接状况命令netstat

linux查看网络链接状况命令 netstat 参数如下: -a 显示所有socket,包括正在监听的. -c 每隔1秒就重新显示一遍,直到用户中断它. -i 显示所有网络接口的信息,格式同“ifconfig -e”. -n 以网络IP地址代替名称,显示出网络连接情形. -r 显示核心路由表,格式同“route -e”. -t 显示TCP协议的连接情况. -u 显示UDP协议的连接情况. -v 显示正在进行的工作. 1. netstat -an | grep LISTEN 0.0.0.0的就是每