微信公众号:冯文议(ID:fwy-world) HTTP请求,在日常开发中,还是比较常见的,今天给大家分享HttpUtils如何使用。...阅读本文,你将收获: 简单总结HTTP请求常用配置; JavaLib中HttpUtils如何使用; 如何封装HTTP请求工具类。...第一部分:简单总结HTTP请求常用配置 大家好,在 Java 开发中,经常遇到需要调用第三方提供的接口服务,常见的形式是 HTTP + JSON,下面,就对 http 请求常见的设置,做一个说明 http...提供多种请求方式,以满足我们日常需要,先按请求方式来做说明: GET POST PUT PATCH DELETE 在 RESTful API 开发中,我们可以根据这些请求方式设计我们的API接口。...我是小冯,一名Java程序员,专注于程序设计和开发,如果你在开发上遇到问题,欢迎一起交流。
IO多路复用主要应用场景:①服务器需要同时处理多个处于监听或连接状态的套接字。②服务器需要同时处理多种网络协议的套接字。...支持IO多路复用的系统调用有select、pselect、poll、epoll。在linux网络编程中,很长时间使用select,但最终选择epoll。...1.3 Java的I/O演进 在JDK 1.4推出Java NIO之前,java都是使用同步阻塞模式(BIO),而这一时期C和C++语言的大型应用都直接使用操作系统提供的异步IO或AIO能力。...②提供AIO功能,支持基于文件的异步IO操作和针对网络套接字的异步操作。 ③完善通道功能,包括对配置和多播数据报的支持等。...其中异步套接字通道是真正的异步非阻塞IO,对应于Unix网络编程中的事件驱动IO(AIO)。它不需要通过多路复用器Selector对注册的通道进行轮询操作即可实现异步读写,从而简化了NIO的编程模型。
所谓长连接,指在一个TCP连接上可以连续发送多个数据包,在TCP连接保持期间,如果没有数据包发送,需要双方发检测包以维持此连接(心跳包),一般需要自己做在线维持。...长连接通常就是: 连接→数据传输→保持连接(心跳)→数据传输→保持连接(心跳)→……→关闭连接; 心跳包就是在客户端和服务端间定时通知对方自己状态的一个自己定义的命令字,按照一定的时间间隔发送,类似于心跳...网络中的接收和发送数据都是使用Socket进行实现。但是如果此套接字已经断开(比如一方断网了),那发送数据和接收数据的时候就一定会有问题。**可是如何判断这个套接字是否还可以使用呢?...HTTP是无状态的协议,针对其无状态特性,在实际应用中又需要有状态的形式,因此一般会通过session/cookie技术来解决此问题。...某些场合使用http不使用socket的原因是socket一旦连接上了,就一直保持连接,就会造成阻塞IO,与此相对的的,还有非阻塞IO。
NIO (Non-blocking/New I/O): NIO 是一种同步非阻塞的 I/O 模型,在 Java 1.4 中引入了 NIO 框架,对应 java.nio 包,提供了 Channel , Selector...在 Java 7 中引入了 NIO 的改进版 NIO 2,它是异步非阻塞的 IO 模型。...对于 NIO 来说,我们的业务线程是在 IO 操作准备好时,得到通知,接着就由这个线程自行进行 IO 操作,IO 操作本身是同步的。 阻塞式I/O模型:默认情况下,所有套接字都是阻塞的。怎么理解?...对于一个套接字上的输入操作,第一步通常涉及等待数据从网络中到达。当所有等待分组到达时,它被复制到内核中的某个缓冲区。第二步就是把数据从内核缓冲区复制到应用程序缓冲区。...非阻塞式I/O:以下这句话很重要:进程把一个套接字设置成非阻塞是在通知内核,当所请求的I/O操作非得把本进程投入睡眠才能完成时,不要把进程投入睡眠,而是返回一个错误。
recvfrom Linux系统提供给用户用于接收网络IO的系统接口。从套接字上接收一个消息,可同时应用于面向连接和无连接的套接字。...Linux使用SIGIO信号来实现IO异步通知机制。 1.2 同步&异步 同步和异步是针对应用程序和内核交互而言的,也可理解为被被调用者(操作系统)的角度来说。...同步是用户进程触发IO操作并等待或轮询的去查看是否就绪,而异步是指用户进程触发IO操作以后便开始做自己的事情,而当IO操作已经完成的时候会得到IO完成的通知,需要CPU支持 1.3 阻塞&非阻塞 阻塞和非阻塞是针对于进程在访问数据的时候...select函数会不断地轮询自己所负责的文件描述符/套接字的到达状态,当某个套接字就绪时,就对这个套接字进行处理。select负责轮询等待,recvfrom负责拷贝。...七、Java中的BIO,NIO,AIO 操作系统的IO模型是底层基石,Java对于IO的操作其实就是进一步的封装。适配一些系统调用方法,让我们玩地更爽。
但是在使用UDP协议传送数据时,由于UDP的面向无连接性,不能保证数据的完整性,因此在 传输重要数据时不建议使用UDP协议。 4....在TCP连接中必须要明确客户端与服务器端,由客户端向服务端发出连接请求,每次连接的创建都需要经过“三次握手” 三次握手:TCP协议中,在发送数据的准备阶段,客户端与服务器之间的三次交互,以保证连接的可靠...相关方法 方法名 说明 void send(DatagramPacket p) 发送数据报包 void close() 关闭数据报套接字 void receive(DatagramPacket p) 从此套接字接受数据报包...Java中的TCP通信 Java对基于TCP协议的的网络提供了良好的封装,使用Socket对象来代表两端的通信端口,并通过Socket产生IO流来进行网络通信。...示例代码 import java.io.IOException; import java.io.InputStream; import java.net.ServerSocket; import java.net.Socket
recvfrom Linux系统提供给用户用于接收网络IO的系统接口。从套接字上接收一个消息,可同时应用于面向连接和无连接的套接字。...Linux使用SIGIO信号来实现IO异步通知机制。 1.2 同步&异步 同步和异步是针对应用程序和内核交互而言的,也可理解为被被调用者(操作系统)的角度来说。...相比于阻塞IO模型,多路复用只是多了一个select/poll/epoll函数。select函数会不断地轮询自己所负责的文件描述符/套接字的到达状态,当某个套接字就绪时,就对这个套接字进行处理。...完成后内核将数据放到指定的缓冲区,通知应用程序来取。 七、Java中的BIO,NIO,AIO 操作系统的IO模型是底层基石,Java对于IO的操作其实就是进一步的封装。...一个有效请求对应一个线程,客户端的IO请求都是OS先完成了再通知服务器应用去启动线程进行处理。 使用场景 从效率上来说,可以简单理解为阻塞IO<非阻塞IO<多路复用IO<信号驱动IO<异步IO。
还是要从 BIO 说起 传统的阻塞式通信流程 早期的 Java 网络相关的 API(java.net包) 使用 Socket(套接字)进行网络通信,不过只支持阻塞函数使用。...初识 NIO NIO 是一种同步非阻塞的 I/O 模型,在 Java 1.4 中引入了 NIO 框架,对应 java.nio 包,提供了 Channel , Selector,Buffer 等抽象。...NIO 提供了与传统 BIO 模型中的 Socket 和 ServerSocket 相对应的 SocketChannel 和 ServerSocketChannel 两种不同的套接字通道实现,两种通道都支持阻塞和非阻塞两种模式...Selector(选择器,也可以理解为多路复用器)是 NIO(非阻塞 IO)实现的关键。它使用了事件通知相关的 API 来实现选择已经就绪也就是能够进行 I/O 相关的操作的任务的能力。...真正的无连接数据包套接字支持。 比直接使用 Java 核心 API 有更高的吞吐量、更低的延迟、更低的资源消耗和更少的内存复制。 安全性不错,有完整的 SSL/TLS 以及 StartTLS 支持。
但是,如果服务器有更多数据需要推送到客户端,在页面加载完成后是无法实现直接将数据从服务器发送给客户端的。实时数据无法被“推送”给客户端。 为了解决这个问题,有人提出了很多解决方案。...可以使用WebSocket类来实例化一个新的套接字(socket),这需要传入服务器的端地址,在这个例子中是ws://example.com: ? 然后我们需要给这个套接字添加事件监听 : ?...然而更多的应用场景是,要想针对不同的用户群发送不同的数据源,你需要根据不同类型的数据源有针对性地给用户推送更新。 我们来看一个聊天室的场景: 用户在聊天室中发送了一个新消息。...查找聊天室中所有和这个Chat记录有关的用户,我们需要给这些用户发送更新通知。 用一条更新来描述发生了什么事情(创建Chat记录),将这个更新推送给相关的用户。...要想将通知发送给这个特定用户,服务器只需向同一个信道发布消息即可。 你可能很想知道发布/订阅模式在信息传输过程(WebSocket或Comet)中是怎样工作的。
2、非阻塞I/O 我们可以使用 fcntl(fd, F_SETFL, flag | O_NONBLOCK); 将套接字标志变成非阻塞,调用recv,如果设备暂时没有数据可读就返回-1,同时置errno为...4、信号驱动I/O 先注册SIGIO信号的处理函数,进程继续执行其他操作,当数据到来时会发送SIGIO信号给进程,然后可以在信号处理函数中调用recv进行数据的复制,然后recv返回进行数据处理。...5、异步I/O aio_read 函数也会提供一个buf,系统调用进入内核,如果没有数据则立即返回,进程继续执行其他操作,所以叫异步I/O,当数据到来时内核自动复制数据,然后推送给用户空间,通过在aio_read...只有异步I/O模型(AIO)是符合异步I/O操作的含义的,即在1数据准备完成、2由内核空间拷贝回缓冲区后 通知进程,在等待通知的这段时间里可以干别的事。...注意当select阻塞返回后,此时调用accept 接收连接是不会阻塞的,直接返回已连接套接字,可以认为是select 提前阻塞了。
当需通过 TCP 发送数据时,在应用程序中实际上执行了将数据从用户空间拷贝至内核空间,再由内核进行实际的发送动作;而从 TCP 读取数据时则反过来,等待内核将数据准备好,再从内核空间拷贝至用户空间,应用数据才能处理...非阻塞式IO 允许将一个套接字设置为非阻塞。当设置为非阻塞时,是在通知内核:如果一个操作需要将当前的调用线程阻塞住才能完成时,不采用阻塞的方式,而是返回一个错误信息。...但是IO复用的优点在于,其select调用,可以同时关注多个套接字,在规模上提升了处理能力。 IO复用的模型支持一样也是在JDK1.4中的 NIO 包提供了支持。...信号驱动IO ? 与非阻塞IO类似,其在数据等待阶段并不阻塞,但是原理不同。信号驱动IO是在套接字上注册了一个信号调用方法。...而且采用通知的方式也避免了轮训带来的损耗。 这种模型在Java中并没有对应的实现。 异步IO 异步IO的实现一般是通过系统调用,向内核注册了一个套接字的读取动作。
, 用以支持两个类的子类的选项; (1) 常量字段解析 IP_MULTICAST_IF : 设置一个用于发送多播包的传出接口(eth0, eth1, wlan0 等); -- 使用环境 : 可以在具有多个网络接口的主机上使用...; -- 套接字本地地址不可更改 : 套接字在创建的时候绑定本地地址, 因此不可更改; -- 套接字默认地址 : INADDR_ANY 表示 多穴主机 (有多个IP地址的主机) 的任何地址; SO_REUSEADDR..., 2小时内 没有通过 Socket 传输数据, TCP 会将 keepalive 探头 发送到同为体中; -- 作用 : 检测同位体主机是否崩溃; -- 适用情况 : 仅对 TCP 套接字有效; --...同位体通过期待的ACK响应 : 不通知应用程序, 在另外2小时 没有数据传输之后, TCP 继续发送一个探头; -- 同位体通过 RST 响应 : 通知本地 TCP 同位体主机 崩溃, 关闭socket...; SO_SNDBUF (send): 设置 网络 输出 的 用到的基础的IO缓冲区大小提示; -- 设置方法使用 : 设置通过套接字 发送数据 时使用的缓冲区的大小; -- 获取方法使用 : 获取套接字设置的
的工作模式谈起 我们在使用Redis的时候,通常是多个客户端连接Redis服务器,然后各自发送命令请求(例如Get、Set)到Redis服务器,最后Redis处理这些请求返回结果。...I/O多路复用技术 现代的UNIX操作系统提供了select/poll/kqueue/epoll这样的系统调用,这些系统调用的功能是:你告知我一批套接字,当这些套接字的可读或可写事件发生时,我通知你这些事件信息...当如下任一情况发生时,会产生套接字的可写事件: 该套接字的发送缓冲区中的可用空间字节数大于等于套接字发送缓冲区低水位标记的大小; 该套接字的写半部关闭,继续写会产生SIGPIPE信号; 非阻塞模式下,connect...此外,在UNIX系统上,一切皆文件。套接字也不例外,每一个套接字都有对应的fd(即文件描述符)。我们简单看看这几个系统调用的原型。...Java中的NIO与Netty 谈到Reactor模式,在这里奉上Java大神Doug Lea的Scalable IO in Java,里面提到了Java网络编程中的经典模式、NIO以及Reactor,
上图中进程在从调用recvfrom开始到它返回的整段时间内被阻塞,recvfrom成功返回后,应用进程开始数据处理 (2)非阻塞式I/O 进程把一个套接字设置成非阻塞是在通知内核:当所请求的I/...这种模式使用中不是很普遍。...(3)IO复用模型 有了I/O复用,我们就可以调用select或poll,阻塞在这两个系统调用中的某一个之上,而不是阻塞真正的I/O系统之上 我们阻塞于select调用,等待数据报套接字变为可读...另外使用select的优势在于我们可以等待多个描述符就绪 ? (4)信号驱动IO模型 可以用信号让内核在描述符就绪时发送SIGIO信号通知我们 ?...I/O 模式下,内核在操作可以被操作的时候通知给我们的应用程序发送SIGIO 消息。
具体实现中,Proactor模式通常使用异步IO操作来处理IO事件,并使用事件通知机制(如Completion Port)来通知应用程序IO操作已经完成。...我们可以使用Reactor模式来实现:创建一个监听套接字,等待客户端的连接请求。...使用select/poll/epoll等函数来等待IO事件发生(即监听套接字的读事件),当有新的连接请求时,创建一个新的连接套接字,并将其加入到一个连接池中。...使用select/poll/epoll等函数来等待IO事件发生(即连接套接字的读事件),当有数据到达时,调用相应的处理函数来处理数据。当连接被关闭时,从连接池中删除连接套接字。...使用水平触发时,当客户端发送了一条数据后,操作系统会不停地向服务器程序通知该事件,直到服务器程序将该数据从缓冲区中读取出来。
然后使用CreateProcess函数创建一个新的CMD进程,并将标准输入、输出和错误输出重定向到套接字的句柄上。这样,客户端可以通过网络连接到这个套接字,发送CMD命令并获取命令输出结果。...WSASocket 函数用于创建重叠IO套接字,重叠 I/O(Overlapped I/O)是一种异步 I/O(Asynchronous I/O)机制,它可以在执行 I/O操作时同时进行其他的操作或处理...要使用重叠 I/O 操作机制,应用程序需要更改套接字的 I/O 模式。在传统的 I/O 操作模式中,应用程序通过同步的方式向套接字发送或接收数据,然后等待操作完成。...而在重叠 I/O 操作模式中,应用程序使用非阻塞的方式进行数据读取和发送操作,不会阻塞线程和进程的执行,同时可以用事件通知机制来处理 I/O 操作的完成。...同时,在 CMD 进程退出后,服务器会等待一段时间然后关闭套接字并释放资源。
以阻塞套接字为参数调用该函数发送数据。如果套接字缓冲区没有可用空间,线程会一直睡眠,直到有空间。 3.接受连接:accept()和WSAAcept()函数。...使用阻塞模式的套接字,开发网络程序比较简单,容易实现。当希望能够立即发送和接收数据,且处理的套接字数量比较少的情况下,使用阻塞模式来开发网络程序比较合适。...使用非阻塞模式套接字,需要编写更多的代码,以便在每个Windows Sockets API函数调用中,对收到的WSAEWOULDBLOCK错误进行处理。因此,非阻塞套接字便显得有些难于使用。...但是,非阻塞套接字在控制建立的多个连接,在数据的收发量不均,时间不定时,明显具有优势。这种套接字在使用上存在一定难度,但只要排除了这些困难,它在功能上还是非常强大的。...实际处理这个调用的部件在完成后,通过状态、通知和回调来通知调用者的输入输出操作。 同步IO引起进程阻塞,直至IO操作完成。 异步IO不会引起进程阻塞。 IO复用是先通过select调用阻塞。
然后使用CreateProcess函数创建一个新的CMD进程,并将标准输入、输出和错误输出重定向到套接字的句柄上。这样,客户端可以通过网络连接到这个套接字,发送CMD命令并获取命令输出结果。...WSASocket 函数用于创建重叠IO套接字,重叠 I/O(Overlapped I/O)是一种异步 I/O(Asynchronous I/O)机制,它可以在执行 I/O操作时同时进行其他的操作或处理...启用重叠 I/O 操作模式后,应用程序就可以使用异步 I/O 操作进行数据的读取、发送、接收等操作,同时进行其他的计算和处理操作。要使用重叠 I/O 操作机制,应用程序需要更改套接字的 I/O 模式。...在传统的 I/O 操作模式中,应用程序通过同步的方式向套接字发送或接收数据,然后等待操作完成。...而在重叠 I/O 操作模式中,应用程序使用非阻塞的方式进行数据读取和发送操作,不会阻塞线程和进程的执行,同时可以用事件通知机制来处理 I/O 操作的完成。
) DatagramSocket代表数据包套接字,当然这个类也有许多的说明和详细的方法使用。...在某些实现中,将 DatagramSocket 绑定到一个更加具体的地址时广播包也可以被接收 这是我们需要主要去了解的信息。我们首先要了解的是这个类具有发送数据和接收数据的功能。...int getTrafficClass() 获取交通类或类型的服务在IP数据报头的DatagramSocket发送的数据包。 boolean isBound() 返回套接字的绑定状态。...Socket(Proxy proxy) 创建一个未连接的套接字并指定代理类型(如果有),该代理不管其他设置如何都应被使用。...void sendUrgentData(int data) 在套接字上发送一个紧急数据字节。
本篇内容包括:Socket 套接字的简介、Socket 套接字的分类、Java 中的 Socket 即 java.net.ServerSocket、java.net.Socket 的使用,以及Java...Socket 的原意是“插座”,在计算机通信领域,Socket 被翻译为“套接字”,它是计算机之间进行通信的一种约定或一种方式。...这类套接字中,传输数据之前必须在两个应用进程之间建立一条通信连接, 这就确保了参与通信的两个应甩进程都是活动并具响应的e当连接建立之卮应用进程只要通过套接字向 TCP 层发送数据流,而另一个应用进程便可以接收到相应的数据流...该服务并不能保证数据传输的可靠性,数据有可能在传输过程中丢失或出现数据重复,且无法保证顺序地接收到数据。数据报套接字使用UDP进行数据的传输。...因此,其主要是在编写自定义底层协议的应用程序时使用,例如各种不同的 TCP/IP 实用程序 三、Java 中的 Socket Java 中对 Socket 的使用是基于两个类 java.net.ServerSocket
领取专属 10元无门槛券
手把手带您无忧上云