Python web在IIS上發佈方法和原理

来源:https://www.cnblogs.com/junshijie/archive/2019/12/26/12105095.html
-Advertisement-
Play Games

Python web應用想要發佈使用iis發佈有兩種方式,這篇文章就為大家介紹一下這兩種方式的具體實現: 1.配置HttpPlatform程式 HttpPlatform 模塊將套接字連接直接傳遞到獨立的 Python 進程。 藉助此傳遞可根據需要運行任何 Web 伺服器,但需要用於運行本地 Web ...


Python web應用想要發佈使用iis發佈有兩種方式,這篇文章就為大家介紹一下這兩種方式的具體實現:

1.配置HttpPlatform程式

HttpPlatform 模塊將套接字連接直接傳遞到獨立的 Python 進程。 藉助此傳遞可根據需要運行任何 Web 伺服器,但需要用於運行本地 Web 伺服器的啟動腳本。 在 web.config 的 <httpPlatform> 元素中指定腳本,其中 processPath 屬性指向站點擴展的 Python 解釋器,arguments 屬性指向腳本和希望提供的任何參數:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.webServer>
    <handlers>
      <add name="PythonHandler" path="*" verb="*" modules="httpPlatformHandler" resourceType="Unspecified"/>
    </handlers>
    <httpPlatform processPath="c:\python36-32\python.exe"
                  arguments="c:\home\site\wwwroot\runserver.py --port %HTTP_PLATFORM_PORT%"
                  stdoutLogEnabled="true"
                  stdoutLogFile="c:\home\LogFiles\python.log"
                  startupTimeLimit="60"
                  processesPerApplication="16">
      <environmentVariables>
        <environmentVariable name="SERVER_PORT" value="%HTTP_PLATFORM_PORT%" />
      </environmentVariables>
    </httpPlatform>
  </system.webServer>
</configuration>

此處顯示的 HTTP_PLATFORM_PORT 環境變數包含埠,本地伺服器使用該埠偵聽來自 localhost 的連接。 此示例還演示如何根據需要創建其他環境變數,本示例中為 SERVER_PORT。

關於httplplatform的更多描述可以參考https://docs.microsoft.com/en-us/iis/extensions/httpplatformhandler/httpplatformhandler-configuration-reference

2.配置 FastCGI 處理程式

FastCGI 是在請求級別工作的介面。 IIS 接收傳入的連接,並將每個請求轉發到在一個或多個持久 Python 進程中運行的 WSGI 應用。

若要使用 wfastcgi 包,請先安裝並配置它,如 pypi.org/project/wfastcgi/ 所述。

接下來,將應用的 web.config 文件修改為,在 PythonHandler 鍵中添加 python.exe 和 wfastcgi.py 的完整路徑。

  • 修改 web.config 中的 PythonHandler 條目,讓路徑與 Python 安裝位置一致(有關確切的詳細信息,請參閱 IIS 配置參考 (iis.net))。

 

<system.webServer>
  <handlers>
    <add name="PythonHandler" path="*" verb="*" modules="FastCgiModule"
        scriptProcessor="c:\python36-32\python.exe|c:\python36-32\wfastcgi.py"
        resourceType="Unspecified" requireAccess="Script"/>
  </handlers>
</system.webServer>
  • 在 web.config 的 <appSettings> 部分中,為 WSGI_HANDLER、WSGI_LOG(可選)和 PYTHONPATH 添加鍵:
<appSettings>
  <add key="PYTHONPATH" value="c:\home\site\wwwroot"/>
  <!-- The handler here is specific to Bottle; see the next section. -->
  <add key="WSGI_HANDLER" value="app.wsgi_app()"/>
  <add key="WSGI_LOG" value="c:\home\LogFiles\wfastcgi.log"/>
</appSettings>

PYTHONPATH 的值可以自由擴展,但必須包括你的應用的根目錄,他擴展了sys.path,可以在這個路徑下找到import的包。
WSGI_HANDLER 必須指向可從你的應用導入的 WSGI 應用,針對不同的框架,這個值也有一些區別,下麵是一些例子。

1.Bottle:確保 app.wsgi_app 後面有括弧,如下所示。 此操作是必需的,因為該對象是函數(請參閱 app.py))而非變數:

<!-- Bottle apps only -->
<add key="WSGI_HANDLER" value="app.wsgi_app()"/>

2.Flask:將 WSGI_HANDLER 值更改為 <project_name>.app,其中 <project_name> 與項目名稱匹配。 可通過查看 runserver.py 中的 from <project_name> import app 語句,找到準確的標識符。 例如,如果項目命名為“FlaskAzurePublishExample”,則該條目如下所示:

<!-- Flask apps only: change the project name to match your app -->
<add key="WSGI_HANDLER" value="flask_iis_example.app"/>

3.Django:對於 Django 項目,需要對“web.config”進行兩項更改。 首先,將 WSGI_HANDLER 值更改為 django.core.wsgi.get_wsgi_application()(該對象位於 wsgi.py 文件中):

<!-- Django apps only -->
<add key="WSGI_HANDLER" value="django.core.wsgi.get_wsgi_application()"/>

其次,在 WSGI_HANDLER 條目下添加以下條目,並將 DjangoAzurePublishExample 替換為項目名稱:

<add key="DJANGO_SETTINGS_MODULE" value="django_iis_example.settings" />

WSGI_LOG 為可選,但建議在調試應用時使用,記錄日誌。

 

以上就是這兩種方式,但是作為補充我還是想跟大家分享一下第二種方式,使用fastcgi時,我們在安裝完wfastcgi後輸入命令wfastcgi-enable之後程式做了什麼。

我們可以根據IIS文檔中對於FastCGI節的描述瞭解到。如果我們想要在web.config使用fastCGI時,必須先定義了該模塊:

 

而這個定義方法呢,就是在IIS全局配置ApplicationHost.config中添加下麵的配置,而這個也是我們在輸入wfastcgi-enable之後做的事情:

<?xml version="1.0"?>
<configuration xmlns:xdt="http://schemas.microsoft.com/XML-Document-Transform">
  <system.webServer>
    <fastCgi>
      <application fullPath="d:\home\site\wwwroot\Python34\python.exe" xdt:Locator="Match(fullPath)" xdt:Transform="Remove" />
      <application fullPath="d:\home\site\wwwroot\Python34\python.exe" arguments="D:\Python34\Scripts\wfastcgi.py"  maxInstances="0" xdt:Transform="Insert"/>
    </fastCgi>
  </system.webServer>
</configuration>

如果您遇到了無法使用wfastcgi-enable這個命令的情況,比如Azure web app的windows環境,那麼你可以使用這種方式使用自定義的python版本。

 

參考文檔:

https://docs.microsoft.com/en-us/iis/extensions/httpplatformhandler/httpplatformhandler-configuration-reference

https://docs.microsoft.com/zh-cn/visualstudio/python/configure-web-apps-for-iis-windows?view=vs-2019

https://pypi.org/project/wfastcgi/

https://docs.microsoft.com/en-us/iis/configuration/system.webserver/fastcgi/

 


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

-Advertisement-
Play Games
更多相關文章
  • 高德地圖技術團隊希望打造一套快速精準的UI解決方案,通過自動化的方式生產UI代碼,解放研發生產力的同時滿足客戶需求。 ...
  • [TOC] 簡單工廠模式缺陷 "大白話簡單工廠模式(Simple Factory Pattern)" 中通過買車的經歷解釋了簡單工廠模式。但熟悉設計模式的朋友會發現一些問題。 工廠類集中了所有實例(產品)的創建邏輯,一旦這個工廠不能正常工作,整個系統都會受到影響。用日產車工廠的例子來形容就是日產汽車 ...
  • 微服務改造是一個長期過程,這個過程會遇到各式各樣的問題,方法論可以幫助我們更好地解決這些問題,並且降低風險。緊接昨天的上篇《如何把單體式應用拆解成微服務?【上】》,今天我們一起來看看具體的拆解場景。 ...
  • socketserver、struct模塊練習,簡易的FTP ...
  • 這幾個變數判斷函數在PHP開發中用的其實挺多的,而且粗看上去都差不多,但其實還是有不少的區別的,如果搞不清楚,也許就會遺留一些潛在的bug, 包括我自已也遇到過這樣的坑,比如有一次我就遇到過用empty判斷出現的問題,前端是允許輸入0的,但是我用empty判斷的話就為真,我就直接給報錯了,所以這裡就 ...
  • Jdk8中java.time包中的新的日期時間API類的LocalDate源碼分析,TemporalAccessor、Temporal、TemporalAdjuster、ChronoLocalDate和LocalDate的關係解析。 ...
  • 要求要安裝Gin軟體包,需要:1、安裝Go(需要1.11+版本)2、設置Go工作區安裝1、下載並安裝 gin: 2、將 gin 引入到代碼中: 3、(可選)導入net/http。例如,如果使用http.StatusOK這類的常量,則需要這樣做: 快速開始1、創建一個名為 example.go 的文件 ...
  • 1、Gin 是什麼? Gin 是一個用 Go (Golang) 編寫的 HTTP web 框架。 它是一個類似於 martini 但擁有更好性能的 API 框架, 由於 httprouter,速度提高了近 40 倍。如果你需要極好的性能,使用 Gin 吧。2、為什麼要用Gin 在 Web 開發中,開 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...