网络的学习 2 Socket

进程是人在系统中的代表,只要把数据给进程,人就相当于拿到了数据

数据传输到主机不是目的,而是手段,到达主机内部,再交给主机内的进程才是目的

上网的行为

  1. 从远端服务器,获取数据 ->

-> ---> 进程(内存) -> 网卡 -> 网络

  1. 本地数据,上传到远端服务器 -> 之间都是IO关系,只能做收取信息和发送信息

通信的本质:就是两个不同的主机的进程在进行数据交换

网络通信,本质就是进程间通信!让不同的进程看到同一份资源!网络!


端口号

端口号,可以用来标识系统中唯一的一个网络进程

端口号 VS pid:OS为每个运行中的进程分配的唯一整数标识

为什么有端口号还要有pid?

  1. 每个进程都有pid但不是每个进程都有端口号

2.从技术角度,pid是可行的,但是,pid是一个系统概念,pid变化了。网络也跟着变,是解耦

一个进程可以有多个端口号,一个端口号只能被一个进程占用

源端口号和目的端口号

描述"数据是谁的,要发给谁"

socket

IP:全网内唯一的一个主机

port:该主机内唯一的一个网络进程

IP + Port = 全网内唯一的一个网络进程

套接字 socket = ip + port

网络通信的本质:全网内唯二的两个进程,再进行进程间通信

{源ip,srcPort,目的ip,dstPort}标识互联网中唯二的两个进程

传输层的典型代表

TCP,UDP协议

都是传输层协议

TCP协议是有连接的 eg:打电话 UDP协议 无连接 eg:对讲机

面向字节流:像"水管输水" 连续可靠 面向数据报:像快递包裹,独立快速

可靠传输 不可靠传输

而是否可靠要把它当成中性词,是特点,可靠即做更多工作,复杂占用的资源多,不可靠则很简单

大小端

TCP/IP协议规定,网络数据流应该采用大端字节序,即低地址高字节

凡是发送到网络中的数据,必须是大端

先发出的数据是低地址,后发出的是高地址

如果当前发送主机是小端就要先将数据转成大端

拿着客户端向服务器发送请求

套接字编程接口

api

socket 创建socket 文件描述符

bind 绑定端口号

listen 监听

accept 接收请求

connect 建立连接

sockaddr 结构

网络通信的本质其实是进程间通信

systemV -- 本地进程间通信

posix 标准 -- 网络通信,进程通信 也能进行本地通信

网络套接字:跨设备通信,依赖ip和端口号,适用于网络场景

本地套接字:本地进程通信,依赖文件路径,速度更快,更安全(无需经过网络协议栈)

socket 会有很多的种类,来满足不同的应用场景

socket未来的接口,会有不同的通信接口规范

socket的设计者只想提供一种通信接口

自行区分是网络通信还是本地通信

本质就是继承和多态

实际上就是基类,用C语言形成的一套继承体系

8位填充清零就可以

IPv6 AF_INET6

相关推荐
im_AMBER几秒前
React 05
开发语言·前端·javascript·笔记·学习·react.js·前端框架
clear sky .19 分钟前
ETH, Lwip,Tcp之间关系
服务器·网络·tcp/ip
我叫汪枫39 分钟前
《从点击到响应:HTTP 请求是如何传出去的》
网络·网络协议·http
南方的狮子先生2 小时前
【数据结构】(C++数据结构)查找算法与排序算法详解
数据结构·c++·学习·算法·排序算法·1024程序员节
此生只爱蛋2 小时前
【Linux】网络基础概念
网络
key_Go2 小时前
06.OpenStack网络管理
网络·openstack
asdfsdgss3 小时前
多项目共享资源:Ruby 定时任务基于 Whenever 的动态扩缩容
java·网络·ruby
py有趣4 小时前
LeetCode算法学习之移动0
学习·算法·leetcode
calwen4 小时前
Windows 通过 SSH 跳板机安全连接内网开发服务器
服务器
百锦再4 小时前
Go与Python在AI大模型开发中的深度对比分析
java·开发语言·人工智能·python·学习·golang·maven