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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss