让 Python 脚本在后台持续运行:架构级解决方案与工业级实践指南
让 Python 脚本在后台持续运行:架构级解决方案与工业级实践指南
一、生产环境需求全景分析
1.1 后台进程的工业级要求矩阵
维度 | 开发环境要求 | 生产环境要求 | 容灾要求 |
---|---|---|---|
可靠性 | 单点运行 | 集群部署 | 跨机房容灾 |
可观测性 | 控制台输出 | 集中式日志 | 分布式追踪 |
资源管理 | 无限制 | CPU/Memory限制 | 动态资源调度 |
生命周期管理 | 手动启停 | 自动拉起 | 滚动升级 |
安全性 | 普通权限 | 最小权限原则 | 安全沙箱 |
1.2 典型应用场景分析
- IoT 数据采集:7x24 小时运行,断线重连,资源受限环境
- 金融交易系统:亚毫秒级延迟,零容忍的进程中断
- AI 训练任务:GPU 资源管理,长时间运行保障
- Web 服务:高并发处理,优雅启停机制
二、进阶进程管理方案
2.1 使用 Supervisor 专业管理
架构原理:
+---------------------+
| Supervisor Daemon |
+----------+----------+|| 管理子进程
+----------v----------+
| Managed Process |
| (Python Script) |
+---------------------+
配置示例(/etc/supervisor/conf.d/webapi.conf):
[program:webapi]
command=/opt/venv/bin/python /app/main.py
directory=/app
user=appuser
autostart=true
autorestart=true
startsecs=3
startretries=5stdout_logfile=/var/log/webapi.out.log
stdout_logfile_maxbytes=50MB
stdout_logfile_backups=10stderr_logfile=/var/log/webapi.err.log
stderr_logfile_maxbytes=50MB
stderr_logfile_backups=10environment=PYTHONPATH="/app",PRODUCTION="1"
核心功能:
- 进程异常退出自动重启
- 日志轮转管理
- 资源使用监控
- Web UI 管理界面
- 事件通知(邮件/Slack)
2.2 Kubernetes 容器化部署
Deployment 配置示例:
apiVersion: apps/v1
kind: Deployment
metadata:name: data-processor
spec:replicas: 3selector:matchLabels:app: data-processortemplate:metadata:labels:app: data-processorspec:containers:- name: mainimage: registry.example.com/data-processor:v1.2.3resources:limits:cpu: "2"memory: 4Girequests:cpu: "1"memory: 2GilivenessProbe:exec:command: ["python", "/app/healthcheck.py"]initialDelaySeconds: 30periodSeconds: 10readinessProbe:httpGet:path: /healthport: 8080volumeMounts:- name: config-volumemountPath: /app/configvolumes:- name: config-volumeconfigMap:name: app-config
关键优势:
- 自动水平扩展
- 滚动更新策略
- 自我修复机制
- 资源隔离保障
- 跨节点调度能力
三、高可用架构设计
3.1 多活架构实现
# 分布式锁示例(Redis实现)
import redis
from redis.lock import Lockclass HAWorker:def __init__(self):self.redis = redis.Redis(host='redis-cluster', port=6379)self.lock_name = "task:processor:lock"def run(self):while True:with Lock(self.redis, self.lock_name, timeout=30, blocking_timeout=5):self.process_data()time.sleep(1)def process_data(self):# 核心业务逻辑pass
3.2 心跳检测机制
# 基于Prometheus的存活检测
from prometheus_client import start_http_server, Gaugeclass HeartbeatMonitor:def __init__(self, port=9000):self.heartbeat = Gauge('app_heartbeat', 'Last successful heartbeat')start_http_server(port)def update(self):self.heartbeat.set_to_current_time()# 在业务代码中集成
monitor = HeartbeatMonitor()
while True:process_data()monitor.update()time.sleep(60)
四、高级运维技巧
4.1 日志管理方案对比
方案 | 采集方式 | 查询性能 | 存储成本 | 适用场景 |
---|---|---|---|---|
ELK Stack | Logstash | 高 | 高 | 大数据量分析 |
Loki+Promtail | Promtail | 中 | 低 | Kubernetes 环境 |
Splunk | Universal FW | 极高 | 极高 | 企业级安全审计 |
Graylog | Syslog | 中 | 中 | 中型企业 |
4.2 性能优化指标监控
# 使用psutil进行资源监控
import psutildef monitor_resources():return {"cpu_percent": psutil.cpu_percent(interval=1),"memory_used": psutil.virtual_memory().used / 1024**3,"disk_io": psutil.disk_io_counters().read_bytes,"network_io": psutil.net_io_counters().bytes_sent}# 集成到Prometheus exporter
from prometheus_client import Gaugecpu_gauge = Gauge('app_cpu_usage', 'CPU usage percentage')
mem_gauge = Gauge('app_memory_usage', 'Memory usage in GB')def update_metrics():metrics = monitor_resources()cpu_gauge.set(metrics['cpu_percent'])mem_gauge.set(metrics['memory_used'])
五、安全加固实践
5.1 最小权限原则实施
# 创建专用用户
sudo useradd -r -s /bin/false appuser# 设置文件权限
sudo chown -R appuser:appgroup /opt/app
sudo chmod 750 /opt/app# 使用capabilities替代root
sudo setcap CAP_NET_BIND_SERVICE=+eip /opt/venv/bin/python
5.2 安全沙箱配置
# 使用seccomp限制系统调用
import prctldef enable_sandbox():# 禁止fork新进程prctl.set_child_subreaper(1)prctl.set_no_new_privs(1)# 限制危险系统调用from seccomp import SyscallFilter, ALLOW, KILLfilter = SyscallFilter(defaction=KILL)filter.add_rule(ALLOW, "read")filter.add_rule(ALLOW, "write")filter.add_rule(ALLOW, "poll")filter.load()
六、灾备与恢复策略
6.1 状态持久化方案
# 基于检查点的状态恢复
import pickle
from datetime import datetimeclass StateManager:def __init__(self):self.state_file = "/var/run/app_state.pkl"def save_state(self, data):with open(self.state_file, 'wb') as f:pickle.dump({'timestamp': datetime.now(),'data': data}, f)def load_state(self):try:with open(self.state_file, 'rb') as f:return pickle.load(f)except FileNotFoundError:return None# 在业务逻辑中集成
state_mgr = StateManager()
last_state = state_mgr.load_state()while True:process_data(last_state)state_mgr.save_state(current_state)time.sleep(60)
6.2 跨地域容灾部署
# AWS多区域部署示例
resource "aws_instance" "app_east" {provider = aws.us-east-1ami = "ami-0c55b159cbfafe1f0"instance_type = "t3.large"count = 3
}resource "aws_instance" "app_west" {provider = aws.us-west-2ami = "ami-0c55b159cbfafe1f0"instance_type = "t3.large"count = 2
}resource "aws_route53_record" "app" {zone_id = var.dns_zonename = "app.example.com"type = "CNAME"ttl = "300"records = [aws_lb.app_east.dns_name,aws_lb.app_west.dns_name]
}
七、性能调优实战
7.1 内存优化技巧
# 使用__slots__减少内存占用
class DataPoint:__slots__ = ['timestamp', 'value', 'quality']def __init__(self, ts, val, q):self.timestamp = tsself.value = valself.quality = q# 使用memory_profiler分析
@profile
def process_data():data = [DataPoint(i, i*0.5, 1) for i in range(1000000)]return sum(d.value for d in data)
7.2 CPU 密集型任务优化
# 使用Cython加速
# File: fastmath.pyx
cimport cython@cython.boundscheck(False)
@cython.wraparound(False)
def calculate(double[:] array):cdef double total = 0.0cdef int ifor i in range(array.shape[0]):total += array[i] ** 2return total# 使用multiprocessing并行
from multiprocessing import Pooldef parallel_process(data_chunks):with Pool(processes=8) as pool:results = pool.map(process_chunk, data_chunks)return sum(results)
八、未来演进方向
8.1 无服务器架构转型
# AWS Lambda函数示例
import boto3def lambda_handler(event, context):s3 = boto3.client('s3')# 处理S3事件for record in event['Records']:bucket = record['s3']['bucket']['name']key = record['s3']['object']['key']# 执行处理逻辑process_file(bucket, key)return {'statusCode': 200,'body': 'Processing completed'}
8.2 智能运维体系构建
# 基于机器学习异常检测
from sklearn.ensemble import IsolationForestclass AnomalyDetector:def __init__(self):self.model = IsolationForest(contamination=0.01)def train(self, metrics_data):self.model.fit(metrics_data)def predict(self, current_metrics):return self.model.predict([current_metrics])[0]# 集成到监控系统
detector = AnomalyDetector()
detector.train(historical_metrics)current = collect_metrics()
if detector.predict(current) == -1:trigger_alert()
九、行业最佳实践总结
- 金融行业:采用双活架构,RTO<30秒,RPO=0
- 电商系统:弹性扩缩容设计,应对流量洪峰
- 物联网平台:边缘计算+云端协同架构
- AI平台:GPU资源共享调度,抢占式任务管理
“系统可靠性不是某个单点特性,而是从架构设计到运维实践的完整体系。” —— Google SRE 实践手册
通过本文介绍的从基础到架构级的解决方案,开发者可以根据业务场景需求,选择适合的后台运行方案,并构建具备工业级可靠性的 Python 应用系统。
相关文章:
让 Python 脚本在后台持续运行:架构级解决方案与工业级实践指南
让 Python 脚本在后台持续运行:架构级解决方案与工业级实践指南 一、生产环境需求全景分析 1.1 后台进程的工业级要求矩阵 维度开发环境要求生产环境要求容灾要求可靠性单点运行集群部署跨机房容灾可观测性控制台输出集中式日志分布式追踪资源管理无限制CPU/Memo…...
设计模式 四、行为设计模式(2)
五、状态模式 1、概述 状态设计模式是一种行为型设计模式,它允许对象在其内部状态发生时改变其行为,这种模式可以消除大量的条件语句,并将每个状态的行为封装到单独的类中。 状态模式的主要组成部分如下: 1)上…...
C++中作用域(public,private,protected
在C中,public、private 和 protected 是用于控制类成员(变量和函数)访问权限的关键字。它们决定了类成员在代码中的可见性和可访问性。在学习时候,对于public是最容易理解的,对于private也好理解,但是对于p…...
Spring配置方式演进:从XML到注解,构建灵活高效的开发体系
Spring配置方式演进:从XML到注解,构建灵活高效的开发体系 在Spring框架的演进长河中,配置方式始终是开发者需要掌握的核心技能。从早期XML一统天下的严谨规范,到注解驱动的敏捷开发,再到如今Java Config的优雅实践&am…...
网络4 OSI7层
OSI七层模型:数据如何传送,向下传送变成了什么样子 应用层 和用户打交道,向用户提供服务。 例如:web服务、http协议、FTP协议 1.用户接口 2.提供各种服务 通过浏览器(接口)提供Web服务 表示层 翻译 我的“…...
前端请求设置credentials: ‘include‘导致的cors问题
1.背景 前端请求设置credentials: ‘include‘其实主要是为了发送凭证,传cookie给后端 2.前端请求 fetch(http://frontend.com, { method: GET, // 或其他HTTP方法 credentials: include, // 不携带凭证 headers: { Content-Type: application/json, }, })…...
LabVIEW中VI Scripting 特定对象解析
该 LabVIEW 程序通过三条并行代码路径,借助 VI Scripting 功能,以特定方式解析程序框图对象,展示了不同方法在处理对象嵌套及特定范围对象时的差异。 上方文字:三条并行代码路径展示了解析程序框图的不同方式。第一条路径使用 …...
CISCO组建RIP V2路由网络
1.实验准备: 2.具体配置: 2.1根据分配好的IP地址配置静态IP: 2.1.1PC配置: PC0: PC1: PC2: 2.1.2路由器配置: R0: Router>en Router#conf t Enter configuration…...
性能飙升50%,react-virtualized-list如何优化大数据集滚动渲染
在处理大规模数据集渲染时,前端性能常常面临巨大的挑战。本文将探讨 react-virtualized-list 库如何通过虚拟化技术和 Intersection Observer API,实现前端渲染性能飙升 50% 的突破!除此之外,我们一同探究下该库还支持哪些新的特性…...
超低功耗MCU软件开发设计中的要点与选型推荐
前沿-超低功耗MCU应用: 超低功耗MCU(微控制器)凭借其极低的功耗和高效的能量管理能力,正在快速渗透到多个新兴领域,尤其在物联网(IoT)、可穿戴设备、智能家居和医疗电子等领域展现出巨大的应用…...
Gson、Fastjson 和 Jackson 对比解析
目录 1. Gson (Google) 基本介绍: 核心功能: 特点: 使用场景: 2. Fastjson (Alibaba) 基本介绍: 核心功能: 特点: 使用场景: 3. Jackson 基本介绍: 核心功能…...
冒泡排序与回调函数——qsort
文章核心内容总结 本文围绕数组排序展开,先介绍了冒泡排序,后引入qsort库函数进行排序,并对二者进行了对比。 1. 冒泡排序实现 在探讨冒泡排序(Bubble Sort)这一经典的排序算法时,我们首先需要了解其基本…...
(四)机器学习---逻辑回归及其Python实现
之前我们提到了常见的任务和算法,本篇我们使用逻辑回归来进行分类 分类问题回归问题聚类问题各种复杂问题决策树√线性回归√K-means√神经网络√逻辑回归√岭回归密度聚类深度学习√集成学习√Lasso回归谱聚类条件随机场贝叶斯层次聚类隐马尔可夫模型支持向量机高…...
微信小程序开发:微信小程序上线发布与后续维护
微信小程序上线发布与后续维护研究 摘要 微信小程序作为移动互联网的重要组成部分,其上线发布与后续维护是确保其稳定运行和持续优化的关键环节。本文从研究学者的角度出发,详细探讨了微信小程序的上线发布流程、后续维护策略以及数据分析与用户反馈处理的方法。通过结合实…...
vue拓扑图组件
vue拓扑图组件 介绍技术栈功能特性快速开始安装依赖开发调试构建部署 使用示例演示截图组件源码 介绍 一个基于 Vue3 的拓扑图组件,具有以下特点: 1.基于 vue-flow 实现,提供流畅的拓扑图展示体验 2.支持传入 JSON 对象自动生成拓扑结构 3.自…...
Python数据分析-NumPy模块-查看数组属性
查看数组的行数和列数 from numpy import array aarray([[1,1],[2,2],[3,3]]) print(a.shape)结果: 提取数组的行数或列数 from numpy import array aarray([[1,1],[2,2],[3,3]]) print(a.shape) print(a.shape[0]) print(a.shape[1])结果: 查看数组…...
ch07课堂参考代码
DFS 的优化 1) 标记搜索过的状态 用数组标记一个状态是否被搜索过,搜索过则直接 return,不用再执行函数,用于保证每个状态只被搜索一次。 在递归调用函数之前,通过 if (vis[x]) 判断 x 是否被搜索过,搜索过则直接ret…...
去重新闻数据中重复的正文内容(body 字段),并把唯一的新闻内容保存到一个新的 JSON 文件中
示例代码: import os import json import nltk from tqdm import tqdmdef wr_dict(filename,dic):if not os.path.isfile(filename):data []data.append(dic)with open(filename, w) as f:json.dump(data, f)else: with open(filename, r) as f:data json.l…...
centos crontab 设置定时任务访问链接
在 CentOS 系统中,使用 crontab 设置定时任务访问 URL,可以通过命令行工具(如 curl 或 wget)发送 HTTP 请求。以下是详细步骤: 1、安装必要工具(若未安装) 安装 curl 或 wget # 安装 curl su…...
oracle大师认证证书有用吗
专业能力的高度认可:OCM 是 Oracle认证的最高级别,是对数据库从业人员技术、知识和操作技能的最高级认可,也是 IT 界顶级认证之一。它表明持证者具备处理关键业务数据库系统和应用的能力,能够解决最困难的技术难题和最复杂的系统故…...
说说对 Node 中的 process 的理解?有哪些常用方法?
1. 简介 process对象是Node.js中的全局变量,它提供了有关当前Node.js进程的信息并允许对其进行控制。通过process对象,我们可以获取进程的环境变量、命令行参数,控制进程的行为以及与其他进程进行通信。 2. 常用属性 process.env process…...
maven 和 idea intej步骤记录
1 maven 安装配置 1.1 参考链接安装 maven参考链接 1.2 maven 关联本机jdk版本 配置 priofiles jdk 版本时,查看本本机jdk 版本:环境变量查看jdk 路径版本: java_home 变量路径是C:\Program Files\Java\jdk-21 # setting.xml <profile&…...
Java Socket编程从零到实战详解
摩西摩西~最近接单子用到了Java的socket编程,顺手给整理下来咯! 各个语言的socket编程除了语法之外几乎思路都是一样的。 所以这些思路都是可以直接移植到其他语言实现的! 话不多说上车! 一、Socket基础概念与工作流程…...
STM32中Hz和时间的转换
目录 一、常见的频率单位及其转换 二、计算公式 三、STM32中定时器的应用 四、例子 一、常见的频率单位及其转换 赫兹(Hz)是频率的国际单位,表示每秒钟周期性事件发生的次数。 1 kHz(千赫兹) 1,000 Hz1 MHz&#…...
Apache Hive学习教程
什么是Hive? Apache Hive是一款建立在Hadoop之上的开源数据仓库系统,可以将存储在Hadoop文件中的结构化、半结构化 数据文件映射为一张数据库表,基于表提供了一种类似SQL的查询模型,称为Hive查询语言(HQL)&…...
学习笔记六——Rust 切片全解析
这篇文章不是告诉你“切片是啥”,而是让你真正理解并学会用切片,同时还会把你最容易卡壳的 {:?}、char_indices() 等都讲清楚! 📚 文章目录 切片到底是什么?能不能通俗一点?切片的本质:它其实…...
Apache Doris SelectDB 技术能力全面解析
Apache Doris 是一款开源的 MPP 数据库,以其优异的分析性能著称,被各行各业广泛应用在实时数据分析、湖仓融合分析、日志与可观测性分析、湖仓构建等场景。Apache Doris 目前被 5000 多家中大型的企业深度应用在生产系统中,包含互联网、金融、…...
设计模式 Day 8:策略模式(Strategy Pattern)完整讲解与实战应用
🔄 前情回顾:Day 7 重点回顾 在 Day 7 中,我们彻底讲透了观察者模式: 它是典型的行为型模式,核心理念是“一变多知”,当一个对象状态变化时,自动通知所有订阅者。 我们通过 RxCpp 实现了工业…...
HarmonyOS-ArkUI V2装饰器-@Once
前文,关于Param的使用: HarmonyOS-ArkUIV2装饰器-Param:组件外部输入-CSDN博客 Once装饰器是一个需要配合Param装饰器一块使用的的装饰器。它的特性是,仅仅在变量进行初始化的时候,接受一个外部传来的值进行初始化&am…...
前端Node.js的包管理工具npm指令
npm(Node Package Manager)是Node.js的包管理工具,主要用于安装、更新、删除和管理JavaScript包。以下是前端开发中常用的npm命令及其用途: 基本命令 npm提供了一系列命令行工具,用于执行各种包管理操作。以下是一…...
本地搭建直播录屏应用并实现使用浏览器远程控制直播间录屏详细教程
 本文主要介绍如何在 Windows 系统电脑本地部署直播录屏工具 Bililive-go,并结合 cpolar 内网穿透工具实现远程访问本地 Bililive-go 服务 web 界面管理录屏任务。 相信很多小伙伴都喜欢看直播,不过如果一旦临时有事看不了直播,…...
Hydra Columnar:一个开源的PostgreSQL列式存储引擎
Hydra Columnar 是一个 PostgreSQL 列式存储插件,专为分析型(OLAP)工作负载设计,旨在提升大规模分析查询和批量更新的效率。 Hydra Columnar 以扩展插件的方式提供,主要特点包括: 采用列式存储,…...
OpenGL学习笔记(assimp封装、深度测试、模板测试)
目录 模型加载Assimp网格模型及导入 深度测试深度值精度深度缓冲的可视化深度冲突 模板测试物体轮廓 GitHub主页:https://github.com/sdpyy1 OpenGL学习仓库:https://github.com/sdpyy1/CppLearn/tree/main/OpenGLtree/main/OpenGL):https://github.com/sdpyy1/CppL…...
自动化备份全网服务器数据平台
1.项目说明 1.1概述 该项目共分为2个子项目,由环境搭建和实施备份两部分组成 该项目旨在复习巩固系统服务部署使用、shell编程等知识,旨在让学生增加知识面,提高项目实习经历,充实简历 1.2项目组织方式及时间 时间:…...
Trea CN多多与主流AI编程工具万字解析
Trea CN多多与主流AI编程工具万字解析 (含数学建模、架构图、开发流程可视化) 一、数学建模:代码生成效率量化模型 1.1 全链路效率公式 T total N ⋅ ( 1 λ C S ) T check (1) T_{\text{total}} N \cdot \left( \frac{1}{\lambda} \…...
Django从零搭建卖家中心注册页面实战
在电商系统开发中,卖家中心是一个重要的组成部分,而用户注册与登陆则是卖家中心的第一步。本文将详细介绍如何使用Django框架从零开始搭建一个功能完善的卖家注册页面,包括前端界面设计和后端逻辑实现。 一、项目概述 我们将创建一个名为sel…...
如何进行预算考核
✅ 一、预算考核体系总体架构 模块内容说明考核内容1. 预算目标/指标完成情况2. 预算编制/执行情况双轮驱动,目标 + 执行双考核考核对象高层、中层、基层、后台支持分层分类考核考核周期月度(滚动)+ 季度(校验)+ 年度(决算)提高适应性和准确性考核工具指标体系、差错率评…...
django相关面试题
django相关面试题 1.django的生命周期 2.django中的orm查询如何自定义方法 3.django中的中间件的作用 4.django中间件,request进来经过哪些中间件,顺序是怎么样的 5.django中的csrf是什么 6.django每访问一次数据库都会创建一个连接吗 7.uwsgi gunicorn…...
【Java面试系列】Spring Cloud微服务架构中的分布式事务实现与性能优化详解 - 3-5年Java开发必备知识
【Java面试系列】Spring Cloud微服务架构中的分布式事务实现与性能优化详解 - 3-5年Java开发必备知识 引言 在微服务架构中,分布式事务是一个不可避免的挑战。随着业务复杂度的提升,如何保证跨服务的数据一致性成为面试中的高频问题。本文将从基础到进…...
PostgreSQL 17深度解析(从17.0-17.4)
PostgreSQL 17自2024年9月发布以来,持续通过小版本迭代增强功能、优化性能并修复安全漏洞。本文将从17.0到17.4的每个版本切入,深度解析其新增特性、技术原理、性能提升及实践价值,帮助开发者、DBA及架构师全面掌握PostgreSQL 17的演进脉络。 一、PostgreSQL 17.0:基石奠定…...
人物4_Japanese
Now, I start my JaPan【Tokyo】 life, 【I go out of my country{China}, the reason is I want learn more new computer technologies in foreign, also it could let me know more different culture.】I like the place and most persons in here. The JaPan culture have…...
Go 语言中的 package main、 func main() 和main.go的使用规范
本文旨在解释 Go 语言中 package main 、 func main() 和main.go的关系及其使用规则,解决如下典型问题: 是否可以在一个项目中定义多个 func main()?是否可以在非 package main 中写 func main()?多个文件中都写 func main() 会冲…...
mac 终端 code 命令打开 vscode,修改 cursor占用
rm /usr/local/bin/code vim ~/.zshrc # 定义 cursor 函数,用于打开 Cursor 应用 function cursor {open -a "/Applications/Cursor.app" "$" }# 定义 code 函数,用于打开 Visual Studio Code function code {open -a "/Appli…...
【常用功能】下载文件和复制到剪切板
前言 前端人员在开发时经常会遇到: 后端给一个地址,需要去下载的需求。将页面的内容复制到剪切板 下载文件 我们先说下载文件,通常情况下我们会自己写上一个非常简单的工具函数。 思路如下: 创建一个a元素设置a元素跳转的链接…...
【ESP32-microros(vscode-Platformio)】
一、步骤 1、目前支持ESP32 2、同一个局域网 3、上位机要安装代理(电脑或者linux设备) 4、可直接通过USB下载,也可以使用官方烧录工具,具体的分区表地址要从USB烧录的时候日志查看,一共四个文件,第三个…...
如何使用AI辅助开发CSS3 - 通义灵码功能全解析
一、引言 CSS3 作为最新的 CSS 标准,引入了众多新特性,如弹性布局、网格布局等,极大地丰富了网页样式的设计能力。然而,CSS3 的样式规则繁多,记忆所有规则对于开发者来说几乎是不可能的任务。在实际开发中,…...
OpenCV图像形态学详解
文章目录 一、什么是图像形态学?二、基本概念:结构元素三、基本形态学操作1. 腐蚀(Erosion)2. 膨胀(Dilation)3. 开运算(Opening)4. 闭运算(Closing) 四、高级…...
Java-servlet(完结篇)过滤器乱码解决与监听器
Java-servlet(完结篇)过滤器乱码解决与监听器 前言一、过滤器乱码解决二、监听器1. HttpSessionListener2. ServletContextListener3. ServletRequestListener 三、监听器的使用场景Java-servlet 结语 前言 在之前的 Java Servlet 学习中,我…...
【发布】dtns协议的js-sdk(实现a2a协议:agent2agent)
【发布】dtns协议的js-sdk(实现a2a协议:agent2agent) dtns协议简介 dtns协议是用于dtns.network分布式智体网络的通讯协议。主要目标是将各个独立的智体节点,通过dtns协议(dtns.network)连接在一起&#…...
深度学习总结(8)
模型工作流程 模型由许多层链接在一起组成,并将输入数据映射为预测值。随后,损失函数将这些预测值与目标值进行比较,得到一个损失值,用于衡量模型预测值与预期结果之间的匹配程度。优化器将利用这个损失值来更新模型权重。 下面是…...