网络协议之:socket协议详解之Datagram Socket
简介
上一篇文章我们讲解了Socket的分类和最常用到的Stream Socket,Stream Socket一般是基于TCP协议的,所以我们经常在web服务中能够看到他们的身影。当然TCP协议有个孪生兄弟叫做UDP,那么基于UDP来做传输协议的socket协议就叫做Datagram Socket,今天我们一起来详细了解一下Datagram Socket。
什么是Datagram Socket
和有连接的Stream Socket不同,Datagram Socket是无连接的。有连接的Stream Socket表明这个socket是稳定可靠的,所以我们可以在Stream socket中进行稳定的数据传输,当然这个稳定是说数据包不会丢失,但是并不一定能够确保数据包不被篡改。
Datagram Socket这种无连接的通常被用在容许数据部分丢失的场景,比如语音、视频等等,无连接的好处就是不需要TCP那样复杂的建立连接的步骤,所以相对而言更加简单。
Datagram Socket通常使用的就是UDP协议作为底层的数据传输协议。
对于UDP来说,因为UDP协议本身并不会保证数据的顺序和数据异常的处理,这些都需要在应用程序中自己实现。
常见的UDP应用有DNS(Domain Name System)服务,NTP(Network Time Protocol)服务等等。
在JDK的java.net包中提供了对Datagram Socket的封装,在其中定义了三个连接的状态:
class DatagramSocket implements java.io.Closeable {
...
static final int ST_NOT_CONNECTED = 0;
static final int ST_CONNECTED = 1;
static final int ST_CONNECTED_NO_IMPL = 2;
...
}
分别表示没有建立连接,建立了连接和建立了连接,但是还没有到实现的level。
另外,在DatagramSocket中还包含了一个连接的地址和端口:
InetAddress connectedAddress = null;
int connectedPort = -1;
使用socat来创建UDP服务
注意,在使用后续的命令之前,需要在unix环境中执行安装命令:yum install iproute2 netcat-openbsd socat
和之前的Stream Socket一样,我们也可以使用socat命令,来建立一个UDP服务器,我们需要用到socat的下面几个参数:
udp4-listen:<port> groups=FD,SOCKET,LISTEN,CHILD,RANGE,IP4,UDP
udp6-listen:<port> groups=FD,SOCKET,LISTEN,CHILD,RANGE,IP6,UDP
我们需要监听udp4和udp6的数据,所以这里使用 udp4-listen和udp6-listen两个参数。
后面的端口号可以自定义,这里我们还是使用同样的8888端口,对应的命令如下:
socat UDP4-LISTEN:8888,fork /dev/null&
socat UDP6-LISTEN:8888,ipv6only=1,fork /dev/null&
上面的命令,我们在8888端口上监听UDP4和UDP6的连接信息,其中fork参数表示程序在接收到程序包之后继续运行,如果不用fork,那么程序会自动退出。
socat后面本来要接一个bi-address,这里我们使用/dev/null,表示丢弃掉所有的income信息。
UDP6-LISTEN有个特殊的参数叫做ipv6only,表示收到的数据包不要发送到IPv4-mapped IPv6 addresses。
什么是IPv4-mapped IPv6 addresses? 简单点说就是将IPv4映射到了IPv6的地址中。
执行上述命令,我们会得到下面的输出:
[1] 16174
[2] 16184
因为是后台执行,所以我们返回了进程的ID。
使用ss命令来监控Datagram Sockets
ss命令可以用来检查socket的状态,这里我们需要用到ss的这样几个参数:
-4, --ipv4 display only IP version 4 sockets
-u, --udp display only UDP sockets
-l, --listening display listening sockets
-n, --numeric don't resolve service names
因为我们只监听ipv4和ipv6的数据,所以这里我们用-4和-6这两个参数。
另外因为只需要监听udp sockets,所以需要使用-u参数。
因为是监听,所以使用-l参数,最后我们希望看到具体的数字,而不是被解析成了服务名,所以这里使用-n参数。
我们使用下面的命令看看结果:
ss -4 -uln
可以得到下面的结果:
State Recv-Q Send-Q Local Address:Port Peer Address:Port
UNCONN 0 0 *:8888 *:*
上面的命令只监听了Ipv4,我们再看看Ipv6:
ss -6 -uln
可以得到下面的结果:
State Recv-Q Send-Q Local Address:Port Peer Address:Port
UNCONN 0 0 :::8888 :::*
和Ipv4的很类似,表示我们在Ipv6上监听到了端口8888。
使用nc建立和UDP Socket的连接
我们已经建立好了了监听UDP连接的服务器,接下来我们尝试使用nc命令来进行连接。
nc是Ncat的简称,是一个非常小并且高效的网络工具。我们来看下本例子中会用到的参数:
-4 Use IPv4 only
-6 Use IPv6 only
-u, --udp Use UDP instead of default TCP
-v, --verbose Set verbosity level (can be used several times)
-z Zero-I/O mode, report connection status only
因为需要连接到Ipv4和Ipv6,所以需要-4和-6参数。
默认情况下nc使用的是TCP协议,如果要使用udp则需要使用-u这个参数。
另外我们需要输出详细的信息,所以需要-v参数,最后我们直接建立连接,并不发送任何数据,所以这里使用-z参数,我们执行一下来看看效果:
nc -4 -u -vz 127.0.0.1 8888
看看下面的输出结果:
Ncat: Version 7.50 ( https://nmap.org/ncat )
Ncat: Connected to 127.0.0.1:8888.
Ncat: UDP packet sent successfully
Ncat: 1 bytes sent, 0 bytes received in 2.02 seconds.
表示UDP连接成功。
同样的,我们可以使用下面的命令来连接到UDP socket:
nc -6 -u -vz ::1 8888
其中::1表示的是本机的ipv6地址.
可以得到下面的结果:
Ncat: Version 7.50 ( https://nmap.org/ncat )
Ncat: Connected to ::1:8888.
Ncat: UDP packet sent successfully
Ncat: 1 bytes sent, 0 bytes received in 2.02 seconds.
表示UDP连接成功。
总结
本文讲解了datagram socket的基本概念,并且使用一些unix的基本命令来构建了udp服务器和客户端,方便大家理解。
本文已收录于 http://www.flydean.com/16-datagram-socket/
最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!
欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!
网络协议之:socket协议详解之Datagram Socket的更多相关文章
- Socket 死连接详解
Socket 死连接详解 当使用 Socket 进行通信时,由于各种不同的因素,都有可能导致死连接停留在服务器端,假如服务端需要处理的连接较多,就有可能造成服务器资源严重浪费,对此,本文将阐述其原理以 ...
- HTTP协议 (六) 状态码详解
HTTP协议 (六) 状态码详解 HTTP状态码,我都是现查现用. 我以前记得几个常用的状态码,比如200,302,304,404, 503. 一般来说我也只需要了解这些常用的状态码就可以了. 如果 ...
- 第8章 应用协议 图解TCP/IP 详解
第8章 应用协议 图解TCP/IP 详解 8.1 应用层协议概要 应用层协议的定义 TCP和IP等下层协议是不依赖上层应用类型.实用性非常广的协议.而应用协议则是为了实现某种应用而设计和创造的协议. ...
- TCP协议粘包问题详解
TCP协议粘包问题详解 前言 在本章节中,我们将探讨TCP协议基于流式传输的最大一个问题,即粘包问题.本章主要介绍TCP粘包的原理与其三种解决粘包的方案.并且还会介绍为什么UDP协议不会产生粘包. 基 ...
- SSL协议之数据加密过程详解
前言 总括: 原文博客地址:SSL协议之数据加密过程详解 知乎专栏&&简书专题:前端进击者(知乎)&&前端进击者(简书) 博主博客地址:Damonare的个人博客 生活 ...
- [转]网络性能评估工具Iperf详解(可测丢包率)
原文链接:安全运维之:网络性能评估工具Iperf详解:http://os.51cto.com/art/201410/454889.htm 参考博文:http://linoxide.com/monito ...
- windows socket函数详解
windows socket函数详解 近期一直用第三方库写网络编程,反倒是遗忘了网络编程最底层的知识.因而产生了整理Winsock函数库的想法.以下知识点均来源于MSDN,本人只做翻译工作.虽然很多前 ...
- Android Socket通信详解
一.Socket通信简介 Android与服务器的通信方式主要有两种,一是Http通信,一是Socket通信.两者的最大差异在于,http连接使用的是“请求—响应方式”,即在请求时建立连接通道,当客 ...
- socket接口详解
1. socket概述 socket是在应用层和传输层之间的一个抽象层,它把TCP/IP层复杂的操作抽象为几个简单的接口供应用层调用已实现进程在网络中通信. socket起源于UNIX,在Unix一切 ...
随机推荐
- 7.Flink实时项目之独立访客开发
1.架构说明 在上6节当中,我们已经完成了从ods层到dwd层的转换,包括日志数据和业务数据,下面我们开始做dwm层的任务. DWM 层主要服务 DWS,因为部分需求直接从 DWD 层到DWS 层中间 ...
- Java 中线程池的 7 种创建方式!
在 Java 语言中,并发编程都是通过创建线程池来实现的,而线程池的创建方式也有很多种,每种线程池的创建方式都对应了不同的使用场景,总体来说线程池的创建可以分为以下两类: 通过 ThreadPoolE ...
- JZ-018-二叉树的镜像
二叉树的镜像 题目描述 操作给定的二叉树,将其变换为源二叉树的镜像. 题目链接: 二叉树的镜像 代码 /** * 标题:二叉树的镜像 * 题目描述 * 操作给定的二叉树,将其变换为源二叉树的镜像. * ...
- Git拉取远程仓库代码并更新本地仓库
1.git pull:获取最新代码到本地,并自动合并到当前分支 //查询当前远程分支 $ git remote -v //直接拉取并合并最新代码 $ git pull origin master [示 ...
- 二级py--day4 数据结构与算法篇
二级py--day4 数据结构与算法篇 1.算法的基本特征:可行性.确定性.有穷性.拥有足够的情报 2.算法的设计要求包括效率与低存储量,既要考虑算法的时间复杂度和空间复杂度 3.算法的优劣:与算法描 ...
- 【python】人脸识别
#coding:utf-8# from __future__ import print_functionfrom time import time #有些步骤要计时,看每个步骤花多长时间import ...
- 从刘维尔方程到Velocity-Verlet算法
技术背景 我们说分子动力学模拟是一个牛顿力学的过程,在使用量子化学的手段或者深度学习的方法或者传统的力场方法,去得到某个时刻某个位置的受力之后,就可以获取下一步的整个系统的状态信息.这个演化的过程所使 ...
- Map 集合
<零基础学Java > Map 集合 在程序中需要存储具有映射关系就需要使用Map集合了. Map集合由Map接口.Map接口的实现类组成. Map 接口 Map接口没有Collectio ...
- Cocoapods插件机制浅析
原文链接 背景 虽然做iOS开发的过程中使用过 Cocoapods, 但是对里面的细节了解其实不算太多,直到这两年做织女项目时,通过对Cocoapods进行Qt支持改造才开始深入了解部分细节,这个过程 ...
- CF587F&CF547E题解
这两道题好像啊 贡献一种使用SAM和ACAM草两道题的方法 下面假装有 \(O(\sum |S|=m)=O(n)\). 你看看,这CF换过多少个出题人啦?换汤不换药啦!其实这两道题是同一个人出的 CF ...