python 簡單搭建阻塞式單進程,多進程,多線程服務

来源:http://www.cnblogs.com/zhenghongxin/archive/2017/11/01/7760725.html
-Advertisement-
Play Games

我們可以通過這樣子的方式去理解apache的工作原理 1 單進程TCP服務(堵塞式) 這是最原始的服務,也就是說只能處理個客戶端的連接,等當前客戶端關閉後,才能處理下個客戶端,是屬於阻塞式等待 這種阻塞型自然不適合處理多客戶端的請求,於是有了改版 2 多進程服務 採取多進程處理多客戶端連接請求,對單 ...


由於經常被抓取文章內容,在此附上博客文章網址:,偶爾會更新某些出錯的數據或文字,建議到我博客地址 :  --> 點擊這裡

我們可以通過這樣子的方式去理解apache的工作原理

1 單進程TCP服務(堵塞式)
  這是最原始的服務,也就是說只能處理個客戶端的連接,等當前客戶端關閉後,才能處理下個客戶端,是屬於阻塞式等待

from socket import *
serSocket = socket(AF_INET, SOCK_STREAM)
#重覆使用綁定的信息
serSocket.setsockopt(SOL_SOCKET, SO_REUSEADDR , 1)

localAddr = ('', 7788)
serSocket.bind(localAddr)

serSocket.listen(5)

while True:
    print('-----主進程,等待客戶端連接------')
    newSocket,destAddr = serSocket.accept()
    print('-----.主進程,接下來負責數據處理[%s]-----'%str(destAddr))
    try:
        while True:
        recvData = newSocket.recv(1024)
        if len(recvData)>0:
            print('recv[%s]:%s'%(str(destAddr), recvData))
        else:
            print('[%s]客戶端已經關閉...'%str(destAddr))
        break
    finally:
        newSocket.close()

這種阻塞型自然不適合處理多客戶端的請求,於是有了改版

2 多進程服務

採取多進程處理多客戶端連接請求,對單進程進行了優化。

from socket import *
from multiprocessing import *
from time import sleep
# 處理客戶端的請求併為其服務
def dealWithClient(newSocket,destAddr):
    while True:
        recvData = newSocket.recv(1024)
        if len(recvData)>0:
            print('recv[%s]:%s'%(str(destAddr), recvData))
        else:
            print('[%s]客戶端已經關閉'%str(destAddr))
            break
    newSocket.close()
def main():
    serSocket = socket(AF_INET, SOCK_STREAM)
    serSocket.setsockopt(SOL_SOCKET, SO_REUSEADDR , 1)
    localAddr = ('', 7788)
    serSocket.bind(localAddr)
    serSocket.listen(5)
    try:
        while True:
        print('-----主進程,,等待新客戶端的到來------')
        newSocket,destAddr = serSocket.accept()
        print('-----主進程,,接下來創建.個新的進程負責數據處理[%s]-----'
        client = Process(target=dealWithClient, args=(newSocket,destAddr))
        client.start()
        #因為已經向.進程中copy了.份(引.),並且.進程中這個套接字也沒有用處了
        #所以關閉
        newSocket.close()
    finally:
        #當為所有的客戶端服務完之後再進.關閉,表示不再接收新的客戶端的鏈接
        serSocket.close()
    if __name__ == '__main__':
        main()

    通過為每個客戶端創建一個進程的方式,能夠同時為多個客戶端進行服務;當客戶端不是特別多的時候,這種方式還行,如果有成百上千個,就不可取了,因為每次創建進程都消耗較多的資源,於是有了改進版

3 多線程服務

採用多線程處理多客戶端連接請求,由於線程共用資源,不用像進程那樣複製出多個資源,因此處理更快。

#coding=utf-8
from socket import *
from threading import Thread
from time import sleep

# 處理客戶端的請求並執行
def dealWithClient(newSocket,destAddr):
    while True:
        recvData = newSocket.recv(1024)
        if len(recvData)>0:
            print('recv[%s]:%s'%(str(destAddr), recvData))
        else:
            print('[%s]客戶端已經關閉'%str(destAddr))
            break
    newSocket.close()

def main():
    serSocket = socket(AF_INET, SOCK_STREAM)
    serSocket.setsockopt(SOL_SOCKET, SO_REUSEADDR , 1)
    localAddr = ('', 7788)
    serSocket.bind(localAddr)
    serSocket.listen(5)
    try:
        while True:
            print('-----主進程,,等待新客戶端的到來------')
            newSocket,destAddr = serSocket.accept()
            print('-----主進程,,接下來創建.個新的進程負責數據處理[%s]-----'
            client = Thread(target=dealWithClient, args=(newSocket,destAddr))
            client.start()

            #這裡不要關閉,線程共用資源,關閉了會導致全部線程均關閉
            #newSocket.close()
    finally:
        serSocket.close()
if __name__ == '__main__':
main()

 可以看我下篇博客,select模型的服務


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>引入標簽庫. <fmt:formatNumber type="number" value="${ch.showValue(item.unitprice,null)}" pa ...
  • 查看當前文件夾下麵多有的目錄文件ls 查看當前目錄下麵所有的文件,包括隱藏的文件ls -a(或者兩個一樣ls -all) 顯示除"."和".."外的所有文件ls -A 用長格式查看文件以及文件夾信息 ls -l 用長格式查看所有文件以及文件夾信息 ls -a -l total後面的數字是指當前目錄下 ...
  • 如果你是程式員,那麼肯定會在周末給自己充下電 有的人選擇看書學習 有的人選擇看視頻學習 如果你是一個老鳥,那麼看書,看博客,看官方文檔,這些是老鳥的學習路線 如果對上面都不感冒,可能你會在網上找一些視頻教程來去學習 如果你是看視頻學習的話, 下麵的這些意見可能對你會有用 一、視頻學習 看視頻的過程中 ...
  • 本文是基於嵌入式的C語言 首先弄明白程式是什麼?電腦為什麼需要編程? 編寫程式的目的是為了去運行,從而得到一些結果。顧名思義電腦就是用來計算的,所以電腦的所有程式就是在計算,那麼電腦在計算什麼呢?當然是在計算數據,因此,數據是程式的重要組成。推出:電腦程式 = 代碼 + 數據。那麼程式運行 ...
  • import java.util.HashMap;import java.util.Map;import java.util.Map.Entry;import java.util.Set; import javax.servlet.http.HttpServletRequest; public st ...
  • 點擊試聽課程 前言 點擊試聽課程 前言 很多自學編程的同學經常和我說想學一門語言自己到網上找一些教程看到一半就像背單詞背到ambulance一樣堅持不下去了....究其原因基本上都是:內容太多,太枯燥,專業術語聽不懂,學的不知道能幹嘛,學到一半就放棄了...確實從零學習編程是一個很枯燥的事,所以在想 ...
  • 用到查看當前目錄的完整路徑使用:pwd 物理路徑和連接路徑什麼鬼?沒明白暫時借鑒別人的記錄下 顯示當前目錄的物理路徑 pwd –P 1: [root@DB-Server init.d]# cd /etc/init.d 2: [root@DB-Server init.d]# pwd -P 3: /et ...
  • JSTL簡介 用的時候: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...