Serverless 应用引擎产品使用之Nacos 在集中发版时遇到老年代暂满,并且频繁进行 Full GC,但是 GC 后内存没有降下来如何解决

本文涉及的产品
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
函数计算FC,每月15万CU 3个月
简介: 阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。

问题一:在Nacos中,有大佬遇到过这种情况吗?


晚上集中发版时遇到nacos老年代暂满,导致频繁进行full gc,但gc后内存无法降下来。目前有4台机器,每台16核32GB内存,其中老年代分配了10GB。有没有遇到过这种情况的经验分享?另外每个nacos服务内存都分配了20GB,其中年轻代10GB,老年代10GB,总内存为80GB,我的主要问题出现在集中发版时,老年代的内存回收不彻底,发版完成后,情况恢复正常了。


参考回答:

升级下jdk.垃圾回收的更完美,用jdk11.线程数量.gc性能 优化的都还不错 1、你可以看一下你server节点长轮询连接数是否很不均衡。

2、我之前遇到的server内存泄漏,是因为/nacos/v1/cs/configs/listener这个长轮询接口在服务端的对象被强引这释放不了。

3、扩大server内存,升级客户端到2.x。


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/573633


问题二:在阿里云Serverless中,函数里边对多线程有限制吗?


函数里边对多线程有限制吗?配置了8个vCPU,java中的parallelStream只有一个线程执行在执行


参考回答:

在阿里云 Serverless 中,函数对多线程有一些限制。具体来说,以下是一些需要注意的方面:

  1. 并发限制:每个函数实例的最大并发数是有限的,这是由函数计算平台自动管理的。并发数受到函数配置、资源配额以及账户级别的限制。如果超过最大并发数,新的请求可能会被拒绝或排队等待。
  2. 线程池和连接池:函数内部使用的线程池和连接池通常也受到限制。例如,Java 函数中的线程池和数据库连接池都需要进行适当的配置,以避免资源耗尽或性能问题。
  3. 长时间运行限制:函数执行时间在阿里云函数计算中是有限制的。对于标准版函数,默认执行时间限制为 10 分钟,超过该时间会被强制停止。若需要更长的执行时间,可以考虑使用高性能版函数。
  4. 共享资源:由于阿里云 Serverless 是一个共享型的环境,多个函数实例可能同时运行在同一物理机上。因此,需要避免函数之间的竞争条件和资源冲突,确保正确处理共享资源的访问。

了解并合理考虑这些限制对于设计和编写具有多线程需求的函数是非常重要的。需要根据具体需求,合理规划函数的并发数、线程池配置和资源消耗,并进行充分的测试以确保函数在实际运行中的可靠性和性能。


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/573608


问题三:在阿里云Serverless中,如何安装 nodejs20 的环境 ?


如何安装 nodejs20 的环境 ?nodejs nodejs安装第三方依赖


参考回答:

函数计算目前支持Node.js 6.x、Node.js 8.x、Node.js 10.x、Node.js 12.x和Node.js 14.x(公测中)运行环境。本文介绍了Node.js运行环境的日志、函数、错误、模块使用和外部命令调用等内容。


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/573607


问题四:在阿里云Serverless中,为什么deploy.sh运行时node的版本时10的?


请问函数式计算部署midway时按照官网的命令设置 但是为什么deploy.sh运行时node的版本时10的?

然后报错


参考回答:

在阿里云 Serverless 中,如果您发现 deploy.sh 脚本运行时使用的 Node.js 版本是 v10,这可能是由于以下原因:

  1. 默认版本
  • 阿里云 Serverless 可能使用了某个特定的默认 Node.js 版本(如 v10)作为其基础镜像的一部分。
  • 这个默认版本可能会被用于部署脚本和其他辅助工具。
  1. 函数配置
  • 如果您没有明确指定 Node.js 的版本,在创建或更新函数时,Serverless 服务可能会选择一个默认的稳定版本来确保兼容性。
  1. 本地环境
  • 如果您在本地执行 deploy.sh 脚本,并且您的开发环境中安装的是 Node.js v10,那么这个脚本将会使用该版本的 Node.js。


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/573603


问题五:在阿里云Serverless中,环境变量里设置TZ不行怎么办


咨询下,自定义运行时custom.debian10如何设置时区,好像到环境变量里设置TZ不行


参考回答:

在阿里云 Serverless 中,如果您发现设置环境变量 TZ 不起作用,可以尝试以下方法:

  1. 确保正确设置
  • 检查您的函数配置中是否正确设置了环境变量 TZ。确保格式和值都是正确的。
  • 例如,要设置为 UTC 时间,请使用:TZ=UTC
  1. 重启函数实例
  • 环境变量更改可能需要重新启动函数实例才能生效。
  • 在函数详情页面,找到“基本配置”部分,然后点击“重置实例”。
  1. 更新代码
  • 如果您正在使用 Node.js,确保在代码中正确地访问环境变量。例如,使用 process.env.TZ 来获取 TZ 的值。
  1. 检查时区兼容性
  • 验证所选的时区是否被您的应用程序支持。有时,特定的时区可能会因为名称不规范或不再使用而无法识别。


关于本问题的更多回答可点击原文查看:https://developer.aliyun.com/ask/573602

相关实践学习
1分钟部署经典小游戏
本场景介绍如何使用Serverless应用引擎SAE 1分钟快速部署经典小游戏。
SAE的功能与使用入门
欢迎来到《SAE的功能与使用入门》,本课程是“云原生Serverless Clouder认证“系列中的第三阶段。课程将向您介绍阿里云Serverless应用引擎(SAE)服务相关的概念、特性与使用方式。通过课程将带您逐步深入探索Serverless世界,借助SAE服务,即使没有丰富的云计算和IT经验,也能够让开发人员在实际业务场景中便捷的掌握如何构建和部署应用程序,快速拥抱Serverless架构,将精力聚焦在应用代码和业务逻辑的实现上。 学习完本课程后,您将能够: 掌握Serverless应用引擎(SAE)的基本概念与核心优势 了解Serverless应用引擎(SAE)的核心功能 掌握使用Serverless应用引擎(SAE)的开发和部署流程 了解Serverless应用引擎(SAE)的适用场景和最佳实践  
相关文章
|
8月前
|
运维 Kubernetes Serverless
Serverless 应用引擎使用问题之如何实现与Nacos的交互
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
8月前
|
弹性计算 数据安全/隐私保护 虚拟化
云服务器 ECS产品使用问题之如何升级内存
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
8月前
|
弹性计算 运维 云计算
云服务器 ECS产品使用问题之如何解决幻兽帕鲁服务器内存溢出
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
7月前
|
NoSQL 关系型数据库 MySQL
实时计算 Flink版产品使用问题之全量同步的内存释放该怎么实现
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
7月前
|
SQL 存储 关系型数据库
实时计算 Flink版产品使用问题之同步MySQL多张表的过程中,内存释放依赖于什么
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
8月前
|
弹性计算 Linux 云计算
云服务器 ECS产品使用问题之如何扩容服务器(内存和带宽)
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
8月前
|
存储 弹性计算 运维
云服务器 ECS产品使用问题之如何减缓内存泄漏
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
4天前
|
存储 缓存 算法
JVM简介—1.Java内存区域
本文详细介绍了Java虚拟机运行时数据区的各个方面,包括其定义、类型(如程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区和直接内存)及其作用。文中还探讨了各版本内存区域的变化、直接内存的使用、从线程角度分析Java内存区域、堆与栈的区别、对象创建步骤、对象内存布局及访问定位,并通过实例说明了常见内存溢出问题的原因和表现形式。这些内容帮助开发者深入理解Java内存管理机制,优化应用程序性能并解决潜在的内存问题。
JVM简介—1.Java内存区域
|
1天前
|
消息中间件 Java 应用服务中间件
JVM实战—2.JVM内存设置与对象分配流转
本文详细介绍了JVM内存管理的相关知识,包括:JVM内存划分原理、对象分配与流转、线上系统JVM内存设置、JVM参数优化、问题汇总。
JVM实战—2.JVM内存设置与对象分配流转
|
3天前
|
缓存 监控 算法
JVM简介—2.垃圾回收器和内存分配策略
本文介绍了Java垃圾回收机制的多个方面,包括垃圾回收概述、对象存活判断、引用类型介绍、垃圾收集算法、垃圾收集器设计、具体垃圾回收器详情、Stop The World现象、内存分配与回收策略、新生代配置演示、内存泄漏和溢出问题以及JDK提供的相关工具。
JVM简介—2.垃圾回收器和内存分配策略

相关产品

  • 函数计算
  • Serverless 应用引擎