当前位置: 首页 > news >正文

关于`IRIS/Caché`进程内存溢出解决方案

文章目录

  • 关于`IRIS/Caché`进程内存溢出解决方案
    • 描述
    • 原因
    • 相关系统变量
      • `$ZSTORAGE`
      • `$STORAGE`
    • 什么情况下进程内存会变化?
    • 内存不足原理
    • 解决方案

关于 IRIS/Caché进程内存溢出解决方案

描述

IRIS/Caché中,进程内存溢出错误是指一个进程(例如运行中的作业JOB、应用程序或服务)在执行过程中消耗了超过其分配内存限制的内存资源,导致操作系统无法继续为其提供足够的内存空间。这可能会导致进程崩溃、运行缓慢或产生不稳定的行为。

原因

进程内存溢出错误可能由以下情况引起:

  • 内存泄漏:进程中的代码在使用完内存后未正确释放,导致内存逐渐耗尽,最终导致溢出。

  • 大量数据处理:处理大量数据时,如果未及时释放已使用的内存,可能会导致内存耗尽。

  • 递归调用:递归调用未正确终止或控制,可能导致堆栈溢出,最终影响进程的内存。

IRIS/Caché中,会提示<STORE>错误。

相关系统变量

在讲原理之前需要先了解两个系统变量$STORAGE$ZSTORAGE

$ZSTORAGE

$ZSTORAGE包含进程私有内存的最大内存量(以KB为单位)。

USER>w $zs
262144

可以在Portal中更改最大每进程内存(KB)系统配置设置来更改$ZSTORAGE默认值。默认值为262144KB256M,如下截图:

在这里插入图片描述

$STORAGE

$STORAGE返回可用于当前进程中的变量存储的字节数。 $STORAGE的初始值由$ZSTORAGE的值确定,该值是该进程可用的最大内存量。 $ZSTORAGE值(以千字节为单位)越大,$STORAGE值(以字节为单位)越大。但$ZSTORAGE$STORAGE之间的关系不是绝对的1:1

USER>w $s
268313368
USER>w $s/1024
262024.7734375
USER>w $s/1024/1024
255.8835678100585938

什么情况下进程内存会变化?

  • 使用set命令,进程内存$STORAGE会减少。
ClassMethod Store()
{w $s,!s name = "yx"w $s,!s age = 18w $s,!
}

注:可观察到减小的数量为8的倍数。也就是说以字节为单位进行递减。

USER>d ##class(M.Store).Store()
268307096
268307088
268307080
  • 重复局部变量不会减小进程内存$STORAGE
ClassMethod Store1()
{w $s,!s name = "yx"w $s,!s age = 18w $s,!s name = "yx"w $s,!s age = 18w $s,!w name,!w $s,!w age,!w $s,!
}
USER>d ##class(M.Store).Store1()
268306968
268306960
268306952
268306952
268306952
yx
268306952
18
268306952
  • 局部变量名称大小对进程内存$STORAGE没有影响,并不是说变量名称越长所占内存越多。
ClassMethod Store2()
{w $s,!s name = "yx"w $s,!s namenamenamenamenamename = "yx"w $s,!s namenamenamenamenamenamenamenamenamenamenamenamenamenamenamenamenamename = "yx"w $s,!
}
USER>d ##class(M.Store).Store2()
268306968
268306960
268306952
268306944
  • 局部变量所保存的值影响进程内存$STORAGE
ClassMethod Store3()
{w $s,!s name = "yx"w $s,!s name = "yxyxyxyx"w $s,!s name = "yxyxyxyxyxyxyxyx"w $s,!s name = "yxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyx"w $s,!
}

注:可观察到字符串越长,所占用的内存越多。

USER>d ##class(M.Store).Store3()
268306968
268306960
268306936
268306904
268306840
  • 多维数组会影响进程内存$STORAGE,下标越多占用的内存越多。
ClassMethod Store4()
{w $s,!s array(1) = 1w $s,!s array(2) = 2w $s,!s array(3) = "yxyx"w $s,!s array(4) = "yxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyx"w $s,!
}
USER>d ##class(M.Store).Store4()
268306968
268306896
268306888
268306680
268306552
  • 删除局部变量,多维数组,可以使进程内存$STORAGE增加或恢复。
ClassMethod Store5()
{w $s,!s name = "yx"w $s,!s name = "yxyxyxyx"w $s,!k namew "删除局部变量后:" _ $s,!w $s,!s array(1) = 1w $s,!s array(2) = 2w $s,!s array(3) = "yxyx"w $s,!s array(4) = "yxyxyxyxyxyxyxyxyxyxyxyxyxyxyxyx"w $s,!k arrayw "删除多维数组后:" _ $s,!
}
USER>d ##class(M.Store).Store5()
268306968
268306960
268306936
删除局部变量后:268306968
268306968
268306896
268306888
268306680
268306552
删除多维数组后:268306968
  • 使用NEW命令时,$STORAGE会减少。因为N会增加堆栈级别,也就意味发生堆栈级别改变的命令都会使内存减少。
ClassMethod Store6()
{w $s,!nw $s,!nw $s,!nw $s,!
}

注:第一次使用New命令时,减少13336,后续的New命令均减少12228

USER>d ##class(M.Store).Store6()
268306968
268293632
268281344
268269056
  • 块语法IF、ELES、FOR、TRY、CATCH命令不会使用$STORAGE会减少。
ClassMethod Store7()
{w $s,!if 1 {w $s,!if 1 {w $s,!} } else {w $s,!}w $s,!try {w $s,!} catch {w $s,!}w $s,!for {w $s,!b}
}
USER>d ##class(M.Store).Store7()
268288144
268288144
268288144
268288144
268288144
268288144
268288144b^
<BREAK>zStore7+19^M.Store.1
USER 3f2>
  • $STORAGE值不受设置的进程私有Global、与临时Global影响。
ClassMethod Store8()
{w $s,!k ^yxw $s,!k ^||yxw $s,!s ^yx("name") = "yx"w $s,!s ^yx("age") = 18w $s,!s ^||yx("address") = "china"w $s,!s ^||yx("work") = "码农"w $s,!
}
USER>d ##class(M.Store).Store8()
268287376
268287376
268287376
268287376
268287376
268287376
268287376
  • 局部变量字符串长度与进程内存关系, 每增加4个字符会增加8Byte内存空间大小,无论中文英文字符。
ClassMethod Store9()
{w "英文所占内存大小:",!s str = ""w 0 _ " :" _ str _ ":" _$s ,!for i = 1 : 1 : 40 {s str = str _ "x"w i _ " :" _ str _ ":" _$s ,!}w "中文所占内存大小:",!w $s,!s name = "姚"w $s,!s name = "姚鑫"w $s,!s name = "姚鑫姚"w $s,!s name = "姚鑫姚鑫"w $s,!s name = "姚鑫姚鑫姚"w $s,!s name = "姚鑫姚鑫姚鑫"w $s,!s name = "姚鑫姚鑫姚鑫姚"w $s,!s name = "姚鑫姚鑫姚鑫姚鑫"w $s,!s name = "姚鑫姚鑫姚鑫姚鑫姚鑫姚鑫"w $s,!s name = "姚鑫姚鑫姚鑫姚鑫姚鑫姚鑫姚鑫姚鑫"w $s,!
}
USER> d ##class(M.Store).Store9()
英文所占内存大小:
0 ::268311440
1 :x:268311432
2 :xx:268311432
3 :xxx:268311432
4 :xxxx:268311424
5 :xxxxx:268311424
6 :xxxxxx:268311424
7 :xxxxxxx:268311424
8 :xxxxxxxx:268311408
9 :xxxxxxxxx:268311408
10 :xxxxxxxxxx:268311408
11 :xxxxxxxxxxx:268311408
12 :xxxxxxxxxxxx:268311408
13 :xxxxxxxxxxxxx:268311408
14 :xxxxxxxxxxxxxx:268311408
15 :xxxxxxxxxxxxxxx:268311408
16 :xxxxxxxxxxxxxxxx:268311376
17 :xxxxxxxxxxxxxxxxx:268311376
18 :xxxxxxxxxxxxxxxxxx:268311376
19 :xxxxxxxxxxxxxxxxxxx:268311376
20 :xxxxxxxxxxxxxxxxxxxx:268311376
21 :xxxxxxxxxxxxxxxxxxxxx:268311376
22 :xxxxxxxxxxxxxxxxxxxxxx:268311376
23 :xxxxxxxxxxxxxxxxxxxxxxx:268311376
24 :xxxxxxxxxxxxxxxxxxxxxxxx:268311376
25 :xxxxxxxxxxxxxxxxxxxxxxxxx:268311376
26 :xxxxxxxxxxxxxxxxxxxxxxxxxx:268311376
27 :xxxxxxxxxxxxxxxxxxxxxxxxxxx:268311376
28 :xxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311376
29 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311376
30 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311376
31 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311376
32 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311312
33 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311312
34 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311312
35 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311312
36 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311312
37 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311312
38 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311312
39 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311312
40 :xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:268311312
中文所占内存大小:
268311312
268311304
268311304
268311304
268311296
268311296
268311296
268311296
268311280
268311280
268311248

内存不足原理

如上一节所述,我们知道了什么情况下内存会发生变化。这里我们模拟常见内存溢出的一种情况:

在处理大量数据时,使用多维数组用于分类或汇总数据,如果多维数据下标节点越来越多,那么使用的内存会越来越多。如果未及时释放已使用的内存,会导致内存耗尽。示例如下:

ClassMethod Store11()
{for {s yx($i(yx)) = $i(yx)}q $$$OK
}
USER> d ##class(M.Store).Store11()s yx($i(yx)) = $i(yx)^
<STORE>zStore11+2^M.Store.1
USER 3f2>

原理:$STORAGE值可以是正数,也可以是负数。值为零并不表示没有可用存储,但表示存储极度短缺。如果$STORAGE减少到小于或接近与零,则会在某个时刻发生<store>错误。例如,如果$STORAGE减少到40,则为另一个局部变量分配存储可能会由于<store>错误而失败,这表明没有足够的可用存储空间来存储局部变量值或建立新的堆栈级别。

ClassMethod Store11()
{for {s yx($i(yx)) = $i(yx)if ($s < 1000){w $s,!}}q $$$OK
}
USER> d ##class(M.Store).Store11()
216
176
120
64
40s yx($i(yx)) = $i(yx)^
<STORE>zStore11+2^M.Store.1

实际上<STORE>内存错误,可以通过设置陷阱来捕获异常。但是进入陷阱时,并不会主动释放内存。示例如下:

ClassMethod Store12()
{s $zt = "Error"for {s yx($i(yx)) = $i(yx)}q $$$OK
Errors $zt = ""w "内存溢出时内存大小:" _ $s,!q $ze
}
USER> d ##class(M.Store).Store12()
内存溢出时内存大小:440

<store>错误发生并用陷阱进行拦截时,系统会自动为进程提供1MB的额外内存,用与错误处理。系统不会更改$ZSTORAGE的大小,允许$STORAGE进一步进入负数值。示例如下:

在这里插入图片描述

当第一个<store>错误发生时,系统在内部将进程指定为内存不足状态。而在此低内存状态下,该进程可以继续分配内存,并且$STORAGE的值可以继续减少到更低的负数。在此低内存状态下,进程可能会释放一些已分配的内存,从而导致$STORAGE的值上升。因此,$STORAGE的值可以在一个值范围内上升或下降,而不会发出额外的<store>错误。

注:第一个<store>错误提供了一些内存缓冲,允许进程调用诊断、执行磁盘保存、正常退出、释放内存并继续。

注:当发生第一个<store>错误进程会消耗额外的内存。当$STORAGE的值达到-1048576时,会出现第二个<STORE>错误。如果进程发生第二个<STORE>错误,则没有更多的内存可供该进程使用,并且进一步的进程操作将变得不可预测。这个进程会立即终止。

注:如果在陷阱当中发生内存再次溢出,进程是直接关闭的。即使设置了$zt= "",也不管用,这种情况如果陷阱中有记录日志或有解锁操作等,将不会就即使,会发生锁无法即使释放。

如下示例,锁永远也不会得到释放。

ClassMethod Store14()
{s $zt = "Error"w "加锁",!l +^yx("node"):3for {s yx($i(yx)) = $i(yx)}q $$$OK
Errors $zt = ""w "内存溢出时内存大小:" _ $s,!for {s yx($i(yx)) = $i(yx)w $s,!}w "陷阱内存溢出,解锁失败",!l -^yx("node"):3q $ze
}

解决方案

要解决内存不足的问题首先要做到以下几点:

  1. 在使用多维数组时,要设置陷阱进行异常拦截。

  2. 在发生内存溢出时,在陷阱中将多维数据kill删除掉,恢复内存。

  3. 如果发生了二次内存溢出。需要讲多维数组方法声明为单独的方法。用于外层接口调用,进行陷阱二次拦截。

示例如下:

注:$SYSTEM.Process.MemoryAutoExpandStatus()方法可以提示出内存溢出的原因。

模拟二次内存溢出代码如下:

ClassMethod Store14()
{s $zt = "Error"w "加锁",!l +^yx("node"):3for {s yx($i(yx)) = $i(yx)}q $$$OK
Errors $zt = ""w "第一次内存溢出错误:" _ $ze,!w "陷阱错误代码:" _ $SYSTEM.Process.MemoryAutoExpandStatus(),!if ($SYSTEM.Process.MemoryAutoExpandStatus() = 1) {w "1——抛出<STORE>错误,因为进程超过了$ZSTORAGE值,并且没有自动扩展$ZSTORAGE值。",!}b ; 陷阱for {s yx($i(yx)) = $i(yx)w $s,!}w "陷阱内存溢出,解锁失败",!l -^yx("node"):3q $ze
}

基于上述第三点,需要单独的方法去调用,用于外层接口调用,进行陷阱二次拦截。示例如下:

ClassMethod Store15()
{s $zt = "Error"w "开始时内存:"_ $s,!d ..Store14()w "结束时内存:"_ $s,!q $$$OK
Errors $zt = ""w "陷阱中剩余:"_ $s,!w "陷阱错误代码:" _ $SYSTEM.Process.MemoryAutoExpandStatus(),!if ($SYSTEM.Process.MemoryAutoExpandStatus() = 2) {w "2——抛出<STORE>错误,因为进程超过了$ZSTORAGE值,并且$ZSTORAGE值被自动扩展了1M。",!}w "第二次内存溢出错误:" _ $ze,!l -^yx("node"):3w "解锁",!q $ze
}

在这里插入图片描述

根据上图可观察到,在外层陷阱进行拦截到第二次内存溢出错误时,可发现系统为我们自动清理了内存,并将内存恢复到$ZSTORAGE最大值268302712。并且也成功解锁。

注:上面示例是为了解决内存二次溢出的情况,通过这种方式防止进程直接结束,实际上应该在第一次内存溢出时,就应该将多维数组进行kill恢复内存。

注:实际上不应该在陷阱当中写入过多的业务逻辑,导致二次内存溢出。

以上是个人对IRIS/Caché进程内存溢出的一些理解,由于个人能力有限,欢迎大家提出意见,共同交流。

相关文章:

关于`IRIS/Caché`进程内存溢出解决方案

文章目录 关于IRIS/Cach进程内存溢出解决方案 描述原因相关系统变量$ZSTORAGE$STORAGE 什么情况下进程内存会变化&#xff1f;内存不足原理解决方案 关于 IRIS/Cach进程内存溢出解决方案 描述 在IRIS/Cach中&#xff0c;进程内存溢出错误是指一个进程&#xff08;例如运行中的…...

构建Docker容器监控系统(cadvisor+influxDB+grafana)

目录 一、部署 1、安装docker-cd 2、阿里云镜像加速 3、下载组件镜像 4、创建自定义网络 5、创建influxdb容器 6、创建Cadvisor 容器 7、创建granafa容器 一、部署 1、安装docker-cd [rootlocalhost ~]# iptables -F [rootlocalhost ~]# setenforce 0 setenforce: SELi…...

最强自动化测试框架Playwright(17)- 模拟接口

模拟接口 介绍 Web API 通常作为 HTTP 终结点实现。Playwright提供了API来模拟和修改网络流量&#xff0c;包括HTTP和HTTPS。页面所做的任何请求&#xff0c;包括 XHR 和获取请求&#xff0c;都可以被跟踪、修改和模拟。使用Playwright&#xff0c;您还可以使用包含页面发出的…...

Python爬虫——requests_get请求

import requests# ?可加可不加 url http://www.baidu.com/s?headers {Cookie: ,User-Agent: , }data {wd: 北京 } # params 参数 response requests.get(urlurl, paramsdata, headersheaders)content response.text print(content)总结&#xff1a; 参数使用params传递…...

【EI复现】一种建筑集成光储系统规划运行综合优化方法(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…...

C++11 异步与通信之 std::async

概念简介 std::async 异步运行一个函数&#xff0c;将返回值保存在std::future中。 含有2个策略参数&#xff1a; launch::deferred 延迟执行&#xff0c;当调用wait()和get()时&#xff0c;任务才会被运行&#xff0c;且不创建线程&#xff1b;launch::async : 创建线程并执…...

影视站用什么cms好?

影视站是指用于提供电影、电视剧、综艺等视频资源的网站。由于影视站需要频繁更新大量的内容&#xff0c;因此使用一个好的内容管理系统&#xff08;CMS&#xff09;非常重要。以下是几个受欢迎的影视站CMS的介绍。最新下载地址&#xff1a;roulang WordPress WordPress是目前…...

HOT88-乘积最大子数组

leetcode原题链接&#xff1a;乘积最大子数组 题目描述 给你一个整数数组 nums &#xff0c;请你找出数组中乘积最大的非空连续子数组&#xff08;该子数组中至少包含一个数字&#xff09;&#xff0c;并返回该子数组所对应的乘积。测试用例的答案是一个 32-位 整数。子数组 是…...

工博士与纷享销客达成战略合作,开启人工智能领域合作新篇章

近日&#xff0c;工博士与纷享销客在上海正式签署了战略合作协议&#xff0c;正式拉开了双方在人工智能与数字营销领域的合作序幕。这次合作将为双方带来更多机遇和发展空间&#xff0c;并为全球人工智能领域的客户提供更高效、智能的CRM解决方案。 < 双方项目人员合影 >…...

拆解与重构:慕云游首页组件化设计

目录 前言1 项目准备1.1 创建项目目录1.2 搭建项目开发环境 2 项目组件化2.1 在当前环境启动原有项目2.2 顶部组件2.3 幻灯片组件2.4 机酒自由行组件2.5 拆分余下的css文件 3 项目完善3.1 幻灯片组件3.1.1 结构和样式3.1.2 功能实现3.1.3 使用Ajax获取数据3.1.4 加载中组件 3.2…...

刷了3个月的华为OD算法题,刷出感觉了,如洁柔般丝滑,文末送《漫画算法2:小灰的算法进阶》

目录 一、考研二战&#xff0c;入职华为&#xff0c;反向调剂电子科大深圳下面分享一道2023 B卷 朋友抽中题 简易内存池&#xff1a;二、题目描述三、输入描述四、输出描述样例&#xff1a;输出样例&#xff1a; 五、解题思路六、Java算法源码七、效果展示1、输入2、输出3、说明…...

ip转换器哪个好用 ip地址切换器有哪些

在互联网时代&#xff0c;IP转换器成为了实现高效工作的常见工具。而如今&#xff0c;市面上涌现出了众多的IP转换器软件&#xff0c;使得用户在选择时感到困惑。本文将介绍一种深度IP转换器软件&#xff0c;探讨其特点和优势&#xff0c;以及与其他软件相比的差异&#xff0c;…...

【python】爬取豆瓣电影Top250(附源码)

前言 在网络爬虫的开发过程中&#xff0c;经常会遇到需要处理一些反爬机制的情况。其中之一就是网站对于频繁访问的限制&#xff0c;即IP封禁。为了绕过这种限制&#xff0c;我们可以使用代理IP来动态改变请求的来源IP地址。在本篇博客中&#xff0c;将介绍如何使用代理IP的技术…...

35岁职业危机?不存在!体能断崖?不担心

概述 90年&#xff0c;硕士毕业&#xff0c;干了快8年的Java开发工作。现年33岁&#xff0c;再过2年就要35岁。 工作这些年&#xff0c;断断续续也看过不少35岁找不到工作&#xff0c;转行&#xff0c;降薪入职的传闻、案例。 35岁&#xff0c;甚至30岁之后&#xff0c;体能…...

C语言——指针进阶

本章重点 字符指针数组指针指针数组数组传参和指针传参函数指针函数指针数组指向函数指针数组的指针回调函数指针和数组面试题的解析 1. 字符指针 在指针的类型中我们知道有一种指针类型为字符指针 char* int main() { char ch w; char *pc &ch; *pc w; return 0; }…...

heap pwn 入门大全 - 1:glibc heap机制与源码阅读(上)

本文为笔者学习heap pwn时&#xff0c;学习阅读glibc ptmalloc2源码时的笔记&#xff0c;与各位分享。可能存在思维跳跃或错误之处&#xff0c;敬请见谅&#xff0c;欢迎在评论中指出。本文也借用了部分外网和其他前辈的素材图片&#xff0c;向各位表示诚挚的感谢&#xff01;如…...

树莓派RP2040 用Arduino IDE安装和编译

目录 1 Arduino IDE 1.1 IDE下载 1.2 安装 arduino mbed os rp2040 boards 2 编程-烧录固件 2.1 打开点灯示例程序 2.2 选择Raspberry Pi Pico开发板 2.3 编译程序 2.4 烧录程序 2.4.1 Raspberry Pi Pico开发板首次烧录提示失败 2.4.2 解决首次下载失败问题 2.4.2.1…...

云安全攻防(八)之 Docker Remote API 未授权访问逃逸

Docker Remote API 未授权访问逃逸 基础知识 Docker Remote API 是一个取代远程命令行界面&#xff08;rcli&#xff09;的REST API&#xff0c;其默认绑定2375端口&#xff0c;如管理员对其配置不当可导致未授权访问漏洞。攻击者利用 docker client 或者 http 直接请求就可以…...

2023-08-13 LeetCode每日一题(合并两个有序数组)

2023-08-13每日一题 一、题目编号 88. 合并两个有序数组二、题目链接 点击跳转到题目位置 三、题目描述 给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2&#xff0c;另有两个整数 m 和 n &#xff0c;分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 …...

nbcio-boot升级springboot、mybatis-plus和JSQLParser后的LocalDateTime日期json问题

升级后&#xff0c;运行显示项目的时候出现下面错误 2023-08-12 10:57:39.174 [http-nio-8080-exec-3] [1;31mERROR[0;39m [36morg.jeecg.common.aspect.DictAspect:104[0;39m - json解析失败Java 8 date/time type java.time.LocalDateTime not supported by default: add Mo…...

基于FPGA的PID算法学习———实现PID比例控制算法

基于FPGA的PID算法学习 前言一、PID算法分析二、PID仿真分析1. PID代码2.PI代码3.P代码4.顶层5.测试文件6.仿真波形 总结 前言 学习内容&#xff1a;参考网站&#xff1a; PID算法控制 PID即&#xff1a;Proportional&#xff08;比例&#xff09;、Integral&#xff08;积分&…...

无法与IP建立连接,未能下载VSCode服务器

如题&#xff0c;在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈&#xff0c;发现是VSCode版本自动更新惹的祸&#xff01;&#xff01;&#xff01; 在VSCode的帮助->关于这里发现前几天VSCode自动更新了&#xff0c;我的版本号变成了1.100.3 才导致了远程连接出…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端

&#x1f31f; 什么是 MCP&#xff1f; 模型控制协议 (MCP) 是一种创新的协议&#xff0c;旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议&#xff0c;它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...

uniapp微信小程序视频实时流+pc端预览方案

方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度​WebSocket图片帧​定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐​RTMP推流​TRTC/即构SDK推流❌ 付费方案 &#xff08;部分有免费额度&#x…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个生活电费的缴纳和查询小程序

一、项目初始化与配置 1. 创建项目 ohpm init harmony/utility-payment-app 2. 配置权限 // module.json5 {"requestPermissions": [{"name": "ohos.permission.INTERNET"},{"name": "ohos.permission.GET_NETWORK_INFO"…...

今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存

文章目录 优雅版线程池ThreadPoolTaskExecutor和ThreadPoolTaskExecutor的装饰器并发修改异常并发修改异常简介实现机制设计原因及意义 使用线程池造成的链路丢失问题线程池导致的链路丢失问题发生原因 常见解决方法更好的解决方法设计精妙之处 登录续期登录续期常见实现方式特…...

Python Ovito统计金刚石结构数量

大家好,我是小马老师。 本文介绍python ovito方法统计金刚石结构的方法。 Ovito Identify diamond structure命令可以识别和统计金刚石结构,但是无法直接输出结构的变化情况。 本文使用python调用ovito包的方法,可以持续统计各步的金刚石结构,具体代码如下: from ovito…...

tauri项目,如何在rust端读取电脑环境变量

如果想在前端通过调用来获取环境变量的值&#xff0c;可以通过标准的依赖&#xff1a; std::env::var(name).ok() 想在前端通过调用来获取&#xff0c;可以写一个command函数&#xff1a; #[tauri::command] pub fn get_env_var(name: String) -> Result<String, Stri…...

Linux中《基础IO》详细介绍

目录 理解"文件"狭义理解广义理解文件操作的归类认知系统角度文件类别 回顾C文件接口打开文件写文件读文件稍作修改&#xff0c;实现简单cat命令 输出信息到显示器&#xff0c;你有哪些方法stdin & stdout & stderr打开文件的方式 系统⽂件I/O⼀种传递标志位…...

云原生周刊:k0s 成为 CNCF 沙箱项目

开源项目推荐 HAMi HAMi&#xff08;原名 k8s‑vGPU‑scheduler&#xff09;是一款 CNCF Sandbox 级别的开源 K8s 中间件&#xff0c;通过虚拟化 GPU/NPU 等异构设备并支持内存、计算核心时间片隔离及共享调度&#xff0c;为容器提供统一接口&#xff0c;实现细粒度资源配额…...