网络程序通信的流程

news2024/11/25 18:40:55

网络程序通信的流程:

1.通过ip地址找到网络中的设备

2.通过端口号找到对应进程的端口

3.传输数据时还需要使用传输协议(TCP),保证数据的可靠性

4.socket完成进程之间网络数据的传输

ip地址的介绍

  IP地址是互联网协议地址(Internet Protocol Address)的缩写,用于在IP网络中唯一标识一个设备。它通常由四个数字组成,每个数字在0-255之间,用点号分隔。IP地址分为IPv4和IPv6两种版本,其中IPv4是目前广泛使用的版本。

端口和端口号的介绍

  端口是计算机上用于接收和发送数据的接口。每个端口都有一个唯一的端口号,用于标识和区分不同的服务或应用程序。常见的端口号有HTTP(80)、HTTPS(443)、FTP(21)等。

tcp的介绍

1.通过ip地址找到网络中的设备

2.通过端口号找到对应进程的端口

3.传输数据时还需要使用传输协议(TCP),保证数据的可靠性

4.socket完成进程之间网络数据的传输

socket的介绍

  进程之间通信的一个工具。Socket是网络编程中用于进程间通信的一个抽象层,它提供了对TCP/IP、UDP等网络通信协议的封装。通过Socket,应用程序可以发送和接收数据,实现不同计算机之间的通信。

tcp网络应用程序的开发流程

tcp客户端程序开发

  • 创建Socket对象。

  • 连接到服务器(指定IP地址和端口号)。

  • 发送和接收数据。

  • 关闭连接。

import socket

if __name__ == '__main__':
    # 1.创建tcp客户端套接字
    # socket.AF_INET:ipv4
    # socket.SOCK_STREAM:tcp传输协议
    tcp_client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

    # 2.和服务端套接字建立连接
    tcp_client_socket.connect(('192.168.198.1', 8080))

    # 3.发送数据到服务端
    send_content = "请输入要传输的数据"
    send_data = send_content.encode('utf-8')
    tcp_client_socket.send(send_data)

    # 4.接收服务端的数据
    recv_data = tcp_client_socket.recv(1024)
    print(recv_data.decode('utf-8'))
    # 5.关闭套接字
    tcp_client_socket.close()

tcp服务端的程序开发

  • 建Socket对象。

  • 绑定IP地址和端口号。

  • 开始监听连接请求。

  • 接受客户端连接。

  • 发送和接收数据。

  • 关闭连接。

import socket

if __name__ == "__main__":
    # 1.创建TCP服务端套接字
    tcp_server_socket  = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    # 2.绑定端口号
    # ip地址一般不用指定,表示本机的任何一个ip即可
    tcp_server_socket.bind(('', 8080))
    # 3.设置监听
    # 128表示最大等待建立连接的个数
    tcp_server_socket.listen(128)
    # 4.等待接收客户端的连接请求
    # 注意点:每次当客户端和服务器端建立连接成功都会返回一个新的套接字
    # tcp_server_socket只负责等待接收客户端建立连接成功,收发消息不使用该套接字
    new_client, ip_port = tcp_server_socket.accept()
    print("客户端的ip地址个端口号为:", ip_port)
    # 5.接收数据
    # 收发信息都使用返回的这个新的套接字
    recv_data = new_client.recv(1024)
    # 对二进制数据进行解码变成字符串
    recv_content = recv_data.decode("gbk")
    print("接受的数据为:", recv_content)
    # 6.发送数据到客户端
    send_content = "问题正在处理中..."
    # 对字符串进行编码
    send_data = send_content.encode("gbk")
    new_client.send(send_data)
    # 关闭服务与客户端的套接字,表示和客户端终止通信
    new_client.close()
    # 7.关闭服务端套接字,表示服务端以后不在等待接收客户端的连接请求
    tcp_server_socket.close()

设置端口号复用

  在某些情况下,服务器程序可能需要在程序重启时立即使用之前绑定的端口号。这时可以设置端口号复用(SO_REUSEADDR)选项,允许服务器程序立即重新绑定到该端口。

import socket

if __name__ == "__main__":
    # 1.创建TCP服务端套接字
    tcp_server_socket  = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    # 设置端口号复用,表示意思:服务端程序退出端口号立即释放
    # 1.SOL_SOCKET:表示当前套接字
    # 2.SO_REUSEADDER:表示复用端口号的选项
    tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR,True)
    # 2.绑定端口号
    # ip地址一般不用指定,表示本机的任何一个ip即可
    tcp_server_socket.bind(('', 8080))
    # 3.设置监听
    # 128表示最大等待建立连接的个数
    tcp_server_socket.listen(128)
    # 4.等待接收客户端的连接请求
    # 注意点:每次当客户端和服务器端建立连接成功都会返回一个新的套接字
    # tcp_server_socket只负责等待接收客户端建立连接成功,收发消息不使用该套接字
    new_client, ip_port = tcp_server_socket.accept()
    # 代码执行到此,说明客户端和服务器建立连接成功
    print("客户端的ip地址个端口号为:", ip_port)
    # 5.接收客户端对的数据
    # 收发信息都使用返回的这个新的套接字
    recv_data = new_client.recv(1024)
    print("接收的数据长度为:",len(recv_data))
    # 对二进制数据进行解码变成字符串
    recv_content = recv_data.decode("gbk")
    print("接受的数据为:", recv_content)

    send_content = "问题正在处理中..."
    # 对字符串进行编码
    send_data = send_content.encode("gbk")
    # 6.发送数据到客户端
    new_client.send(send_data)
    # 关闭服务与客户端的套接字,表示和客户端终止通信
    new_client.close()
    # 7.关闭服务端套接字,表示服务端以后不在等待接收客户端的连接请求
    tcp_server_socket.close()

tcp网络应用程序的注意点

  • 并发处理:服务端需要能够同时处理多个客户端的连接请求和数据传输。

  • 异常处理:在网络编程中,网络故障、连接中断等异常情况时有发生,需要编写健壮的异常处理代码。

  • 资源管理:合理管理Socket资源、内存资源等,避免资源泄漏和性能问题

  • 当 TCP 客户端程序想要和 TCP 服务端程序进行通信的时候必须要先建立连接

  • TCP 客户端程序一般不需要绑定端口号,因为客户端是主动发起建立连接的。

  • TCP 服务端程序必须绑定端口号,否则客户端找不到这个 TCP 服务端程序。

  • listen 后的套接字是被动套接字,只负责接收新的客户端的连接请求,不能收发消息。

  • 当TCP 客户端程序和 TCP 服务端程序连接成功后,TCP 服务器端程序会产生一个新的套接字,收发客户端消息使用该套接字。

  • 关闭 accept 返回的套接字意味着和这个客户端已经通信完毕。

  • 关闭 listen 后的套接字意味着服务端的套接字关闭了,会导致新的客户端不能连接服务端,但是之前已经接成功的客户端还能正常通信。

  • 当客户端的套接字调用 close后,服务器端的recv 会解阻塞,返回的数据长度为0,服务端可以通过8.返回数据的长度来判断客户端是否已经下线,反之服务端关闭套接字,客户端的recv 也会解阻塞,返回的数据长度也为0。

多人版tcp服务端程序

  多人版TCP服务端程序需要能够同时处理多个客户端的连接请求和数据传输。这通常需要使用多线程或多进程技术来实现并发处理。每个客户端连接都由一个单独的线程或进程负责处理,从而实现多人同时在线通信。

import socket

if __name__ == "__main__":
    # 1.创建TCP服务端套接字
    tcp_server_socket  = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    # 设置端口号复用,表示意思:服务端程序退出端口号立即释放
    # 1.SOL_SOCKET:表示当前套接字
    # 2.SO_REUSEADDER:表示复用端口号的选项
    tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR,True)
    # 2.绑定端口号
    # ip地址一般不用指定,表示本机的任何一个ip即可
    tcp_server_socket.bind(('', 8080))
    # 3.设置监听
    # 128表示最大等待建立连接的个数
    tcp_server_socket.listen(128)
    # 4.等待接收客户端的连接请求
    # 注意点:每次当客户端和服务器端建立连接成功都会返回一个新的套接字
    # tcp_server_socket只负责等待接收客户端建立连接成功,收发消息不使用该套接字
    # 循环等待接收客户端的连接请求
    while True:
        new_client, ip_port = tcp_server_socket.accept()
        # 代码执行到此,说明客户端和服务器建立连接成功
        print("客户端的ip地址个端口号为:", ip_port)
        # 5.接收客户端对的数据
        # 收发信息都使用返回的这个新的套接字
        recv_data = new_client.recv(1024)
        print("接收的数据长度为:",len(recv_data))
        # 对二进制数据进行解码变成字符串
        recv_content = recv_data.decode("gbk")
        print("接受的数据为:", recv_content)

        send_content = "问题正在处理中..."
        # 对字符串进行编码
        send_data = send_content.encode("gbk")
        # 6.发送数据到客户端
        new_client.send(send_data)
        # 关闭服务与客户端的套接字,表示和客户端终止通信
        new_client.close()
    # 7.关闭服务端套接字,表示服务端以后不在等待接收客户端的连接请求
    tcp_server_socket.close()

socket之send和recv的原理剖析

  • send:在TCP中,send函数用于向连接的对端发送数据。数据被封装在TCP报文中,通过网络传输到对端。send函数在数据被成功写入发送缓冲区后返回,但并不意味着数据已经被对端接收。

  • recv:recv函数用于从连接的对端接收数据。它从接收缓冲区中读取数据,并返回给调用者。如果接收缓冲区中没有数据

文章转载自:JJJhr

原文链接:https://www.cnblogs.com/JJJHaoran/p/18255027

体验地址:引迈 - JNPF快速开发平台_低代码开发平台_零代码开发平台_流程设计器_表单引擎_工作流引擎_软件架构

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1852470.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

汉语拼音字母表 (声母表和韵母表)

汉语拼音字母表 [声母表和韵母表] 1. 汉语拼音声母表2. 汉语拼音韵母表References 1. 汉语拼音声母表 声母是韵母前的辅音,与韵母一起构成一个完整的音节。 辅音是发声时,气流在口腔中受到各种阻碍所产生的声音,发音的过程即是气流受阻和克…

AtCoder Beginner Contest 359(ABCDEFG题)视频讲解

A - Count Takahashi Problem Statement You are given N N N strings. The i i i-th string S i S_i Si​ ( 1 ≤ i ≤ N ) (1 \leq i \leq N) (1≤i≤N) is either Takahashi or Aoki. How many i i i are there such that S i S_i Si​ is equal to Takahashi? C…

idea2022激活

下载激活脚本 解压后,打开文件夹如下:ja-netfilter.jar 为激活补丁: 复制补丁所在的整个文件夹到硬盘某个位置 将 ja-netfilter补丁所在的整个文件夹移动到电脑上某个位置,我是放到了 D 盘下: (路径中不…

Nginx负载均衡之Memcached缓存模块

Nginx 的 ngx_http_memcached_module 模块本身并没有提供缓存功能,它只是一个将用户请求转发到 Memcached 服务器的代理模块。 在以 Memcached 服务器为缓存应用的方案中,Memcached 作为内容缓存的存储服务器,用户通过 URL 为 Memcac…

Android面试题精选——再聊Android-Handler机制

​ static final ThreadLocal sThreadLocal new ThreadLocal(); //创建当前线程的Looper对象 private static void prepare(boolean quitAllowed) { if (sThreadLocal.get() ! null) { throw new RuntimeException(“Only one Looper may be created per thread”); } sThre…

【课程总结】Day10:卷积网络的基本组件

前言 由于接下来的课程内容将围绕计算机视觉展开,其中接触最多的内容是卷积、卷积神经网络等…因此,本篇内容将从卷积入手,梳理理解:卷积的意义、卷积在图像处理中的作用以及卷积神经网络的概念,最后利用pytorch搭建一…

详解互联网基石之HTTPS

一、HTTPS简介 HTTPS(HyperText Transfer Protocol Secure)是一种用于安全通信的网络传输协议。它是HTTP的加密版本,通过使用TLS(Transport Layer Security)或其前身SSL(Secure Sockets Layer)来…

Leetcode3185. 构成整天的下标对数目 II

Every day a Leetcode 题目来源&#xff1a;3185. 构成整天的下标对数目 II 解法1&#xff1a;哈希 本质思路类同经典的“两数之和”。枚举右&#xff0c;用哈希表维护左。 枚举 j&#xff0c;并维护 cnt[x] 表示所有满足 i < j 的下标 i 中&#xff0c;有几个 hours[i]…

服务器硬件的基础知识

引言 服务器是现代数据中心和企业IT基础设施的核心组成部分。了解服务器硬件的基本知识不仅有助于选择和维护服务器&#xff0c;还能提高系统性能和可靠性。本文将详细介绍服务器硬件的各个方面&#xff0c;包括处理器、内存、存储、网络、散热和电源等&#xff0c;帮助读者全…

数据库系统概论、数据管理的三种方式

一、数据库系统概论 数据库系统管理数据的的方式是用数据库来组织和存储数据&#xff0c;利用数据库管理系统&#xff0c;在操作系统的支持下&#xff0c;统一管理和控制存储在磁盘上的数据库&#xff0c;各类用户通过不同的方式&#xff0c;借助于数据库管理系统&#xff08;…

Android简单登录界面布局设计

<ImageView android:id“id/yxlg” android:layout_marginTop“12dp” android:layout_marginLeft“80dp” android:layout_width“30dp” android:layout_height“30dp” android:background“drawable/net” /> <TextView android:paddingTop“5dp” andr…

【面试干货】HashSet 和 TreeSet 的区别

【面试干货】HashSet 和 TreeSet 的区别 1、实现方式HashSetTreeSet 2、性能添加、删除和查找操作的时间复杂度HashSetTreeSet 3、元素唯一性4、迭代顺序HashSetTreeSet 5、使用场景HashSetTreeSet 6、示例代码 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不…

fastapi+vue3+primeflex前后端分离开发项目第一个程序

安装axios axios是用来请求后端接口的。 https://www.axios-http.cn/docs/intro pnpm 是一个前端的包管理工具&#xff0c;当我们需要给前端项目添加新的依赖的时候&#xff0c;就可以使用pnpm install 命令进行安装。 pnpm install axios安装 primeflex primeflex是一个cs…

MySQL之复制(十二)

复制 复制的问题和解决方案 未定义的服务器ID 如果没有在my.cnf里面定义服务器ID,可以通过CHANGE MASTER TO 来设置备库&#xff0c;但却无法启动复制。 mysql>START SLAVE; ERROR 1200(HY000):The server is not configured as slave;fix in config file or with CHANG…

【shell脚本速成】mysql备份脚本

文章目录 案例需求脚本应用场景&#xff1a;解决问题脚本思路实现代码 &#x1f308;你好呀&#xff01;我是 山顶风景独好 &#x1f388;欢迎踏入我的博客世界&#xff0c;能与您在此邂逅&#xff0c;真是缘分使然&#xff01;&#x1f60a; &#x1f338;愿您在此停留的每一刻…

ubuntu链接mysql

C链接mysql 报错 sudo apt-get update sudo apt-get install libmysqlclient-dev 指令编译 g -o mysql_example mysql_example.cpp -I/usr/include/mysql -lmysqlclient g mysql_test.cpp mysql_config --cflags --libs 安装mysql sudo apt updatesudo apt install mysql-…

2024各省自考报名时间汇总❗所需材料❗

天津&#xff1a;5月27日-5月31日&#xff08;已结束&#xff09; 河北&#xff1a;6月10日~6月15日&#xff08;已结束&#xff09; 贵州&#xff1a;6月17日~26日 山东&#xff1a;6月18日~6月24日 江西&#xff1a;6月26日-7月7日&#xff08;6月下旬&#xff09; 浙江&…

pytest测试框架pytest-xdist插件并发执行测试用例

Pytest提供了丰富的插件来扩展其功能&#xff0c;本章介绍下插件pytest-xdist&#xff0c;主要是提供并行测试、分布式测试、循环测试等功能&#xff0c;可以加快测试速度。 pytest-xdist官方显示没有严格的python和pytest版本限制。 pytest-xdist安装 使用pip命令安装: pip…

如何解决代码中if…else-过多的问题,建议收藏

逻辑表达模式固定的 if…else 实现与示例 if (param.equals(value1)) { doAction1(someParams); } else if (param.equals(value2)) { doAction2(someParams); } else if (param.equals(value3)) { doAction3(someParams); } // … 可重构为 Map<?, Function<?>…

电脑有哪些重复文件删除工具?分享四个一键去重软件!

重复文件删除工具有哪些&#xff0c;哪个重复文件删除工具好用&#xff1f;日常工作生活中&#xff0c;如果需要对重复文件进行查找和删除&#xff0c;我们可以借助专业的金舟重复删除工具、czkawka、Wise Duplicate Finder和DiskBoss四种方法解决&#xff0c;具体操作如下&…