Python 全栈系列245 nginx 前端web页面透传

2024-05-13 07:12

本文主要是介绍Python 全栈系列245 nginx 前端web页面透传,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

说明

过去的几年,我已经构造了很多组件,从图的角度来看,完成了很多点。这些点的单点测试看起来都不错,但是因为没有连起来,所以无法体现系统价值。好比发动机的马力虽然大,但是没有传动轴,那就没法用起来。

所以今年,虽然我还是会继续增加一些新的点,或者对某些点进行迭代,但是更重要的是将已有的点,连起来,完成系统功能。

内容

1 主要配置

1.1 基础部分

先配置了nginx监听端口。因为是容器启动的,所以端口实际上会透到宿主机的某个端口

events {#设置工作模式为epoll,除此之外还有select,poll,kqueue,rtsig和/dev/poll模式use epoll;#定义每个进程的最大连接数,受系统进程的最大打开文件数量限制worker_connections  1024;
}http {server {listen       80;server_name  172.17.0.1;include mime.types;#默认文件类型default_type application/octet-stream;#默认编码#charset utf-8;proxy_http_version 1.1;proxy_set_header Host $host;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "upgrade";proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-Proto $scheme;proxy_set_header X-Forwarded-For $http_x_forwarded_for;proxy_set_header X-Forwarded-Port $server_port;proxy_connect_timeout 300;proxy_read_timeout 300;proxy_send_timeout 300;client_max_body_size 1024M;client_body_buffer_size 8192k;

被转发的服务配置配置

1.1 转发web服务

        location /summarizer/ {include /etc/nginx/mime.types;proxy_connect_timeout 60;proxy_read_timeout 60;proxy_send_timeout 60;proxy_intercept_errors off;proxy_http_version 1.1;proxy_set_header Host $http_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;proxy_pass http://172.17.0.1:24509/;}location .*summarizer.*\.(js|css)?$ {proxy_pass http://172.17.0.1:24509/;expires 7d;access_log off;}

1.2 转发API服务

	location /ent_api/ {proxy_pass http://192.168.0.4:24103/parse_ent/;proxy_set_header X-Forwarded-For  $proxy_add_x_forwarded_for;proxy_set_header Host $http_host;proxy_redirect off;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "upgrade";}

2 实验

m4是我的一台主机,基本不承担计算任务。64G内存,除了1T系统盘,还挂载了2T的固态硬盘(致钛Ti5100)和16T的机械硬盘(西数),所以很适合用于做一些IO方面的任务。

微服务:m4_web_nginx_24107

这个微服务将集中提供cn001内的服务, 各算网机可以统一把配置放在 mkdir -p /home/nginx_confs下面,配置名称对应于nginx微服务名称。

微服务带来的好处包括:

  • 1 不必频繁修改frpc。一方面减少了端口的使用,也避免手误,导致机器连接中断。
  • 2 配置集中化。通过配置的集中化,我们可以很清楚有多少服务可用,以及它们之间的关联( “边” )

具体的目标:

  • 1 使用streamlit 建立一个导航网站,这个网站将固化可用的前后端微服务
  • 2 将一个较为稳定的微服务挪到这个网站下

从长期来看,在本地的streamlit 上构建原型,一旦成熟后,就将其发布为服务。

2.1 nginx 配置及启动

配置

└─ $ cat m4_web_nginx_24107.conf
events {#设置工作模式为epoll,除此之外还有select,poll,kqueue,rtsig和/dev/poll模式use epoll;#定义每个进程的最大连接数,受系统进程的最大打开文件数量限制worker_connections  1024;
}http {server {listen       80;server_name  172.17.0.1;include mime.types;#默认文件类型default_type application/octet-stream;#默认编码#charset utf-8;proxy_http_version 1.1;proxy_set_header Host $host;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "upgrade";proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-Proto $scheme;proxy_set_header X-Forwarded-For $http_x_forwarded_for;proxy_set_header X-Forwarded-Port $server_port;proxy_connect_timeout 300;proxy_read_timeout 300;proxy_send_timeout 300;client_max_body_size 1024M;client_body_buffer_size 8192k;location /portal/ {proxy_pass http://172.17.0.1:24108/;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header Host $http_host;proxy_redirect off;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "upgrade";}}
}

启动

docker run -d \--restart=always \--name=m4_web_nginx_24107 \-v /etc/localtime:/etc/localtime  \-v /etc/timezone:/etc/timezone\-v /etc/hostname:/etc/hostname\-e "LANG=C.UTF-8" \-p 24107:80\-v /home/nginx_confs/m4_web_nginx_24107.conf:/etc/nginx/nginx.conf \registry.cn-hangzhou.aliyuncs.com/andy08008/nginx:v1

2.2 portal 配置及启动(样例)

portal

ms_24108_portal_web.py

import streamlit as st
import requests as req 
import ast
# 设置全局属性
st.set_page_config(page_title='我的规则',page_icon=' ',layout='wide')def intro():import streamlit as stst.sidebar.success("选择一个规范")st.write("# 确保规范化的应用")page_names_to_funcs = {"介绍": intro,}demo_name = st.sidebar.selectbox("Choose a function", page_names_to_funcs.keys())
page_names_to_funcs[demo_name]()

启动命令

docker run -d \--restart=always \--name=ms_24108_portal_web \-v /etc/localtime:/etc/localtime -v /etc/timezone:/etc/timezone -v /etc/hostname:/etc/hostname -e "LANG=C.UTF-8" -w /workspace \-v /opt/aprojects/cn001_micro_services/ms_24108_portal_web.py:/workspace/ms_24108_portal_web.py \-p 24108:8000 \myregistry.domain.com:24052/server.andy.cn001_micro_services:v100 \sh -c "streamlit run ms_24108_portal_web.py  --server.port 8000"

效果
在这里插入图片描述

这篇关于Python 全栈系列245 nginx 前端web页面透传的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/985028

相关文章

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

在React中引入Tailwind CSS的完整指南

《在React中引入TailwindCSS的完整指南》在现代前端开发中,使用UI库可以显著提高开发效率,TailwindCSS是一个功能类优先的CSS框架,本文将详细介绍如何在Reac... 目录前言一、Tailwind css 简介二、创建 React 项目使用 Create React App 创建项目

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优