草庐IT

Java网络编程 - 网络编程介绍 - 网络通信三要素

学全栈的灌汤包 2024-07-06 原文

文章目录

网络编程

网络编程介绍

什么是网络编程?

网络编程可以让程序与网络上的其他设备中的程序进行数据交互。

网络编程基本模式:

常见的通信模式有如下2种形式:Client-Server(CS: 客户端与服务器模式) 、 Browser/Server(BS: 浏览器与服务器模式)

Client-Server(CS)模式

Browser/Server(BS)模式

网络通信三要素

实现网络编程关键的三要素:

IP地址:设备在网络中的地址,是唯一的标识。

端口:应用程序在设备中唯一的标识。

协议: 数据在网络中传输的规则,常见的协议有UDP协议和TCP协议。

要素一: IP地址

IP地址基本介绍

IP(Internet Protocol):全称”互联网协议地址”,是分配给上网设备的唯一标志。

常见的IP分类为:IPv4和IPv6

IPV4

IPV4: 32位(四个字节)

IPV4每个字节表示一个整数, 每个整数之间使用逗号隔开

IPV6

IPv6:128位(16个字节),由于IPV4不够用, 所以出现了IPV6, IPV6号称可以为地球每一粒沙子编号。

IPv6分成8个整数,每个整数用四个十六进制位表示, 数之间用冒号(:)分开。

IP地址形式:

公网地址、和私有地址(局域网使用)。

192.168. 开头的就是常见的局域网地址,范围即为192.168.0.0–192.168.255.255,专门为组织机构内部使用。

IP常用命令:

ipconfig:查看本机IP地址

ping IP地址:检查网络是否连通

特殊的IP地址:

本机IP: 127.0.0.1或者localhost:称为回送地址也可称本地回环地址,只会寻找当前所在本机。

IP地址的操作类

IP地址操作类InetAddress的使用

此类表示Internet协议(IP)地址。

InetAddress API如下:

名称说明
static InetAddress getLocalHost()返回本主机的地址对象
static InetAddress getByName(String host)得到指定主机的IP地址对象,参数是域名或者IP地址
getHostName()获取此IP地址的主机名
getHostAddress()返回IP地址字符串
isReachable(int timeout)在指定毫秒内连通该IP地址对应的主机,连通返回true

前两个静态方法用于获取地址对象

public static void main(String[] args) throws Exception {
    // 返回本机地址对象
    InetAddress ip1 = InetAddress.getLocalHost();
    System.out.println(ip1); // chenyqdeMacBook-Pro.local/127.0.0.1

    // 根据域名或IP地址返回地址对象
    InetAddress ip2 = InetAddress.getByName("www.baidu.com");
    System.out.println(ip2); // www.baidu.com/183.232.231.172
}

获取地址对象后, 可以根据地址对象获取主机名、地址字符串、是否连通等等。

public static void main(String[] args) throws Exception {
    // 返回本机地址对象
    InetAddress ip1 = InetAddress.getLocalHost();
    System.out.println(ip1); // chenyqdeMacBook-Pro.local/127.0.0.1

    // 主机名
    System.out.println(ip1.getHostName()); // chenyqdeMacBook-Pro.local
    // 主机地址
    System.out.println(ip1.getHostAddress()); // 127.0.0.1
    // 三秒内是否连通
    System.out.println(ip1.isReachable(3000)); // true
}

要素二: 端口号

端口号:

端口号:标识正在计算机设备上运行的进程(程序),被规定为一个 16 位的二进制,范围是 0~65535。

例如我们将IP地址看成是酒店名称, 那么端口号就是房间号; 有IP地址有端口号我们才可以准确的找到运行的程序

端口类型:

周知端口:0~1023,被预先定义的知名应用占用(如:HTTP占用 80,FTP占用21)

注册端口:1024~49151, 分配给用户进程或某些应用程序。(如:Tomcat占 用8080,MySQL占用3306)

动态端口:49152到65535,之所以称为动态端口,是因为它一般不固定分配某种进程,而是动态分配。

注意:我们自己开发的程序选择注册端口,且一个设备中不能出现两个程序的端口号一样,否则出错

要素三: 协议

通信协议:

连接和通信数据的规则被称为网络通信协议

网络通信协议有两套参考模型:

OSI参考模型:世界互联协议标准,全球通信规范,由于此模型过于理想化,未能在因特网上进行广泛推广。

TCP/IP参考模型(或TCP/IP协议):事实上的国际标准。

OSI参考模型TCP/IP参考模型各层对应面向操作
应用层应用层HTTP、FTP、DNS、SMTP…应用程序需要关注的:浏览器,邮箱。程序员一般在这一层开发
表示层
会话层
传输层传输层TCP、UDP…选择使用的TCP , UDP协议
网络层网络层IP、ICMP…封装源和目标IP,进行路径选择
数据链路层数据链路层+物理物理寻址、比特流…物理设备中传输
物理层

传输层的两个常见的协议:

TCP(Transmission Control Protocol) :传输控制协议

UDP(User Datagram Protocol):用户数据报协议

TCP协议

TCP协议特点:

使用TCP协议,必须双方先建立连接,它是一种面向连接的可靠通信协议。

传输前,采用“三次握手”方式建立连接,所以是可靠的 。

在连接中可进行大数据量的传输 。

连接、发送数据都需要确认,且传输完毕后,还需释放已建立的连接,通信效率较低。

TCP协议通信场景:

对信息安全要求较高的场景,例如:文件下载、金融等数据通信

TCP会进行三次握手确立连接:

第一次握手: 客户端发送网络包,服务端收到了。

  • 服务器端得出结论: 客户端发送能力正常, 服务端接收能力正常

第二次握手: 服务端发包,客户端收到了。

  • 客户端得出结论: 服务端的发送能力和接收能力正常, 客户端的发送能力和接收能力正常;
  • 但是此时服务端并不知道客户端的接收能力是否正常, 所以就会进行第三次握手

第三次握手: 客户端发包,服务端收到了。

  • 服务端得出结论: 客户端的接收、发送能力正常,服务器自己的发送、接收能力也正常。

TCP会进行四次挥手断开连接:

第一次挥手: 客户端向服务端发送一个数据包

  • 告诉服务端:我要跟你断开连接了,不会再给你发数据了;

第二次挥手: 服务端收到数据包后, 向客户端发送一个数据包

  • 服务端告诉客户端:我知道你要断开了,但是我还有数据没有发送完,等发送完了所有的数据就进行第三次挥手

第三次挥手: 服务端向客户端发送一个数据包

  • 这是服务端告诉客户端:我的数据也发送完了,不再给你发数据了

第四次挥手: 客户端收到数据包之后,一样发送一个 ACK 报文作为应答; 并经过一段时间发送确认包

  • 至此断开连接, 四次挥手结束

UDP协议

UDP协议:

UDP是一种无连接、不可靠传输的协议。

将数据源IP、目的地IP和端口封装成数据包,不需要建立连接

每个数据包的大小限制在64KB内

发送不管对方是否准备好,接收方收到也不确认,故是不可靠的

可以广播发送 ,发送数据结束时无需释放资源,开销小,速度快。

UDP协议通信场景:

语言通话, 视频通话

有关Java网络编程 - 网络编程介绍 - 网络通信三要素的更多相关文章

  1. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  2. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  3. ruby - 寻找通过阅读代码确定编程语言的ruby gem? - 2

    几个月前,我读了一篇关于ruby​​gem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:

  4. ruby - 用 Ruby 编写一个简单的网络服务器 - 2

    我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b

  5. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  6. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

  7. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

  8. Unity 热更新技术 | (三) Lua语言基本介绍及下载安装 - 2

    ?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------

  9. Observability:从零开始创建 Java 微服务并监控它 (二) - 2

    这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/

  10. 【Java 面试合集】HashMap中为什么引入红黑树,而不是AVL树呢 - 2

    HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候

随机推荐