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包也没有长度指示符。

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

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

    转自:http://cizixs.com/2018/01/13/linux-udp-packet-drop-debug?hmsr=toutiao.io&utm_medium=toutiao.i ...

  2. [转]SOCKET通信中TCP、UDP数据包大小的确定

    TCP.UDP数据包大小的确定 UDP和TCP协议利用端口号实现多项应用同时发送和接收数据.数据通过源端口发送出去,通过目标端口接收.有的网络应用只能使用预留或注册的静态端口:而另外一些网络应用则可以 ...

  3. Linux Socket - 基本socket链接

    0x0000 Linux Socket 函数 bind listen connect accept send recv read write 0x0001 Server绑不上ip 报错位置在bind函 ...

  4. Linux下unix socket 读写 抓包

    Linux下unix socket 读写 抓包-ubuntuer-ChinaUnix博客 http://blog.chinaunix.net/uid-9950859-id-247877.html

  5. Linux Socket 原始套接字编程

    对于linux网络编程来说,可以简单的分为标准套接字编程和原始套接字编程,标准套接字主要就是应用层数据的传输,原始套接字则是可以获得不止是应用层的其他层不同协议的数据.与标准套接字相区别的主要是要开发 ...

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

    UDP数据包长度 UDP数据包的理论长度 udp数据包的理论长度是多少,合适的udp数据包应该是多少呢?从TCP-IP详解卷一第11章的udp数据包的包头可以看出,udp的最大包长度是2^16-1的个 ...

  7. Nginx学习笔记(四) 源码分析&socket/UDP/shmem

    源码分析 在茫茫的源码中,看到了几个好像挺熟悉的名字(socket/UDP/shmem).那就来看看这个文件吧!从简单的开始~~~ src/os/unix/Ngx_socket.h&Ngx_s ...

  8. linux socket高性能服务器处理框架

    这个博客很多东西 http://blog.csdn.net/luozhonghua2014/article/details/37041765   思考一种高性能的服务器处理框架 1.首先需要一个内存池 ...

  9. Linux socket编程 DNS查询IP地址

    本来是一次计算机网络的实验,但是还没有完全写好,DNS的响应请求报文的冗余信息太多了,不只有IP地址.所以这次的实验主要就是解析DNS报文.同时也需要正确的填充请求报文.如果代码有什么bug,欢迎指正 ...

随机推荐

  1. 阿里云VPS(win系统)装ROS教程

    以下方法是VPS下的WIN系统下安装ROS的方法,LINUX暂时没有 VPS系统装2003或2008 ,建议2008 启动快,安全,但以下内容是在2003上测试的, 2003系统,2003设置开机自动 ...

  2. Ant+jmeter 实现自动化性能测试

    一.前言 性能测试首选的工具是JMeter,在此不多做介绍,但是不得不说JMeter也是一款非常好的接口测试工具.性能测试过程中手工重复的活动非常多,为了给客户提供一个性能测试报告,我用了一周时间进行 ...

  3. java工具库

    Guava: commons:---工具库(尤其里面的排序库) joda-time:

  4. Hadoop 2.7.3 安装配置及测试

    1.概述 Hadoop是一个由Apache基金会所开发的分布式系统基础架构.用户可以在不了解分布式底层细节的情况下,开发分布式程序.hadoop三种安装模式:单机模式,伪分布式,真正分布式.因在实际生 ...

  5. OpenMP 简单的规约

    ▶ 简单的计算和规约 ● 第一种方法,将全局和的指针传入工作函数中进行加和,使用 critical 来控制临界区的访问 #include <stdio.h> #include <st ...

  6. Linux测试环境搭建apache+mysql+php

    Linux Red Hat Enterprise Linux Server release 5.4 (Tikanga) Kernel \r on an \m Apache +Mysql+php 搭建准 ...

  7. swarm调度

    Swarm filters Configure the available filters 过滤器分为两类,即节点过滤器和容器配置过滤器. 节点过滤器对Docker主机的特性或Docker守护程序的配 ...

  8. 网页中给超链接添加"是否确认"的方法

    最近在做数据库, 需要给一个"删除"链接增加是否确认的弹出框, 在网上查到了两种方法: 1, 先看看最麻烦的一种 <html xmlns="http://www.w ...

  9. 并发包下常见的同步工具类详解(CountDownLatch,CyclicBarrier,Semaphore)

    目录 1. 前言 2. 闭锁CountDownLatch 2.1 CountDownLatch功能简介 2.2 使用CountDownLatch 2.3 CountDownLatch原理浅析 3.循环 ...

  10. shiro 和spring集合 实现登录时输入验证码并校验(七)

    编写实现验证码的主体实现类:CaptchaCode import java.util.UUID; import javax.servlet.http.HttpServletRequest; impor ...