multiprocessing多進程使用案例

multiprocessing — 基于進程的并行:https://docs.python.org/zh-cn/3.11/library/multiprocessing.html

import sys
from fastchat.serve.controller import Controller
from fastchat.serve.model_worker import ModelWorker
from fastchat.serve.openai_api_server import app, CORSMiddleware, app_settingsimport sys
import uuid
import uvicorn
from fastapi import FastAPI# 創建不同的 FastAPI 應用實例
controller_app = FastAPI(title="FastChat Controller Service")
worker_app = FastAPI(title="FastChat Model Worker Service")
api_app = FastAPI(title="FastChat OpenAI API Service")def start_controller():"""啟動 FastChat Controller 服務分布式系統設計中常見的一種優化策略,決定如何分配任務給不同的model_worker(或服務器)- LOTTERY:這種方法系統會隨機選擇一個worker。不考慮worker的當前負載或任何其他因素。- SHORTEST_QUEUE:這種方法會選擇當前隊列長度最短的worker,也就是當前負載最小的工人。"""controller = Controller(dispatch_method="shortest_queue")# sys.modules 是一個字典,它存儲了已經加載的模塊。每個鍵是一個模塊名,每個值是一個模塊對象。# 這種機制使得Python在導入模塊時可以檢查模塊是否已經在sys.modules中,如果是,就直接使用已經加載的模塊,避免重復加載。sys.modules["fastchat.serve.controller"].controller = controllercontroller_app.title = "FastChat Controller"controller_app._controller = controlleruvicorn.run(controller_app, host="192.168.110.131", port=21001)def start_model_worker():"""啟動 Model Worker 服務"""worker_id = str(uuid.uuid4())[:8]worker = ModelWorker(controller_addr="http://192.168.110.131:21001",worker_addr="http://192.168.110.131:21002",worker_id=worker_id,limit_worker_concurrency=5,no_register=False,# no_register=True,model_path="/home/00_rag/model/ZhipuAI/chatglm3-6b",num_gpus=4,model_names=["chatglm3-6b"],device="cuda",max_gpu_memory="22GiB",)worker_app.title = f"FastChat LLM Server ChaGLM3-6b"worker_app._worker = workeruvicorn.run(worker_app, host="192.168.110.131", port=21002)def start_openai_api_server():"""啟動 OpenAI API 服務"""api_app.add_middleware(CORSMiddleware,allow_credentials=True,  # 允許前端請求攜帶認證信息(如 cookiesallow_origins=["*"],  # 允許所有域名的請求,星號表示不限制任何域。allow_methods=["*"],  # 允許所有的 HTTP 方法。allow_headers=["*"],  # 允許所有的 HTTP 頭)app_settings.controller_address = "http://192.168.110.131:21001"app_settings.api_keys = []api_app.title = "FastChat OpenAI API Server"uvicorn.run(api_app, host="192.168.110.131", port=8000)from multiprocessing import Process
import timedef start_services_in_processes():# 創建進程# controller_process = Process(target=start_controller)worker_process = Process(target=start_model_worker)api_server_process = Process(target=start_openai_api_server)# 啟動進程# controller_process.start()worker_process.start()api_server_process.start()# 等待所有進程完成# controller_process.join()worker_process.join()api_server_process.join()if __name__ == '__main__':start_services_in_processes()

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/84735.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/84735.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/84735.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

鴻蒙OSUniApp 開發實時天氣查詢應用 —— 鴻蒙生態下的跨端實踐#三方框架 #Uniapp

使用 UniApp 開發實時天氣查詢應用 —— 鴻蒙生態下的跨端實踐 在移動互聯網時代,天氣應用幾乎是每個人手機中的"標配"。無論是出行、旅游還是日常生活,實時獲取天氣信息都極為重要。本文將以"實時天氣查詢應用"為例,詳…

藍橋杯178 全球變暖

題目描述 你有一張某海域 NxN 像素的照片,"."表示海洋、"#"表示陸地,如下所示: ....... .##.... .##.... ....##. ..####. ...###. ....... 其中"上下左右"四個方向上連在一起的一片陸地組成一座島嶼。例如上…

第五十二節:增強現實基礎-簡單 AR 應用實現

引言 增強現實(Augmented Reality, AR)是一種將虛擬信息疊加到真實世界的技術,廣泛應用于游戲、教育、工業維護等領域。與傳統虛擬現實(VR)不同,AR強調虛實結合,用戶無需完全沉浸到虛擬環境中。本文將通過Python和OpenCV庫,從零開始實現一個基礎的AR應用:在檢測到特定…

青少年編程與數學 02-019 Rust 編程基礎 23課題、web服務器

青少年編程與數學 02-019 Rust 編程基礎 23課題、web服務器 一、單線程Web 服務器基本實現步驟完整代碼示例運行結果項目結構注意事項擴展方向 二、多線程Web服務器1. 基本架構設計2. 完整實現代碼項目文件結構文件內容Cargo.tomlsrc/main.rssrc/lib.rsstatic/hello.htmlstatic…

(14)JVM彈性內存管理

文章目錄 🚀 JVM彈性內存管理:K8s環境下的內存優化終極攻略? TL;DR😵 等等,為什么我需要關心這個?🛠? 五步搞定彈性內存(拯救你的Java應用)1?? JVM參數調教2?? 監控指標全覆蓋…

Spring Boot集成Spring AI與Milvus實現智能問答系統

在Spring Boot中集成Spring AI與Milvus實現智能問答系統 引言 隨著人工智能技術的快速發展,智能問答系統在企業中的應用越來越廣泛。然而,傳統的問答系統往往面臨AI幻覺(Hallucination)問題,即生成不準確或無意義的回…

電腦網絡如何改ip地址?ip地址改不了怎么回事

在日常使用電腦上網時,我們有時會遇到需要更改IP地址的情況,比如訪問某些受限制的網站、解決網絡沖突問題,或者出于隱私保護的需求。然而,許多用戶在嘗試修改IP地址時可能會遇到各種問題,例如IP地址無法更改、修改后無…

SQL進階之旅 Day 1:高效表設計與規范

SQL進階之旅 Day 1:高效表設計與規范 開篇 歡迎來到為期30天的“SQL進階之旅”系列的第一天!今天我們將從數據庫表設計的基礎入手,討論如何通過合理的表設計來提升數據庫性能。這不僅是每位數據庫開發工程師的基本功,也是解決實…

【MySQL】第11節|MySQL 8.0 主從復制原理分析與實戰

一、MySQL主從復制基礎 1. 核心概念 定義: MySQL主從復制是將主庫(Source/Master)的數據變更同步到一個或多個從庫(Replica/Slave)的機制,默認采用異步復制,支持全庫、指定庫或表的同步。 角…

怎么判斷一個Android APP使用了Cocos 這個跨端框架

要判斷一個 Android 應用是否使用了 Cocos 跨端框架,可以通過以下步驟進行驗證: 一、安裝包結構分析 1. 解壓 APK 將 .apk 文件重命名為 .zip 并解壓,檢查以下特征文件: ? lib/ 目錄: Cocos 引擎的核心原生庫文件通常…

刪除word中由奇偶頁和頁碼1設置多出來的空白頁

問題: 在調整畢設論文格式時,要求奇偶頁眉設置不同,且摘要頁的頁碼是1(I)。如果摘要頁在整個文檔的第偶數頁,將其頁碼設置為1后會變為奇數頁,word為了湊齊奇偶頁,會在摘要前增加一個…

# 探索自然語言處理的奧秘:基于 Qwen 模型的文本分類與對話系統實現

探索自然語言處理的奧秘:基于 Qwen 模型的文本分類與對話系統實現 在當今數字化時代,自然語言處理(NLP)技術正以前所未有的速度改變著我們的生活和工作方式。從智能語音助手到自動文本生成,從情感分析到機器翻譯&…

Linux Shell 切換

在 Linux 系統中,切換至 Bash Shell 在 Linux 系統中,切換至 Bash Shell 的方法如下: 臨時切換到 Bash 直接在終端輸入以下命令,啟動一個新的 Bash 會話: bash 退出時輸入 exit 或按 CtrlD 返回原 Shell。 永久切換…

在Windows上,將 Ubuntu WSL 安裝并遷移到 D 盤完整教程(含 Appx 安裝與遷移導入)

💻 將 Ubuntu WSL 安裝并遷移到 D 盤完整教程(含 Appx 安裝與遷移導入) 本文記錄如何在 Windows 系統中手動啟用 WSL、下載 Ubuntu 安裝包、安裝并遷移 Ubuntu 到 D 盤,避免默認寫入 C 盤,提高系統性能與可維護性。 ?…

doucker 掛載卷

在 Docker 中,掛載卷(Volumes)是一種非常重要的功能,它允許你將宿主機的文件系統與容器的文件系統進行共享。掛載卷不僅可以用于持久化數據,還可以用于在宿主機和容器之間傳遞文件。 掛載卷的類型 Docker 支持多種類型…

BLIP3-o:一系列完全開源的統一多模態模型——架構、訓練與數據集

摘要 在近期關于多模態模型的研究中,將圖像理解與生成統一起來受到了越來越多的關注。盡管圖像理解的設計選擇已經得到了廣泛研究,但對于具有圖像生成功能的統一框架而言,其最優模型架構和訓練方案仍有待進一步探索。鑒于自回歸和擴散模型在…

數據分析案例-基于紅米和華為手機的用戶評論分析

🤵?♂? 個人主頁:艾派森的個人主頁 ?🏻作者簡介:Python學習者 🐋 希望大家多多支持,我們一起進步!😄 如果文章對你有幫助的話, 歡迎評論 💬點贊&#x1f4…

基礎框架 兼容視頻格式

基礎框架 兼容視頻格式 修改 \src\components\Upload\src\BasicUpload.vue 數據庫新增 vue <template><div class"w-full"><div class"upload"><div class"upload-card"><!--圖片列表--><divclass"uploa…

qiankun 子應用怎樣通過 props拿到子應用【注冊之后掛載之前】主應用中發生變更的數據

場景描述&#xff1a;子應用需要在接口調用和頁面渲染時&#xff0c;需要用到主應用登錄之后拿到的用戶數據 邏輯前提&#xff1a; 1、主應用在 main.js中通過 registerMicroApps注冊了子應用 2、主應用登錄之后將用戶數據傳遞給子應用 >> 原先的做法&#xff08;有問題&…

Hooks 進階:自定義 Hook 的設計與實踐

引言 React Hooks 已成為現代 React 開發的核心范式&#xff0c;而自定義 Hook 則為我們提供了強大的代碼復用機制。 自定義 Hook 的基礎原理 自定義 Hook 本質上是一種函數復用機制&#xff0c;它允許我們將組件邏輯提取到可重用的函數中。與傳統的高階組件(HOC)和 render …