日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

apache 部署python3_flask+apache2+wsgi+python3 部署(挖坑记)

發(fā)布時(shí)間:2025/3/19 python 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 apache 部署python3_flask+apache2+wsgi+python3 部署(挖坑记) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

昨天小伙伴要我?guī)兔懸粋€(gè)網(wǎng)頁用來查詢成績,給的格式xlxs文件,我一想,思路很簡單:把數(shù)據(jù)轉(zhuǎn)換成數(shù)據(jù)庫

寫個(gè)表單,傳遞查詢學(xué)號(hào)

后臺(tái)用數(shù)據(jù)庫查詢

把網(wǎng)站部署到服務(wù)器上

于是就有….

xlxs 轉(zhuǎn)換成數(shù)據(jù)庫

本身數(shù)據(jù)就沒有多少,所以我決定使用sqlite3,完全夠用,有三種思路:Excel文件另存為csv文件,然后使用sqlite導(dǎo)入 .import data.csv tablename

使用openpyxl庫讀取Excel文件,然后逐條插入到數(shù)據(jù)庫中

但我google發(fā)現(xiàn)了一個(gè)xls2db的庫,使用兩行代碼進(jìn)行轉(zhuǎn)換 from xls2db import xls2db xls2db("data.xlxs","student.db")

flask 表單,路由

因?yàn)楦杏X比較簡單,所以決定嘗試一下flask,而不是用servlet。(因?yàn)閖ava環(huán)境不想裝了)

query_score/

.

|-- 1.xlsx

|-- __pycache__

|-- app

|-- config.py

|-- config.pyc

|-- index.py

|-- query_score.wsgi

|-- requirements.txt

`-- student.db

目錄結(jié)構(gòu)大致就是這個(gè)樣子,主要的代碼都存放在 app 文件夾下,代碼暫且不表

參考教程

flask 的運(yùn)行主要在與調(diào)用 app.run(), app 是我們創(chuàng)建的一個(gè) Flask 對(duì)象。所以我們可以這樣運(yùn)行:在 index.py 中的寫入 from app import app 這里的第一個(gè)app,表示的是 app目錄,在Python中,目錄中帶有 __init__.py 文件夾就可以被調(diào)用,第二個(gè)app,是我們?cè)?__init__.py 中創(chuàng)建的 app 實(shí)例 from flask import Flask app=Flask(__name__),最后設(shè)置環(huán)境變量 export FLASK_APP=index.py ,然后運(yùn)行flask run 就Ok了

要么在 index.py 中寫入 if __name__=='__main__': app.run(),然后使用python index.py進(jìn)行運(yùn)行

我們需要清楚的是只要我們像運(yùn)行整個(gè)網(wǎng)站,一定要調(diào)用 Flask 實(shí)例的 run 方法

這一部分真的很簡單,多調(diào)試即可(況且我是新學(xué)233)

數(shù)據(jù)庫查詢

sqlite3 數(shù)據(jù)庫查詢:打開數(shù)據(jù)庫

執(zhí)行數(shù)據(jù)庫查詢語句

遍歷查詢的結(jié)果列表,處理成字典,返回(字典我用了有序字典,否則的話,最后遍歷的時(shí)候,順序是按照優(yōu)化的存儲(chǔ)順序,字典理論上應(yīng)該是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:

#處理數(shù)據(jù) result=OrderedDict()

for item,num in enumerate(c):

result[col_name[num]]=item

return result

在總結(jié)的時(shí)候我突然想起來,這種拼接sql語句的方法可能會(huì)造成 sql injection(( ̄▽ ̄)~*) 然而,我測試的時(shí)候,并沒有出現(xiàn),因?yàn)槲以诮獍?cur的時(shí)候,默認(rèn)認(rèn)為只有一條數(shù)據(jù)(查詢的時(shí)候可不是一人一條嘛),所以處理完第一條數(shù)據(jù),直接返回了2333,但還是推薦一下這種sql 語句格式化的方法:

....

cur=db.execute("select * from Sheet1 where stuno=?",(stuno))

....

部署到服務(wù)器上

頭大的一批。。。。

因?yàn)槲铱吹酱蠖鄶?shù)老哥都是用了 virtualenv來配置環(huán)境,但我頭比較鐵,直接使用了全局環(huán)境,最后還是慫了。。。。

大多數(shù)過程參考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

一個(gè)小技巧,偶然間想起來的 tail -f /var/log/apache2/error.log 這樣會(huì)一直維持著查看apache2的錯(cuò)誤日志

所以我們可以開兩個(gè)ssh 連接,一個(gè)修改代碼,一個(gè)看日志

大多數(shù)教程網(wǎng)上都有,不再贅述,只做一點(diǎn)經(jīng)驗(yàn)總結(jié):python3 和 python2 使用的 wsgi 是不一樣的。因?yàn)樵诓渴鸬絘pache2上時(shí),使用的不是 python 解釋器程序,而是使用mod_wsgi模塊進(jìn)行運(yùn)行,所有的庫都是通過它運(yùn)行的,所以mod_wsgi的版本和python庫的版本一定要一樣

有可能出現(xiàn)部分庫無法導(dǎo)入的問題(importerror),(因?yàn)橛锌赡苡袃商譸ython 環(huán)境 2.7 3.5),首先卸載2.7的庫(或者全部卸載),然后重新使用python3(因?yàn)槲矣玫氖莗ython3)的pip3進(jìn)行安裝 參考

建議使用pip的時(shí)候,最好通過 python -m pip ... python3 -m pip ,這樣不會(huì)亂,因?yàn)樵谖业闹鳈C(jī)上,我發(fā)現(xiàn)pip 居然莫名其妙變成python3的了..

sqlite數(shù)據(jù)庫打開的時(shí)候會(huì)生成一個(gè)lockfile,用來保證數(shù)據(jù)庫的一致性,所以運(yùn)行需要有數(shù)據(jù)庫文件所在目錄寫權(quán)限,實(shí)在不行使用root運(yùn)行apache

使用virtualenv的時(shí)候那個(gè) activate_this.py 不在python 虛擬環(huán)境下面,到github下下載,或者在virtualenv包下面找都行

修改了自定義的 /etc/apache2/sites-available/myconf.conf 有可能因?yàn)榕渲梦募徽_導(dǎo)致apache2 無法重啟啟動(dòng)/關(guān)閉/報(bào)錯(cuò),會(huì)提醒你使用systemctl status apache2.service 或者 journalctl -xe 好看apache2 詳細(xì)信息,其實(shí)可以使用 apache2ctl configtest檢查配置文件的錯(cuò)誤,指定定位到行,方便改正。

總結(jié)

以上是生活随笔為你收集整理的apache 部署python3_flask+apache2+wsgi+python3 部署(挖坑记)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。