盘点那些进行“网络编程”必须要知道的基础知识!
首先我们来了解一下网络的通信结构。
局域网和因特网
=======
在网络通信中,两台计算机的信息传输可以使用如下的网络线路来表示:
其中服务器是指提供信息的计算机或程序,
客户端是指请求信息的计算机或程序,
两者之间通过网络进行连接并且实现相互的通信,
那么我们所了解的局域网和因特网又有哪些区别的呢?
局域网(LAN)从名字上我们大概就可以了解,它是在一定区域内由一定数量的计算机互相连接而成的网络,它可以是两台,也可以是同一个区域内的上千台计算机构成,当一个局域网的范围继续进行扩大,它也就形成了广域网(WAN)。
而我们所熟知的因特网(Internet)就是由无数个局域网和广域网连接而成的,它是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协定相连,形成逻辑上的单一巨大国际网络。这种将计算机网络互相联接在一起的方法可称作“网络互联”,在这基础上发展出覆盖全世界的全球性互联网络称“互联网”,即是“互相连接一起的网络”。
那么我们接下来就来聊一聊这些网络之间到底具备哪些协议?
网络协议
====
网络协议规定了计算机之间连接的物理、机械、电器等特征,计算机之间的相互寻址规则,数据发送冲突的解决方式,长数据如何分段传送和接收等内容。这就像在世界上不同的国家之间,有不同的法律是一样的,目前在互联网中的网络协议也有很多种,其中最常见的就是 IP 协议和 TCP
以及 UDP 协议。
大灰狼来简单的和大家介绍一下以上这三种协议的基本内容
IP 协议
IP 是 internet?protocol 的简称,是网络协议中的一种,internet 网络采用的协议是 TCP/IP 协议,但是这个协议是绝对不可以小视的,因特网依靠 TCP/IP 协议在全球范围内实现了不同硬件结构、不同操作系统、不同网络系统之间的互联。在 intertet 网络中,存在着数以亿计的主机,每一台主机都用网络为其分配的 intertete 地址来代表自己主机本身,这个地址就是 IP 地址,所以我们也可以说 IP 地址就是某一台计算机的身份证号码。
到目前为止呢,IP 地址用四个字节来表示,也就是 32 位的二进制数来表示,这也是我们通常最常见的 IPV4 地址,为了方便使用呢,我们通常取每个字节的十进制数,并且在每个字节之间用圆点隔开来表示 IP 地址,如最常见的 192.168.1.1,当然肯定还有小伙伴在电脑上也发现有用 16 个字节来表示的 IP 地址,这种 IP 地址是属于 IPV6 地址
并且 TCP/IP 模式是一种层次结构,一共有四层,分别为应用层,传输层互联网层和网络层,他们每一层都有自己所特定的功能,提供特定的服务和对应的访问接口,并且拒一定的独立性,这四层的关系如下图所示
TCP 与 UDP 协议
=========
在 TCP/UDP 协议栈中,有两个高级协议是我们在进行网络应用程序的编写中应该要了解的,即传输控制协议 TCP 和用户数据报协议 UDP。
TCP 协议是一种以固接连线为基础的协议,它提供两台计算机间可靠的数据传输,TCP 可以保证从一端数据送至连接的另一端时,数据能够准确送达,而且抵达的数据的排列顺序和送出时的顺序相同,
因此 TCP 协议适合可靠性要求非常高的场合,打个比方来说:这就像我们双方在打电话,我必须先拨号给对方,等两端确定连接之后,双方才能互相听到对方讲话,也能够知道对方用的是什么内容。
**而 UDP 协议是无连接通信协议,不保证数据的可靠传输,但能够向若干个目标发送数据,或者接收来自若干个园的数据,UDP 以独立发送数据包的方式进行,**这种方式就像快递员送快递给客户,可以寄出很多个包裹给同一个人,每一个包裹都是相互独立的个包裹,送达的顺序并不重要,快递员小哥接收包裹的顺序也不能保证与愁包裹的顺序相同。
因此,UDP 协议适用于一些对数据准确性要求不高,但对数据传输速度和时效性要求非常高的网络,例如我们常见的网络聊天室,在线影片等。
这其中的原因就是因为 TCP 协议在认证上存在额外耗费,可能是传输速度减慢,而 UDP 协议即使有一小部分数据包损失,或者传输顺序有所不同,也不会造成严重的危害该通信。
这也就是为什么常说 TCP 可靠而非安全,UDP 安全而非可靠了。
在这里我们需要注意一点,就是一些防火墙和路由器会设置成不允许就地被数据包传输,因此,若遇到 UDP 连接方面的问题,应该先确定所在的网络是否允许 UDP 协议
端口和套接字
======
刚听到这两个名词的时候,小伙伴可能不是特别了解,在这里打个通俗一点的比方,套接字就好比电源插座,将原本复杂的客户端服务器端通过这个插座连接在一起。
一般而言,对于一台计算机来说,只有单一的连接到网络的物理连接,所有的数据都通过此连接对内、对外送达特定的计算机。这就是端口的定义,网络程序设计中的端口(Port)并非真实存在的,他只不过是一个假想的连接装置,端口被规定为在一个 0~65535 之间的整数。例如 HTTP 服务一般使用 80 端口,FTP 服务使用 21 端口,所以当一台计算机提供了多种不同的服务时,客户机就会通过不同的端口来确定连接到服务器上的哪项服务上面。
其实在端口上也有一定的讲究,如 0~1023 之间的端口,一般用于一些知名的网络服务和应用,而用户的普通网络应用程序应该使用 1024 以上的端口数,这样做的目的也是避免端口号与另一个应用或系统服务所用的端口所造成冲突。
端口的使用如下图所示
在网络程序中的套接字(Socket)表示用于将应用程序与端口连接起来,同样套接字也是一个假想的连接装置,在 JAVA 编程中将套接字可以抽象为类,我们在进行程序开发的时候,只需要创建 Socket 类对象,就可以使用套接字了。
可以用下面这个图来简单的表示套接字:
评论