網站首頁 編程語言 正文
概述
使用多線程,讓web服務器可以同時處理多個用戶的訪問。當客戶端和服務端建立連接成功,創建子線程,使用子線程專門處理客戶端的請求,防止主線程阻塞。把創建的子線程設置成為守護主線程,防止主線程無法退出。
實現步驟
1.導入threading模塊
import threading
2.設置端口號復用, 程序退出端口立即釋放
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
3.當客戶端和服務器建立連接程,創建子線程
設置target的名稱,并且通過元組的方式傳入new_socket參數
sub_thread = threading.Thread(target=handle_client_request, args=(new_socket,))
4.設置守護主進程
sub_thread.setDaemon(True)
5.啟動子線程
sub_thread.start()
代碼實現
import socket
import threading
# 處理客戶端的請求
def handle_client_request(new_socket):
# 代碼執行到此,說明連接建立成功
recv_client_data = new_socket.recv(4096)
if len(recv_client_data) == 0:
print("關閉瀏覽器了")
new_socket.close()
return
# 對二進制數據進行解碼
recv_client_content = recv_client_data.decode("utf-8")
print(recv_client_content)
# 根據指定字符串進行分割, 最大分割次數指定2
request_list = recv_client_content.split(" ", maxsplit=2)
# 獲取請求資源路徑
request_path = request_list[1]
print(request_path)
# 判斷請求的是否是根目錄,如果條件成立,指定首頁數據返回
if request_path == "/":
request_path = "/index.html"
try:
# 動態打開指定文件
with open("static" + request_path, "rb") as file:
# 讀取文件數據
file_data = file.read()
except Exception as e:
# 請求資源不存在,返回404數據
# 響應行
response_line = "HTTP/1.1 404 Not Found\r\n"
# 響應頭
response_header = "Server: PWS1.0\r\n"
with open("static/error.html", "rb") as file:
file_data = file.read()
# 響應體
response_body = file_data
# 拼接響應報文
response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body
# 發送數據
new_socket.send(response_data)
else:
# 響應行
response_line = "HTTP/1.1 200 OK\r\n"
# 響應頭
response_header = "Server: PWS1.0\r\n"
# 響應體
response_body = file_data
# 拼接響應報文
response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body
# 發送數據
new_socket.send(response_data)
finally:
# 關閉服務與客戶端的套接字
new_socket.close()
# 程序入口函數
def main():
# 創建tcp服務端套接字
tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 設置端口號復用, 程序退出端口立即釋放
tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
# 綁定端口號
tcp_server_socket.bind(("", 9000))
# 設置監聽
tcp_server_socket.listen(128)
while True:
# 等待接受客戶端的連接請求
new_socket, ip_port = tcp_server_socket.accept()
print(ip_port)
# 當客戶端和服務器建立連接程,創建子線程
sub_thread = threading.Thread(target=handle_client_request, args=(new_socket,))
# 設置守護主線程
sub_thread.setDaemon(True)
# 啟動子線程執行對應的任務
sub_thread.start()
if __name__ == '__main__':
main()
原文鏈接:https://cloud.tencent.com/developer/article/1948183
相關推薦
- 2022-06-15 C#實現希爾排序_C#教程
- 2023-01-15 React?Fiber樹的構建和替換過程講解_React
- 2022-02-17 H5移動端點擊出現背景藍色框的解決方案
- 2022-04-19 idea如何解決jar包沖突
- 2022-08-05 C語言示例講解do?while循環語句的用法_C 語言
- 2022-09-01 一文搞懂Scrapy與MongoDB交互過程_MongoDB
- 2022-10-03 利用正則表達式校驗金額最多保留兩位小數實例代碼_正則表達式
- 2022-05-27 Jmeter如何使用BeanShell取樣器調用Python腳本_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支