文章目录
什么是网络编程?
网络编程可以让程序与网络上的其他设备中的程序进行数据交互。
网络编程基本模式:
常见的通信模式有如下2种形式:Client-Server(CS: 客户端与服务器模式) 、 Browser/Server(BS: 浏览器与服务器模式)
Client-Server(CS)模式

Browser/Server(BS)模式

实现网络编程关键的三要素:
IP地址:设备在网络中的地址,是唯一的标识。
端口:应用程序在设备中唯一的标识。
协议: 数据在网络中传输的规则,常见的协议有UDP协议和TCP协议。

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地址操作类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会进行四次挥手断开连接:
第一次挥手: 客户端向服务端发送一个数据包
- 告诉服务端:我要跟你断开连接了,不会再给你发数据了;
第二次挥手: 服务端收到数据包后, 向客户端发送一个数据包
- 服务端告诉客户端:我知道你要断开了,但是我还有数据没有发送完,等发送完了所有的数据就进行第三次挥手
第三次挥手: 服务端向客户端发送一个数据包
- 这是服务端告诉客户端:我的数据也发送完了,不再给你发数据了
第四次挥手: 客户端收到数据包之后,一样发送一个 ACK 报文作为应答; 并经过一段时间发送确认包
- 至此断开连接, 四次挥手结束

UDP协议:
UDP是一种无连接、不可靠传输的协议。
将数据源IP、目的地IP和端口封装成数据包,不需要建立连接
每个数据包的大小限制在64KB内
发送不管对方是否准备好,接收方收到也不确认,故是不可靠的
可以广播发送 ,发送数据结束时无需释放资源,开销小,速度快。
UDP协议通信场景:
语言通话, 视频通话
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
几个月前,我读了一篇关于rubygem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:
我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b
我正在尝试使用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
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------
这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/
HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候