這篇文章主要介紹了使用SAE部署Python運行環境的教程,SAE作為新浪的在線軟件部署平台,在國內擁有一定的性價比,需要的朋友可以參考下
因為 GAE 在國內訪問不便,所以平時有一些小應用,我都會放在 SAE 上面, 雖然 SAE 還有很多缺陷,但算是上手比較容易的一個了,最起碼文檔寫的不錯。
開發 SAE 上的應用,我一般都用 Flask,SAE 預裝了 Flask,所以你可以直接用, 但我們難免會用一些沒有預裝的庫。
如果是在以前,可能需要自己將 package 挨個 copy 到應用目錄中,然後手動加載, 現在嘛,不需要那麼麻煩了,SAE 有個非常不錯的解決方案,見《安裝依賴的第三方包》
你可以使用 saecloud 來代替 pip 安裝第三方庫
?
1 saecloud install -r requirements.txt這條命令會將第三方庫安裝在應用目錄的 site-packages 目錄下面,部署時可以將所有的依賴 打包成 zip 檔案,這樣上傳和維護都很方便。
?
1 2 cd site-packages/ zip -r ../site-packages.zip .在 index.wsgi 中將這些依賴加載進來
?
1 2 3 4 5 6 7 8 import os import sys root = os.path.dirname(__file__) # 兩者取其一 sys.path.insert(0, os.path.join(root, 'site-packages')) sys.path.insert(0, os.path.join(root, 'site-packages.zip'))雖然是二者取其一,但學是推薦使用 zip 檔案的方式。
有個問題是,我們需要打包的,只是 SAE 沒有預裝的包, 但我們本地開發還要依賴 Flask 這些預裝的包, 都使用 saecloud 安裝的話,這個包明顯就會有冗余。
借鑒於 bower, npm 這些包管理器的依賴管理的優點, 我們顯然應該將依賴庫分離出來。
?
1 2 3 4 # 安裝非預裝依賴 pip install -r requirements.txt # 維護預裝依賴 saecloud install -r requirements-dev.txt這樣,只有 requirements.txt 中的包會被安裝到應用目錄下的 site-packages 文件夾中。
經過一些實踐,我整理了自己用著比較順手的源代碼文件結構
復制代碼 代碼如下:
LICENSE
Makefile
README.md
requirements-dev.txt
requirements.txt
site-packages
...
site <--- web app 目錄
index.wsgi
main.py
config.yam
site-packages.zip <--- 打包的依賴庫
...
我會將下面的文件加入到 .gitignore,以避免它們被提交到版本中。
復制代碼 代碼如下:
/site-packages
/site/site-packages.zip
/site/index.wsgic
為了方便安裝依賴和部署項目,我寫了個 Makefile