JavaEE|网络编程基础与Socket套接字
文章目录
- 一、为什么需要网络编程
- 二、什么是网络编程
- 三、网络编程中的基本概念
- 1.发送端和接收端
- 2.请求和响应
- 3.客户端和服务端
- 4.常见的客户端服务端模型
- 四、Socket套接字概念及分类
- 1.概念
- 2.分类
- 1)流套接字:使用传输层TCP协议
- 2)数据报套接字:使用传输层UDP协议
- 3)原始套接字
- 五、Java数据报套接字通信模型
- 六、Java流套接字通信模型
- 七、Socket编程注意事项
一、为什么需要网络编程
在网络上可以获取的各种数据资源就叫做网络资源。
我们可以通过上网,查询到我们想要的资源,而这些丰富的网络资源就是通过网络编程来进行传输的。
与本地打开视频资源类似,只是视频文件资源的来源是网络。相比本地资源,网络提供了更为丰富的网络资源,比如视频资源、图片资源、文本资源等。
二、什么是网络编程
网络编程就是网络上的主机通过不同的进程以编程的方式实现网络通信/网络数据传输。
这就意味,网络编程可以是,不同主机上的不同进程进行通信,也可以是同一台主机上的不同进程进行通信。
简言之,网络编程就是不同进程通过网络进行通信。
进程A:编程来获取资源
进程B:编程来发送/提供资源
这里边的核心就是学习Socket Api。是和传输层密切相关的。传输层提供了两个最核心的协议——udp\TCp,他对应的也提供了两种风格,udp和tcp(第三种风格的是unix领域的套接字,现在早就没人用了)
Socket英译就是插座,这里我们的术语翻成了套接字(有一定历史背景,但是我不知道)
网络编程本质上就是操作网卡。
三、网络编程中的基本概念
1.发送端和接收端
一次网络数据传输时:
发送端:数据的发送方进程,称为发送端。对应的发送端主机就是网络通信中的源主机。
接收端:数据的接收方进程,称为接收端。对应的接收端主机即网络通信中的目的主机。
收发端:发送端和接收端两端,也简称为收发端。
注意:收发端是相对的,或者说是由网络数据传输流向决定的,主动的就是发送端,被动的就是接收端。
2.请求和响应
一般,获取一个网络资源,涉及到两次网络数据传输。第一次就是请求,第二次就是响应。
3.客户端和服务端
在上述网络通信过程中,主机A的进程是获取服务/资源的一方,也称为客户端,主机B的进程是提供服务/资源的一方,也称为服务器。
4.常见的客户端服务端模型
最常见的场景,客户端是指给用户使用的程序,服务端是提供用户服务的程序:
- 客户端先发送请求到服务端
- 服务端根据请求数据,执行相应的业务处理
- 服务端返回响应:发送业务处理结果
- 客户端根据响应数据,展示处理结果(展示获取的资源,或提示保存资源的处理结果)
四、Socket套接字概念及分类
1.概念
Socket套接字就是由系统提供用于网络通信的技术。
Socket套接字是基于TCP/IP协议进行网络通信的基本操作单元。
网络编程就是基于Socket套接字的网络程序开发。
2.分类
套接字是传输层专有的吗?它跟整套TCP/IP协议栈又有什么关系??
1)流套接字:使用传输层TCP协议
TCP:即Transmission Control Protocol,传输控制协议。是传输层协议的一种。
TCP的特点:有连接、可靠传输、面向字节流、全双工
对于这里的有连接:
需要连接建立了才能通信。
对于这里的可靠传输:
发送方能知道自己的消息是不是发过去了还是丢了。
对于这里的面向字节流:传输数据是基于IO流。
流式数据的特征就是在IO流没有关闭的情况下,是无边界的数据、可多次发送也可分开多次接受。和文件io/读写类似。
对于这里的全双工:
全双工:一个通信通道可以双向传输(A→B且B→A)。指A→B的同时B→A,是瞬时同步的。
半双工:一个通信通道只允许单向传输(A→B或B→A)。
为什么tcp和udp都是全双工的?
一根网线其实有8根线,有的负责上传有的负责下载,相当于8车道。
不只是这里,整个计网大部分情况还是全双工
宿舍的网不改成半双工用不了:
与路由器和交换机配置有关
关于网速
与传输的数据量(类比马路上跑的车辆)和带宽(类比马路的宽度)有关系。
网络转发设备的转发能力是有上限的,他们转发的数据不只是我们自己的数据。一旦其中一个设备有问题,就会慢。
上传比下载慢:是运营商的问题(上行带宽),下行带宽(一般都快于上行带宽)
百度网盘是属于软件限速,和带宽没有关系。
idm是Internet download manager,好像是能提高下载速度,一般是浏览器插件。
2)数据报套接字:使用传输层UDP协议
UDP:即User Datagram Protocol(用户数据报协议)。一种传输层协议。
UDP特点:无连接、不可靠传输、面向数据包、全双工
对于这里面向数据包:
可以理解为数据包为基本的收发单位。一个数据报可能是好几个字节。数据量大了,就多弄几个数据包,但是即使是数据量少了,比如一个字节,也不能说不包裹直接发送,必须封装成数据包进行发送。
3)原始套接字
原始套接字用于自定义传输层协议,用于读写内核没有处理的IP协议数据。 是在unix角度来讲的,现在很少用。。
仅作了解即可。
五、Java数据报套接字通信模型
对于UDP协议来讲,每次通信都不需要进行连接,并且一次发送全部数据,一次接收全部数据。
????Java中使用UDP协议进行通信,主要基于DatagramSocket类来创建数据报套接字,基于DatagramPacket类对象来作为发送/接受UDP数据报。
六、Java流套接字通信模型
七、Socket编程注意事项
-
客户端和服务器:开发时,经常时基于一个主机开启两个进程作为客户端和服务器;应用时,一般是不同主机的分别作为客户端和服务器
-
目的ip和目的端口号:两者分别表示了一次数据发送过程中要发送数据的终点主机(因为实际上一次数据传输过程中一般需要经过很多路由器等网络设备)和终点进程。
-
Socket编程我们是使用流套接字和数据报套接字,基于传输层的TCP或UDP协议,但应用层协议,也需要考虑,这块我们在后续来说明如何设计应用层协议
-
端口号和socket对象是多对一的
-
端口被占用:即进程B试图绑定一个已经被另一个进程A绑定的端口号。此时会报这样的错误信息。
解决办法:检查B进程试图绑定的端口号==>查看此端口号被哪个进程占用
·如果占用端口进程A不需要运行,就可以关闭A后,再启动需要绑定该端口的进程B
·如果需要运行,就修改进程B的绑定端口换成其他没有使用的端口。
-
在cmd输入 netstat -ano | findstr 端口号 ,则可以显示对应进程的pid。如以下命令显示了8888进程的pid
-
在任务管理器(ctrl+alt+delete)中,通过pid查找进程
-
相关文章:

JavaEE|网络编程基础与Socket套接字
文章目录一、为什么需要网络编程二、什么是网络编程三、网络编程中的基本概念1.发送端和接收端2.请求和响应3.客户端和服务端4.常见的客户端服务端模型四、Socket套接字概念及分类1.概念2.分类1)流套接字:使用传输层TCP协议2)数据报套接字&am…...
【SpringBoot】基础协议及邮件配置整合
一、名词概念解释 什么是POP3、SMTP和IMAP? 简单的说:POP3和IMAP是用来从服务器上下载邮件的。SMTP适用于发送或中转信件时找到下一个目的地。所以我们发送邮件应该使用SMTP协议。 POP3、SMTP和IMAP协议介绍 IMAP和POP3有什么区别?什么是免费…...

pytorch配置—什么是CUDA,什么是CUDNN、在配置pytorch虚拟环境中遇到的问题、在安装gpu—pytorch中遇到的问题
1.什么是CUDA,什么是CUDNN (1)什么是CUDA CUDA(ComputeUnified Device Architecture),是显卡厂商NVIDIA推出的运算平台。 CUDA是一种由NVIDIA推出的通用并行计算架构,该架构使GPU能够解决复杂的计算问题。 ࿰…...

jfr引起的一次jvm异常记录
业务生产启动时,20个节点有1-2个节点因为jvm问题出现启动失败,k8s自动重启后正常。在测试环境2个节点下偶现 排查思路: 先拿到hs_err_pid的jvm错误文件找到当前线程和内部错误信息 hs_err_pid 文件分析 当前线程:lettuce的线程…...

Java智慧校园平台源码:SaaS模式智慧校园运营云平台源码
校班务管理:评价管理: 1.web端/教师端小程序编辑点评 多元化评价,捕捉学生闪光点全方位评价,自定义评价类型、 评价信息实时推送至家长、AI智能点评 班级报表一键导出,智能评测学生在校表现,老师、家长实…...

【yolov5】将标注好的数据集进行划分(附完整可运行python代码)
问题描述 准备使用yolov5训练自己的模型,自己将下载的开源数据集按照自己的要求重新标注了一下,然后现在对其进行划分。 问题分析 划分数据集主要的步骤就是,首先要将数据集打乱顺序,然后按照一定的比例将其分为训练集…...
es-05分词器
文章目录分词器1 normalization:文档规范化,提高召回率2 字符过滤器(character filter):分词之前的预处理,过滤无用字符3 令牌过滤器(token filter):停用词、时态转换、大小写转换、…...

已解决zipfile.BadZipFile: File is not a zip file
已解决Python openpyxl 读取Excel文件,抛出异常zipfile.BadZipFile: File is not a zip file的正确解决,亲测有效!!! 文章目录报错问题报错翻译报错原因解决方法联系博主免费帮忙解决报错报错问题 一个小伙伴遇到问题跑…...

Mybatis源码分析:Mybatis的数据存储对象
前言:SQLSession是对JDBC的封装 一:SQLSession和JDBC的对照说明 左边是我们的客户端程序,右边是我们的MySQL数据仓,或者叫MySQL实例 Mybatis是对JDBC的封装,将JDBC封装成了一个核心的SQLSession对象 JDBC当中的核心对…...

学习 Python 之 Pygame 开发坦克大战(二)
学习 Python 之 Pygame 开发坦克大战(二)坦克大战的需求开始编写坦克大战1. 搭建主类框架2. 获取窗口中的事件3. 创建基类4. 初始化我方坦克类5. 完善我方坦克的移动5. 完善我方坦克的显示6. 在主类中加入我方坦克并完成坦克移动7. 初始化子弹类8. 完善子…...

短视频时代是靠什么赚钱的,介绍常见的5种方式,简单明了
目前,短视频越来越火热,大家都知道做短视频可以赚钱,那么究竟是靠什么赚钱的,又有几个人知道呢?短视频创业有个人、有团队,怎么实现团队的生存和发展。 常见的几种变现方式有: 1、平台分成 各…...
关于CentOS维护的几条简单命令
1、检查/etc/passwd这个文件里面有没有异常用户名2、通过命令top查看是否有异常进程,按M键对进程进行排序3、通过命令netstat -lnpt,查看是否有异常端口号4、通过命令ll -a /proc/PID,查看异常进程执行文件所在位置5、通过命令kill -9 PID&am…...
PoW 、PoS , DPoS 算法
PoW 、PoS , DPoS 算法 在区块链领域,多采用 PoW 工作量证明算法、PoS 权益证明算法,以及 DPoS 代理权 益证明算法,以上三种是业界主流的共识算法,这些算法与经典分布式一致性算法不同的是 融入了经济学博弈的概念。 …...

SpringCloud(PS)远程调用--Feign
远程调用RestTemplate远程调用RestTemplate方式调用存在的问题Http客户端Feign实现步骤自定义配置Feign优化Feign性能优化——连接池配置最佳实践RestTemplate远程调用 Bean // LoadBalancedpublic RestTemplate restTemplate(){return new RestTemplate();}Autowiredprivat…...
2023年全国最新二级建造师精选真题及答案1
百分百题库提供二级建造师考试试题、二建考试预测题、二级建造师考试真题、二建证考试题库等,提供在线做题刷题,在线模拟考试,助你考试轻松过关。 11.当事人未依照法律、行政法规规定办理租赁合同登记备案手续的,租赁合同…...

HydroD 实用教程(四)水动力模型
目 录一、前言二、Hydro Properties2.1 Compartment Properties2.2 Rudder and Thruster2.3 Wind Properties三、Hydro Structure3.1 Load Cross Sections四、Loading Conditions4.1 Mass Model4.2 Second Order Surface Model4.3 Wadam Offbody Points4.4 Additional Matrices…...

vue项目第七天
项目中模块操做业务使用ajax(需要使用接口认证)修改封装的findData发送ajax请求管理员列表内部搜索业务复用之前的findData 方法即可实现整个查询业务。实现退出业务在下拉菜单上添加事件以及属性。用户退出登录,二次登录系统菜单可能不存在的…...

拂晓·微信机器人
前言 本项目是基于千寻微信框架进行的功能开发,采用SpringBoot青云客机器人进行开发。 千寻初衷是想开源一个框架的写法,并不是为了用来运营,因此功能不全,所以使用和适配前请查看是否与自己需求匹配。 因此本文主要通过千寻客…...
React:Hooks工作机制
Hooks规则 React Hooks的使用,有两个规则: Hooks只能在函数组件中使用;不能在条件、循环或者嵌套函数中使用hook。确保每一次渲染中都按照同样的顺序被调用,import React, {useState } from "react"; export default function PersonalInfoComponent() {const […...

基于深度神经网络的3D模型合成【Transformer vs. CNN】
本文介绍用于3D模型合成的transformer网络与深度卷积网络。 推荐:使用 NSDT场景设计器 快速搭建 3D场景。 1、概述 从单一视角合成 3D 数据是一种基本的人类视觉功能,这对计算机视觉算法来说极具挑战性,这是一个共识。 但在 3D 传感器&#…...

23-Oracle 23 ai 区块链表(Blockchain Table)
小伙伴有没有在金融强合规的领域中遇见,必须要保持数据不可变,管理员都无法修改和留痕的要求。比如医疗的电子病历中,影像检查检验结果不可篡改行的,药品追溯过程中数据只可插入无法删除的特性需求;登录日志、修改日志…...

1.3 VSCode安装与环境配置
进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件,然后打开终端,进入下载文件夹,键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...

在WSL2的Ubuntu镜像中安装Docker
Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...
力扣-35.搜索插入位置
题目描述 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 class Solution {public int searchInsert(int[] nums, …...

算法笔记2
1.字符串拼接最好用StringBuilder,不用String 2.创建List<>类型的数组并创建内存 List arr[] new ArrayList[26]; Arrays.setAll(arr, i -> new ArrayList<>()); 3.去掉首尾空格...
python报错No module named ‘tensorflow.keras‘
是由于不同版本的tensorflow下的keras所在的路径不同,结合所安装的tensorflow的目录结构修改from语句即可。 原语句: from tensorflow.keras.layers import Conv1D, MaxPooling1D, LSTM, Dense 修改后: from tensorflow.python.keras.lay…...
PAN/FPN
import torch import torch.nn as nn import torch.nn.functional as F import mathclass LowResQueryHighResKVAttention(nn.Module):"""方案 1: 低分辨率特征 (Query) 查询高分辨率特征 (Key, Value).输出分辨率与低分辨率输入相同。"""def __…...

面向无人机海岸带生态系统监测的语义分割基准数据集
描述:海岸带生态系统的监测是维护生态平衡和可持续发展的重要任务。语义分割技术在遥感影像中的应用为海岸带生态系统的精准监测提供了有效手段。然而,目前该领域仍面临一个挑战,即缺乏公开的专门面向海岸带生态系统的语义分割基准数据集。受…...
深度学习之模型压缩三驾马车:模型剪枝、模型量化、知识蒸馏
一、引言 在深度学习中,我们训练出的神经网络往往非常庞大(比如像 ResNet、YOLOv8、Vision Transformer),虽然精度很高,但“太重”了,运行起来很慢,占用内存大,不适合部署到手机、摄…...

Android写一个捕获全局异常的工具类
项目开发和实际运行过程中难免会遇到异常发生,系统提供了一个可以捕获全局异常的工具Uncaughtexceptionhandler,它是Thread的子类(就是package java.lang;里线程的Thread)。本文将利用它将设备信息、报错信息以及错误的发生时间都…...