apache 部署python3_flask+apache2+wsgi+python3 部署(挖坑记)
昨天小伙伴要我幫忙寫一個網頁用來查詢成績,給的格式xlxs文件,我一想,思路很簡單:把數據轉換成數據庫
寫個表單,傳遞查詢學號
后臺用數據庫查詢
把網站部署到服務器上
于是就有….
xlxs 轉換成數據庫
本身數據就沒有多少,所以我決定使用sqlite3,完全夠用,有三種思路:Excel文件另存為csv文件,然后使用sqlite導入 .import data.csv tablename
使用openpyxl庫讀取Excel文件,然后逐條插入到數據庫中
但我google發現了一個xls2db的庫,使用兩行代碼進行轉換 from xls2db import xls2db xls2db("data.xlxs","student.db")
flask 表單,路由
因為感覺比較簡單,所以決定嘗試一下flask,而不是用servlet。(因為java環境不想裝了)
query_score/
.
|-- 1.xlsx
|-- __pycache__
|-- app
|-- config.py
|-- config.pyc
|-- index.py
|-- query_score.wsgi
|-- requirements.txt
`-- student.db
目錄結構大致就是這個樣子,主要的代碼都存放在 app 文件夾下,代碼暫且不表
參考教程
flask 的運行主要在與調用 app.run(), app 是我們創建的一個 Flask 對象。所以我們可以這樣運行:在 index.py 中的寫入 from app import app 這里的第一個app,表示的是 app目錄,在Python中,目錄中帶有 __init__.py 文件夾就可以被調用,第二個app,是我們在 __init__.py 中創建的 app 實例 from flask import Flask app=Flask(__name__),最后設置環境變量 export FLASK_APP=index.py ,然后運行flask run 就Ok了
要么在 index.py 中寫入 if __name__=='__main__': app.run(),然后使用python index.py進行運行
我們需要清楚的是只要我們像運行整個網站,一定要調用 Flask 實例的 run 方法
這一部分真的很簡單,多調試即可(況且我是新學233)
數據庫查詢
sqlite3 數據庫查詢:打開數據庫
執行數據庫查詢語句
遍歷查詢的結果列表,處理成字典,返回(字典我用了有序字典,否則的話,最后遍歷的時候,順序是按照優化的存儲順序,字典理論上應該是hash表,所以沒有順序(推測))
import sqlite3
from collections import OrderedDict
DATABASE="./student.db"
db=sqlite3.connect(DATABASE)
cur=db.execute("select * from Sheet1 where stuno={}".format(stuno))
#獲得列名col_name=[tuple[0] for tuple in cur.decription]
for c in cur:
#處理數據 result=OrderedDict()
for item,num in enumerate(c):
result[col_name[num]]=item
return result
在總結的時候我突然想起來,這種拼接sql語句的方法可能會造成 sql injection(( ̄▽ ̄)~*) 然而,我測試的時候,并沒有出現,因為我在解包 cur的時候,默認認為只有一條數據(查詢的時候可不是一人一條嘛),所以處理完第一條數據,直接返回了2333,但還是推薦一下這種sql 語句格式化的方法:
....
cur=db.execute("select * from Sheet1 where stuno=?",(stuno))
....
部署到服務器上
頭大的一批。。。。
因為我看到大多數老哥都是用了 virtualenv來配置環境,但我頭比較鐵,直接使用了全局環境,最后還是慫了。。。。
大多數過程參考Pi的答案
https://stackoverflow.com/questions/30674644/installing-mod-wsgi-for-python3-on-ubuntu/30682386#30682386
https://stackoverflow.com/questions/30642894/getting-flask-to-use-python3-apache-mod-wsgi
一個小技巧,偶然間想起來的 tail -f /var/log/apache2/error.log 這樣會一直維持著查看apache2的錯誤日志
所以我們可以開兩個ssh 連接,一個修改代碼,一個看日志
大多數教程網上都有,不再贅述,只做一點經驗總結:python3 和 python2 使用的 wsgi 是不一樣的。因為在部署到apache2上時,使用的不是 python 解釋器程序,而是使用mod_wsgi模塊進行運行,所有的庫都是通過它運行的,所以mod_wsgi的版本和python庫的版本一定要一樣
有可能出現部分庫無法導入的問題(importerror),(因為有可能有兩套python 環境 2.7 3.5),首先卸載2.7的庫(或者全部卸載),然后重新使用python3(因為我用的是python3)的pip3進行安裝 參考
建議使用pip的時候,最好通過 python -m pip ... python3 -m pip ,這樣不會亂,因為在我的主機上,我發現pip 居然莫名其妙變成python3的了..
sqlite數據庫打開的時候會生成一個lockfile,用來保證數據庫的一致性,所以運行需要有數據庫文件所在目錄寫權限,實在不行使用root運行apache
使用virtualenv的時候那個 activate_this.py 不在python 虛擬環境下面,到github下下載,或者在virtualenv包下面找都行
修改了自定義的 /etc/apache2/sites-available/myconf.conf 有可能因為配置文件不正確導致apache2 無法重啟啟動/關閉/報錯,會提醒你使用systemctl status apache2.service 或者 journalctl -xe 好看apache2 詳細信息,其實可以使用 apache2ctl configtest檢查配置文件的錯誤,指定定位到行,方便改正。
總結
以上是生活随笔為你收集整理的apache 部署python3_flask+apache2+wsgi+python3 部署(挖坑记)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql中的sql_mysql中的sq
- 下一篇: 无法为您重置MySQL密码_无法重置My