uni-app 使用过程中遇到Bug:升级后台管理系统登录提示【FC invoke failed, resource exhausted】,但实际未到时间且已续费

发布于 1周前 作者 htzhanglong 来自 Uni-App

uni-app 使用过程中遇到Bug:升级后台管理系统登录提示【FC invoke failed, resource exhausted】,但实际未到时间且已续费

操作步骤:

如上描述

预期结果:

如上描述

实际结果:

如上描述

bug描述:

使用uniapp 升级插件,部署了后台,刚刚弄的时候登录,由于项目插入暂停,今天再登录时提示
空间到期日期: 2024-10-23 00:00:00
续一次:到期日期 2024-11-23 00:00:00 到期

根据错误,查找文档,没有当前说明

Image Image Image


6 回复

你这个空间套餐里的云函数使用量已经超了,建议直接转按量计费


谢谢,现在可以登录了,能进去就行,还是有点点疑问(不用解答),还在测试阶段,【云函数使用量已经超了】还没有怎么用,后面转按量 再看看

现在又出现了,可以帮忙再延长半个月,这边在申请费用。

回复 t***@bibibi.net: 无法延长哦, 这个是云厂商控制的, 建议直接转按量计费即可

回复 DCloud_uniCloud_VK: 谢谢 没事了,看到有个变更了 可以先弄一个月的那种

在处理 uni-app 中遇到的 FC invoke failed, resource exhausted 错误时,这通常意味着后端函数计算(Function Compute,简称 FC)资源被耗尽或受限。尽管您提到已经续费且实际未到时间,这种情况可能由于多种原因引起,包括并发请求过多、资源配额限制、或者系统内部错误等。

以下是一些代码级别的检查和调整策略,可以帮助您诊断和缓解这个问题:

1. 检查并发请求

首先,确保应用没有发送过多的并发请求到后端。您可以通过在前端实施请求队列或节流(throttling)机制来控制并发量。

// 简单的节流函数示例
function throttle(func, wait) {
    let context, args, timeout;
    return function() {
        context = this;
        args = arguments;
        const later = function() {
            timeout = null;
            if (!immediate) func.apply(context, args);
        };
        const callNow = !timeout;
        clearTimeout(timeout);
        timeout = setTimeout(later, wait);
        if (callNow) func.apply(context, args);
    };
}

// 使用节流函数控制登录请求
const throttledLogin = throttle(() => {
    // 您的登录逻辑代码
}, 1000); // 每秒最多一次

2. 调整后端资源配额

登录到阿里云控制台,检查您的 Function Compute 服务配额设置。可能需要增加并发执行数、内存大小等配额。

3. 优化后端函数

确保后端函数计算代码高效执行,避免不必要的资源消耗。例如,优化数据库查询,减少不必要的数据处理。

# 示例:优化后的 Python 函数计算代码
import time
from aliyunsdkcore.client import AcsClient
from aliyunsdkcore.request import CommonRequest

def handler(event, context):
    # 假设这是处理登录请求的函数
    start_time = time.time()
    
    # 高效数据库查询示例
    # db_result = query_database_efficiently()
    
    # 模拟处理时间
    time.sleep(2)  # 假设实际操作需要2秒
    
    end_time = time.time()
    print(f"Function execution time: {end_time - start_time} seconds")
    
    return {
        'statusCode': 200,
        'body': json.dumps({
            'message': 'Login successful',
            'executionTime': end_time - start_time
        })
    }

4. 日志和监控

启用详细的日志记录和监控,以便更好地理解何时何地资源被耗尽。阿里云 Function Compute 提供了内置的日志和监控功能。

通过上述方法,您可以更系统地诊断和解决 FC invoke failed, resource exhausted 的问题。如果问题依旧存在,建议联系阿里云的技术支持获取更专业的帮助。

回到顶部