TCP和并发服务器

与UDP不同的是,他是一个面向连接的,可靠的数据传输协议

TCP通信比较复杂

先写一个TCP服务器,一般步骤如下:

1、首先是要创建一个socket套接字:socket()

2、服务器一般是需要一个固定的IP地址和固定端口号,服务器就要绑定这个IP地址和端口号:bind()

3、客户端连接服务器是是有一定的数量(允许最大连接数)的,而这个数量是服务器设定的:listen()

4、上面3步是做被连接的准备,这一步是来接受客户端的数据,在接受数据之前,服务器还是需要接受客户端的socket套接字和IP地址:accept()

5、只有服务器和客户端绑定相同的IP地址,服务器和客户端才可以互相接收数据和发送数据,常理来想,服务器是一只被开启的,也是一直接受数据,所以在接受数据的过程中,我们需要无限循环:recv()

6、如果我们要发送数据给客户端,客户端也需要绑定上面的地址,然后需要调用相应的函数send()

import socket

# TCP
# 创建一个服务器socket套接字
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 服务器的IP地址和端口号
address = ("127.0.0.1", 9999)
# 服务器绑定地址
server_socket.bind(address)
# 设置服务器的最大连接数
server_socket.listen(1)
# 创建一个等待连接的客户端socket套接字,accept()函数会返回两个值,可以自行打印
client_socket, address = server_socket.accept()
# 服务器需要不停的接受客户端的发来的数据
while True:
"""
以防客户端连接失败,需要检测异常
无论是接受数据还是发送数据,我们需要将数据统一编码和解码
"""
try:
data = client_socket.recv(2048).decode("UTF-8")
# 数据处理
print("服务器接受的数据:", data) # 服务器接受的数据:我是一个客户端
client_socket.send("我是一个服务器".encode("UTF-8"))
except:
break

再写一个TCP客户端,一般步骤如下:

1、首先是要创建一个socket套接字:socket()

2、客户端一般是不需要一个固定的IP地址和固定端口号,连接服务器的时候系统会自动分配端口号

3、客户端连接服务器必须先知道服务器的IP地址和端口号,然后在连接服务器:connect()

4、上面3步是做连接的准备,这一步是来发送客户端的数据:send()

5、客户端也可以一直接受服务器发来的数据,所以在接受数据的过程中,我们需要无限循环:recv()

import socket

# 客户端需要创建一个套接字
client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 客户端需要连接服务器,必须先知道服务器的IP地址和端口号
address = ("127.0.0.1", 9999) # 连接服务器
client_socket.connect(address) # 这个数据是将要发送的数据
data = "我是一个客户端"
client_socket.send(data.encode("UTF-8"))
while True:
"""
以防服务器中断退出,需要检测异常
无论是接受数据还是发送数据,我们需要将数据统一编码和解码
"""
try:
data = client_socket.recv(2048).decode("UTF-8")
# 数据处理,这里打印出来并且将数据发回客户端
print("客户端接受的数据:", data)
except:
break

并发服务器,这里我只介绍多线程服务器,进程和线程是差不多的)

  在TCP服务器的原有基础上增加一个线程,再将监听数增加为5,就可以允许5个客户端线程同时访问,并且可同时发送和接受数据

import socket
from threading import Thread # TCP
# 创建一个服务器socket套接字
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 服务器的IP地址和端口号
address = ("127.0.0.1", 9999) def net_connect():
try:
# 服务器绑定地址
server_socket.bind(address)
# 设置服务器的最大连接数
server_socket.listen(5)
except:
return
# 创建线程
th = Thread(target=recv_data)
th.start() def recv_data():
# 服务器需要不停的接受客户端的发来的数据
while True:
"""
以防客户端连接失败,需要检测异常
无论是接受数据还是发送数据,我们需要将数据统一编码和解码
"""
# 创建一个等待连接的客户端socket套接字,accept()函数会返回两个值,可以自行打印
client_socket, address = server_socket.accept()try:
data = client_socket.recv(2048).decode("UTF-8")
# 数据处理
print("服务器接受的数据:", data)
client_socket.send("我是一个服务器".encode("UTF-8"))
except:
break net_connect()

在TCP客户端上也增加一个线程,然后同时运行多次这个客户端程序:

import socket

# 客户端需要创建一个套接字
from threading import Thread client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 客户端需要连接服务器,必须先知道服务器的IP地址和端口号
address = ("127.0.0.1", 9999) def net_connect():
try:
# 连接服务器
client_socket.connect(address)
except:
return
th = Thread(target=recv_data)
# th.setDaemon(True)
th.start() def recv_data():
# 这个数据是将要发送的数据
data = "我是一个客户端"
client_socket.send(data.encode("UTF-8")) while True:
"""
以防服务器中断退出,需要检测异常
无论是接受数据还是发送数据,我们需要将数据统一编码和解码
"""
try:
data = client_socket.recv(2048).decode("UTF-8")
# 数据处理,这里打印出来并且将数据发回客户端
print("客户端接受的数据:", data)
except:
break net_connect()

python高级编程——网络编程(三)的更多相关文章

  1. python高级之网络编程

    python高级之网络编程 本节内容 网络通信概念 socket编程 socket模块一些方法 聊天socket实现 远程执行命令及上传文件 socketserver及其源码分析 1.网络通信概念 说 ...

  2. 第六篇:python高级之网络编程

    python高级之网络编程   python高级之网络编程 本节内容 网络通信概念 socket编程 socket模块一些方法 聊天socket实现 远程执行命令及上传文件 socketserver及 ...

  3. python语法基础-网络编程-TCP协议和UDP协议

    ###############    网络编程    ############## """ 网络编程 学习了Python基础之后,包括函数,面向对象等,你就可以开发了,你 ...

  4. Python之路 - 网络编程之粘包

    Python之路 - 网络编程之粘包 粘包

  5. Python之路 - 网络编程初识

    Python之路 - 网络编程初识 前言

  6. Python中级 —— 04网络编程

    网络编程 网络编程对所有开发语言都是一样的,Python也不例外.用Python进行网络编程,就是在Python程序本身这个进程内,连接别的服务器进程的通信端口进行通信. TCP编程 TCP建立可靠连 ...

  7. python高级编程——网络编程(一)

    计算机网络基础 概念:计算机网络就是把各个计算机连接到一起,让网络中的计算机可以互相通信.网络编程就是如何在程序中实现两台计算机的通信.而网络编程就是开发计算机网络应用程序 计算机的通信协议 概念:计 ...

  8. python之Socket网络编程

    什么是网络? 网络是由节点和连线构成,表示诸多对象及其相互联系.在数学上,网络是一种图,一般认为专指加权图.网络除了数学定义外,还有具体的物理含义,即网络是从某种相同类型的实际问题中抽象出来的模型.在 ...

  9. 【循序渐进学Python】15.网络编程

    Python 内置封装了很多常见的网络协议的库,因此Python成为了一个强大的网络编程工具,这里是对Python的网络方面编程的一个简单描述. 1. 常用的网络设计模块 在标准库中有很多网络设计相关 ...

  10. python 之socket 网络编程

    socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求. socket起源于Un ...

随机推荐

  1. sqlserver 数据库 创建不同文件组的数据库

  2. LG5367 「模板」康托展开 康托展开

    问题描述 LG5367 题解 康托展开公式: \[ans=1+(\sum_{i=1}^{n}{a_i})\times(n-i)!\] 用树状数组维护一下\(\sum\)里面的东西,前缀积维护后面的东西 ...

  3. Ubuntu16.04安装flume

    参考:https://www.cnblogs.com/soyo/p/7686702.html

  4. perfview微软开源的cpu以及内存性能分析工具

    perfview 是一个强大的分析工具,能用来分cpu,内存,磁盘io...多种指标,使用简单,功能强大 用来分析windows应用的性能问题,是一个很不错的选择 下载地址 https://githu ...

  5. pytest--fixture

    前戏 fixture是在测试函数运行前后,由pytest执行的外壳函数.fixture中的代码可以定制,满足多变的测试需求,包括定义传入测试中的数据集.配置测试前系统的初始状态.为批量测试提供数据源等 ...

  6. xBIM之二:构建墙和门窗

    研究了两天,终于实现了利用xBIM自动输出墙和门窗 比较粗糙的源码如下: private void Form1_Load(object sender, EventArgs e) { //first c ...

  7. CSP2019蒸馏记

    Day -\(\infty\) ~ Day -2 认真准备联赛. Day -1 复习模板,全真模拟比赛平衡树 下午进行了湖南大学 2 小时游. Day 0 上午睡过头了 下午日常训练,并没有什么开放日 ...

  8. MyBatis 通过 BATCH 批量提交

    本文由 简悦 SimpRead 转码, 原文地址 https://www.jb51.net/article/153382.htm 很多人在用 MyBatis 或者 通用 Mapper 时,经常会问有没 ...

  9. 执行"rm -rf /"之后世界安静了吗

    对于Unix/Linux程序员来说,"rm -rf /"一直被认为是一个极度危险的操作,因为直接把根目录给删除了,整个操作系统也就崩溃了.但实际上会是这样的吗?呵呵,请看图: 啊哈 ...

  10. java 解决safari下载中文文件名乱码

    主要就是在响应头设置content-disposition,主要遵循 RFC 5987标准. response.setHeader("content-disposition",&q ...