当前位置: 首页 > news >正文

Socket编程【个人简单】

介绍

Socket是计算机网络中的一种通信端点,通过它应用程序可以在网络上发送和接收数据。它可以是基于TCP(传输控制协议)的流套接字,也可以是基于UDP(用户数据报协议)的数据报套接字。

TCP、UDP、HTTP和WebSocket都是用于网络通信的协议,但它们在用途、特性和实现方式上有所不同。以下是对这些协议的详细介绍和区别:

1. TCP(Transmission Control Protocol)

特点:

  • 连接导向: TCP是面向连接的协议,通信双方必须先建立连接(三次握手)才能进行数据传输。
  • 可靠传输: TCP提供可靠的传输服务,通过确认机制、重传机制和流量控制确保数据包按序、无误地到达。
  • 有序传输: 数据包按序到达,保持数据的顺序一致性。
  • 适用场景: 适用于对数据传输可靠性和顺序性要求高的应用,如HTTP、FTP、SMTP等。

示例:

import socket# TCP 客户端
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client_socket.connect(('localhost', 8080))
client_socket.sendall(b'Hello, Server')
response = client_socket.recv(1024)
print('Received:', response)
client_socket.close()

2. UDP(User Datagram Protocol)

特点:

  • 无连接: UDP是无连接的协议,不需要建立连接,直接发送数据包。
  • 不可靠传输: UDP不保证数据包的可靠性和顺序性,数据包可能丢失、重复或乱序。
  • 低延迟: 由于没有连接建立和维护的开销,UDP传输延迟较低。
  • 适用场景: 适用于对实时性要求高但不需要保证可靠传输的应用,如视频流、VoIP、在线游戏等。

示例:

import socket# UDP 客户端
client_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
client_socket.sendto(b'Hello, Server', ('localhost', 8080))
response, server = client_socket.recvfrom(1024)
print('Received:', response)
client_socket.close()

3. HTTP(Hypertext Transfer Protocol)

特点:

  • 应用层协议: HTTP是应用层协议,基于TCP实现,主要用于在Web浏览器和服务器之间传输超文本数据(HTML)。
  • 请求-响应模式: 客户端发送请求,服务器返回响应。
  • 无状态: 每次请求都是独立的,服务器不保留客户端状态。可以通过Cookies、Sessions等机制实现状态保持。
  • 适用场景: 主要用于Web应用,传输网页内容和相关资源。

示例:

import requests# HTTP 客户端
response = requests.get('http://www.example.com')
print('Response:', response.text)

4. WebSocket

特点:

  • 双向通信: WebSocket提供了全双工通信通道,客户端和服务器可以相互发送消息。
  • 基于TCP: WebSocket基于TCP连接,并通过HTTP协议进行初始握手,然后升级为WebSocket协议。
  • 低延迟: 保持长连接,减少了频繁建立连接的开销,适合实时应用。
  • 适用场景: 适用于需要实时双向通信的应用,如实时聊天、在线协作、实时数据更新等。

示例:

import websocketdef on_message(ws, message):print('Received:', message)def on_open(ws):ws.send('Hello, Server')# WebSocket 客户端
ws = websocket.WebSocketApp('ws://localhost:8080', on_message=on_message)
ws.on_open = on_open
ws.run_forever()

总结

  • TCPUDP是传输层协议,负责数据包的传输。TCP提供可靠、有序的数据传输,而UDP提供低延迟、无连接的数据传输。
  • HTTPWebSocket是应用层协议,基于TCP实现。HTTP是无状态的请求-响应协议,主要用于Web内容传输;WebSocket提供持久的双向通信通道,适用于实时应用。

当你访问一个HTTP服务器时,实际通信过程是先通过TCP协议建立连接,然后通过HTTP协议进行数据传输。HTTP请求和响应都是通过已经建立的TCP连接传输的。因此,可以认为HTTP协议运行在TCP协议之上。

Netty

Netty是一个高性能的、异步事件驱动的网络应用框架,旨在简化和抽象化Socket编程的复杂性。Netty的主要作用包括:

封装底层操作:Netty封装了底层的Socket API,使得开发者不必直接处理复杂的Socket编程任务。
提供高层次的API:Netty提供了一组更高级的API,用于处理网络通信,使得开发者可以专注于业务逻辑而非底层细节。
异步事件驱动模型:Netty采用异步事件驱动模型,通过事件和回调机制处理网络事件,提高了性能和扩展性。

http://www.lryc.cn/news/383058.html

相关文章:

  • java入门 grpc测试案例
  • 【操作系统】信号处理与阻塞函数|时序竞态问题
  • go语言day4 引入第三方依赖 整型和字符串转换 进制间转换 指针类型 浮点数类型 字符串类型
  • IOS Swift 从入门到精通:闭包第二部分,高级闭包
  • 爬虫超详细介绍
  • 双向长短期记忆神经网络BiLSTM
  • python基础篇(4):range语句
  • 基于STM32的简易计算器proteus仿真设计(仿真+程序+设计报告+讲解视频)
  • 小程序onLoad 和 onShow
  • 抖音直播违规规定有哪些?(直播违禁词汇总表)
  • 安卓 jetpack compose
  • JavaWeb系列十九: jQuery的DOM操作 上
  • JavaWeb系列十一: Web 开发会话技术(Cookie, Session)
  • 【激光雷达使用记录】—— 如何在ubuntu中利用ros自带的rviz工具实时可视化雷达点云的数据
  • 运行项目报错(java: 无效的目标发行版: 17)项目jdk版本不兼容,修改Java编译器配置
  • 一道session文件包含题
  • vuex数据持久化
  • MySQL之复制(十)
  • Spring MVC数据绑定和响应——简单数据绑定(一)默认类型数据绑定
  • 短视频平台自动化插件编写需要用到的源代码分享!
  • 安卓下载以来总是要添加maven下载地址,放在哪?
  • springboot多数据源应用,A服务依赖于B服务jar包,A服务和B服务业务数据分别入自己的库如何做?
  • 20240626 每日AI必读资讯
  • C语言经典算法题第一题
  • 计算预卷积特征
  • Python 入门 —— 描述器
  • 测试驱动开发TDD
  • [论文笔记]Mixture-of-Agents Enhances Large Language Model Capabilities
  • Redis 7.x 系列【6】数据类型之字符串(String)
  • 指针(一)