我的网站上PHP写的,但是我的爬虫和人工智能项目使用python写的,那么如何将两种项目同时运行,文章介绍了如何通过Nginx配置实现PHP网站对Python(Flask+WSGI)项目的流量转发。首先确保Python项目正常运行,然后配置Nginx以新的端口转发请求到Python服务的内网地址,通过域名访问即指向Python应用,简化了不同语言项目间的交互。
搭建Python web flask +wsgi 需要使用wsgi模式 nginx才支持
该模式可以可以参考上一篇文章:python 对接阿里通义万象文生图
开启已经写好的python项目,检查项目是否可以正常运行
/www/wwwroot/Python/myenv/bin/python3 -m flask --app tongyiwxiang run --host=0.0.0.0
data:image/s3,"s3://crabby-images/f60f7/f60f7eb4a4f960f121e55740cfc31fdebdd26a0a" alt=""
浏览器输入http://ip地址:5000/tongyiwanxiang,检查项目是否正常运行
data:image/s3,"s3://crabby-images/9fa6f/9fa6fe0f9d8d09f65f24b8ce911712db211248fd" alt=""
方法一:可以通过宝塔自带的ngnix反向代理,将通过代理域名访问python项目
首先添加一个站点
data:image/s3,"s3://crabby-images/5f712/5f712fb1e375738a3777f94966d99e2f770a581c" alt=""
事先准备一个解析到自己的服务器的域名
data:image/s3,"s3://crabby-images/4f8c0/4f8c003ade8dbf7716453e1cb5c9d1ad9f12464f" alt=""
创建
data:image/s3,"s3://crabby-images/5f04b/5f04be3547c91727493f48cc0bd2a736ac55afdb" alt=""
data:image/s3,"s3://crabby-images/a7523/a7523bd5afe12faa9276e53ca7e626d9a1bad41a" alt=""
data:image/s3,"s3://crabby-images/e47ad/e47adfc0bbba050303d064bfe7c53ae807896838" alt=""
data:image/s3,"s3://crabby-images/c9918/c99180b9af3f8527ce8b96d07df613f8ade3cfd2" alt=""
浏览器输入http://pywstx.zlhdsg.com/tongyiwanxiang测试
data:image/s3,"s3://crabby-images/adb5e/adb5e8586693b73510122062d5025ca1c49b4ad4" alt=""
如果想用https,可以通过宝塔面板申请免费证书
data:image/s3,"s3://crabby-images/1a8e2/1a8e218f1c7012191e99732a87e58e7cab9fc8f1" alt=""
data:image/s3,"s3://crabby-images/fe4c8/fe4c8b602588a8e5f7b53a2f49c903062e470027" alt=""
data:image/s3,"s3://crabby-images/2f112/2f112b7c688f79c6af3132d9132b995415925336" alt=""
浏览器输入https://pywstx.zlhdsg.com/tongyiwanxiang测试
data:image/s3,"s3://crabby-images/5f644/5f64408e84ad14047ded1caa7be0fdb1e5773d54" alt=""
nginx设置反向代理接口超时时间
proxy_read_timeout 600s;
data:image/s3,"s3://crabby-images/163d8/163d8b05ba1696ee520d8f6bc6ab8600bf6e3a88" alt=""
data:image/s3,"s3://crabby-images/e5b46/e5b46a0f7b2c2c4e73315aca9742ecb567d339ad" alt=""
以上为宝塔自带反向代理方式
方式二:如果不使用宝塔可以自己配置ngnix反向代理也是可以的,将上边配置网站关闭
查看ngnix 配置
data:image/s3,"s3://crabby-images/68774/68774e0613deee4f74e8f20a82e26c41298019ff" alt=""
配置文件拉倒底就是我们创建php网站的配置,记录下路径
include /www/wwwroot/ngnix/zhuanfa.conf;
zhuanfa.conf文件放到上方图片箭头文件上方,不然遗留配置会覆盖这个文件
server {
listen 80;
server_name pywstx.zlhdsg.com;
location / {
proxy_pass http://127.0.0.1:5000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
# HTTP反向代理相关配置结束 <<<
access_log /www/wwwlogs/wstx.log;
error_log /www/wwwlogs/wstx.error.log;
}
浏览器输入http://pywstx.zlhdsg.com/tongyiwanxiang测试
data:image/s3,"s3://crabby-images/b97e9/b97e9e39c3f5ed5e583d940d0734de38bf86c1a7" alt=""
如果想用https可以通过配置文件
server {
listen 80;
listen 443 ssl http2 ;
server_name pywstx.zlhdsg.com;
index index.php index.html index.htm default.php default.htm default.html;
root /www/wwwroot/Python/wstx;
#CERT-APPLY-CHECK--START
# 用于SSL证书申请时的文件验证相关配置 -- 请勿删除
include /www/server/panel/vhost/nginx/well-known/pywstx.zlhdsg.com.conf;
#CERT-APPLY-CHECK--END
#SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则
#error_page 404/404.html;
ssl_certificate /www/server/panel/vhost/cert/pywstx.zlhdsg.com/fullchain.pem;
ssl_certificate_key /www/server/panel/vhost/cert/pywstx.zlhdsg.com/privkey.pem;
ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;
ssl_ciphers EECDH+CHACHA20:EECDH+CHACHA20-draft:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5;
ssl_prefer_server_ciphers on;
ssl_session_tickets on;
ssl_session_cache shared:SSL:10m;
ssl_session_timeout 10m;
location / {
proxy_pass http://127.0.0.1:5000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
# HTTP反向代理相关配置结束 <<<
access_log /www/wwwlogs/wstx.log;
error_log /www/wwwlogs/wstx.error.log;
}
ssl_certificate和 ssl_certificate_key 处使用的是宝塔申请的ssl证书文件,也可以用其他证书
浏览器输入https://pywstx.zlhdsg.com/tongyiwanxiang测试
data:image/s3,"s3://crabby-images/bf214/bf2148776ef7b0c8c760853f629b249d73f1784d" alt=""
以上为nginx反向代理目标URL的全部操作