Java Socket的api可能很多人会用,但是Java Socket的参数可能很多人都不知道用来干嘛的,甚至都不知道有这些参数。

backlog

用于ServerSocket,配置ServerSocket的最大客户端等待队列。等待队列的意思,先看下面代码

按 Ctrl+C 复制代码

public class Main { public static void main(String[] args) throws Exception { int port = 8999; int backlog = 2; ServerSocket serverSocket = new ServerSocket(port, backlog); Socket clientSock = serverSocket.accept(); System.out.println("revcive from " + clientSock.getPort()); while (true) { byte buf[] = new byte[1024]; int len = clientSock.getInputStream().read(buf); System.out.println(new String(buf, 0, len)); } } }

按 Ctrl+C 复制代码

这段测试代码在第一次处理一个客户端时,就不会处理第二个客户端,所以除了第一个客户端,其他客户端就是等待队列了。所以这个服务器最多可以同时连接3个客户端,其中2个等待队列。大家可以telnet localhost 8999测试下。

这个参数设置为-1表示无限制,默认是50个最大等待队列,如果设置无限制,那么你要小心了,如果你服务器无法处理那么多连接,那么当很多客户端连到你的服务器时,每一个TCP连接都会占用服务器的内存,最后会让服务器崩溃的。

另外,就算你设置了backlog为10,如果你的代码中是一直Socket clientSock = serverSocket.accept(),假设我们的机器最多可以同时处理100个请求,总共有100个线程在运行,然后你把在100个线程的线程池处理clientSock,不能处理的clientSock就排队,最后clientSock越来越多,也意味着TCP连接越来越多,也意味着我们的服务器的内存使用越来越高(客户端连接进程,肯定会发送数据过来,数据会保存到服务器端的TCP接收缓存区),最后服务器就宕机了。所以如果你不能处理那么多请求,请不要循环无限制地调用serverSocket.accept(),否则backlog也无法生效。如果真的请求过多,只会让你的服务器宕机(相信很多人都是这么写,要注意点)

TcpNoDelay

禁用纳格算法,将数据立即发送出去。纳格算法是以减少封包传送量来增进TCP/IP网络的效能,当我们调用下面代码,如:

按 Ctrl+C 复制代码

Socket socket = new Socket(); socket.connect(new InetSocketAddress(host, 8000)); InputStream in = socket.getInputStream(); OutputStream out = socket.getOutputStream(); String head = "hello "; String body = "world\r\n"; out.write(head.getBytes()); out.write(body.getBytes());

按 Ctrl+C 复制代码

我们发送了hello,当hello没有收到ack确认(TCP是可靠连接,发送的每一个数据都要收到对方的一个ack确认,否则就要重发)的时候,根据纳格算法,world不会立马发送,会等待,要么等到ack确认(最多等100ms对方会发过来的),要么等到TCP缓冲区内容>=MSS,很明显这里没有机会,我们写了world后再也没有写数据了,所以只能等到hello的ack我们才会发送world,除非我们禁用纳格算法,数据就会立即发送了。

纳格算法参考:http://zh.wikipedia.org/wiki/%E7%B4%8D%E6%A0%BC%E7%AE%97%E6%B3%95

另外有一篇讲解纳格算法和delay ack的文章(挺不错的):http://blog.csdn.net/frankggyy/article/details/6624401

SoLinger

当我们调用socket.close()返回时,socket已经write的数据未必已经发送到对方了,例如

按 Ctrl+C 复制代码

Socket socket = new Socket(); socket.connect(new InetSocketAddress(host, 8000)); InputStream in = socket.getInputStream(); OutputStream out = socket.getOutputStream(); String head = "hello "; String body = "world\r\n"; out.write(head.getBytes()); out.write(body.getBytes()); socket.close();

按 Ctrl+C 复制代码

这里调用了socket.close()返回时,hello和world未必已经成功发送到对方了,如果我们设置了linger而不小于0,如:

按 Ctrl+C 复制代码

bool on = true; int linger = 100; .... socket.setSoLinger(boolean on, int linger) ...... socket.close();

按 Ctrl+C 复制代码

那么close会等到发送的数据已经确认了才返回。但是如果对方宕机,超时,那么会根据linger设定的时间返回。

UrgentData和OOBInline

TCP的紧急指针,一般都不建议使用,而且不同的TCP/IP实现,也不同,一般说如果你有紧急数据宁愿再建立一个新的TCP/IP连接发送数据,让对方紧急处理。

所以这两个参数,你们可以忽略吧,想知道更多的,自己查下资料。

SoTimeout

设置socket调用InputStream读数据的超时时间,以毫秒为单位,如果超过这个时候,会抛出java.net.SocketTimeoutException。

KeepAlive

keepalive不是说TCP的常连接,当我们作为服务端,一个客户端连接上来,如果设置了keeplive为true,当对方没有发送任何数据过来,超过一个时间(看系统内核参数配置),那么我们这边会发送一个ack探测包发到对方,探测双方的TCP/IP连接是否有效(对方可能断点,断网),在Linux好像这个时间是75秒。如果不设置,那么客户端宕机时,服务器永远也不知道客户端宕机了,仍然保存这个失效的连接。

SendBufferSize和ReceiveBufferSize

TCP发送缓存区和接收缓存区,默认是8192,一般情况下足够了,而且就算你增加了发送缓存区,对方没有增加它对应的接收缓冲,那么在TCP三握手时,最后确定的最大发送窗口还是双方最小的那个缓冲区,就算你无视,发了更多的数据,那么多出来的数据也会被丢弃。除非双方都协商好。

以上的参数都是比较重要的Java Socket参数了,其他就不另外说明了。

Java Socket重要参数讲解相关推荐

  1. Java socket 重要参数

    Java Socket的api可能很多人会用,但是Java Socket的参数可能很多人都不知道用来干嘛的,甚至都不知道有这些参数. backlog 用于ServerSocket,配置ServerSo ...

  2. Java Socket 参数详解

    Java socket参数选项: TCP_NODELAY:  表示立即发送数据 SO_RESUSEADDR:  表示是否允许重用socket所绑定的本地地址 SO_TIMEOUT :  表示接收数据时 ...

  3. java毕业设计——基于Java+Socket的视频会议系统设计与实现(毕业论文+程序源码)——视频会议系统

    基于Java+Socket的视频会议系统设计与实现(毕业论文+程序源码) 大家好,今天给大家介绍基于Java+Socket的视频会议系统设计与实现,文章末尾附有本毕业设计的论文和源码下载地址哦.需要下 ...

  4. java 内存例子_简单的例子 关于Java内存管理的讲解

    我想做的是,逐行读取文件,然后用该行的电影名去获取电影信息.因为源文件较大,readlines()不能完全读取所有电影名,所以我们逐行读取. 就这段代码,我想要在位置二处使用base64,然后结果呢? ...

  5. Java Socket发送与接收HTTP消息简单实现

    在上次Java Socket现实简单的HTTP服务我 们实现了简单的HTTP服务,它可以用来模拟HTTP服务,用它可以截获HTTP请求的原始码流,让我们很清楚的了解到我们向服务发的HTTP消息的结 构 ...

  6. java http服务端例子_简单的用 Java Socket 编写的 HTTP 服务器应用

    /*** SimpleHttpServer.java*/importjava.io.*;importjava.net.*;importjava.util.StringTokenizer;/*** 一个 ...

  7. JAVA socket编程 Datagram套接字 UDP协议(转)

      查看文章     JAVA socket编程 Datagram套接字 UDP协议 2009-05-13 09:35 1 UDP套接字 数据报(Datagram)是网络层数据单元在介质上传输信息的一 ...

  8. Java Socket编程----通信是这样炼成的

    转载自 Java Socket编程----通信是这样炼成的 Java最初是作为网络编程语言出现的,其对网络提供了高度的支持,使得客户端和服务器的沟通变成了现实,而在网络编程中,使用最多的就是Socke ...

  9. linux java socket编程_深入学习socket网络编程,以java语言为例

    了解java的socket编程与Linux Socket API之间的关系 一.java的网络编程 1.socket原理 socket通信就是通过IP和端口号将两台主机建立连接,提供通信.主机A的应用 ...

最新文章

  1. 基于 DDD 设计并实现模块化单体应用
  2. 测试 Zoundry Raven
  3. Android多线程分析之二:Thread的实现
  4. 编号003099--ORACLE DBA-SH/WH
  5. python iloc函数_Python 基本操作- 数据选取loc、iloc、ix函数
  6. python计算方位角_实例讲解:用python 计算方位角(根据两点的坐标计算)记得收藏哦...
  7. java 状态模式 同步_JAVA设计模式之状态模式
  8. [Xcode 实际操作]七、文件与数据-(17)解析JSON文档
  9. linux的进程/线程/协程系列5:协程的发展复兴与实现现状
  10. 每日一句20191104
  11. shiro自定义session过期时间
  12. 利用matlab实现卷积实验报告,matlab卷积实验报告(共8篇).doc
  13. 手披云雾开鸿蒙,描写泰山的诗句不是整首诗、注明作者
  14. STM32F103X hal RTThread rtc驱动支持日期保存
  15. Failure recovering jobs: Lock wait timeout exceeded; try restarting transaction
  16. 用python画靶盘九个_““python程序设计:画一个射箭运动所用的箭靶.从小到大分别黄,红,蓝,黑,白色的同...
  17. MySQL数据库的锁 --- 六种分类 - 14种锁详细介绍
  18. 【前端篇】火狐浏览器打开调试器,报“Error: Incorrect contents fetched, please reload.”
  19. 短距离无线通讯-蓝牙
  20. 广远社团队给大家分享这些年经历的网赚时代

热门文章

  1. FFmpeg图像处理深度应用
  2. 《视频直播技术详解》系列之七:现代播放器原理
  3. 认证鉴权与API权限控制在微服务架构中的设计与实现
  4. C++编程常见问题—error: passing 'const std::map]' discards qualifiers或pass-by-reference-to-const-map导致的“d
  5. Unable to create '/media/sf_nginx/H2_20151103/H2/.git/index.lock': File exists.
  6. sourcetree帮助文档
  7. ARM 虚拟化技术简介
  8. Nexus for linux安装
  9. leetcode 239. Sliding Window Maximum | 239. 滑动窗口最大值(单调栈,窗口内最大最小值更新结构)
  10. 爬虫实战:CentOS安装JDK,部署Java程序,利用screen使其保持在前台运行