JavaScript 节点分段错误

JavaScript Node Segmentation fault

提问人:MrGreenPepper 提问时间:7/28/2023 最后编辑:VLAZMrGreenPepper 更新时间:11/14/2023 访问量:406

问:

我目前正在使用 Windows 11 笔记本电脑和 Ubuntu 22LTS 台式电脑。只有在PC上,程序才会突然中断。经过一番研究,我发现它在“分段错误”中运行 - 错误,当从 postgres 数据库加载一些数据并用它创建一个对象时。调用构造函数后,就会发生错误。

import SegFaultHandler from 'segfault-handler'

SegFaultHandler.registerHandler("crash.log")

export async function _init(containerName) {
    let sqlQueries = {
        loadItemData: {
            syntax: 'select * from containercontent where itemname = $1',
            variables: [containerName],
        },
    };
    let containerData = await dbHandler
        .sqlQuery(sqlQueries.loadItemData.syntax, sqlQueries.loadItemData.variables)
        .then((res) => res.rows[0]);
    let Container = new Container();

    return Container;
}
export class Container extends MarketObject {
    constructor() {...} // <-- the error occurs

我已经重新安装了 vsCode、node、npm 和所有依赖项。我还用谷歌搜索并遵循了一些说明。其中之一是安装“segfault-handler”。现在我有一个日志,但我不明白:

PID 35548 received SIGSEGV for address: 0x7c
/home/nox/mega/GitHub/JavaScript/market/node_modules/segfault-handler/build/Release/segfault-handler.node(+0x3340)[0x7f72e3f1d340]
/lib/x86_64-linux-gnu/libc.so.6(+0x42520)[0x7f72e3842520]
node(_ZNK2v88internal13ScopeIterator15VisitLocalScopeERKSt8functionIFbNS0_6HandleINS0_6StringEEENS3_INS0_6ObjectEEENS1_9ScopeTypeEEENS1_4ModeES8_+0x14d)[0xe4cf1d]
node(_ZN2v88internal13ScopeIterator11ScopeObjectENS1_4ModeE+0x67)[0xe4d667]
node(_ZN2v88internal13DebugEvaluate14ContextBuilderC1EPNS0_7IsolateEPNS0_15JavaScriptFrameEi+0xf0)[0xe3f570]
node(_ZN2v88internal13DebugEvaluate5LocalEPNS0_7IsolateENS0_12StackFrameIdEiNS0_6HandleINS0_6StringEEEb+0x82)[0xe3f7e2]
node(_ZN2v88internal23DebugStackTraceIterator8EvaluateENS_5LocalINS_6StringEEEb+0x60)[0xe4eab0]
node(_ZN12v8_inspector19V8DebuggerAgentImpl19evaluateOnCallFrameERKNS_8String16ES3_N8v8_crdtp6detail10ValueMaybeIS1_EENS6_IbEES8_S8_S8_S8_NS6_IdEEPSt10unique_ptrINS_8protocol7Runtime12RemoteObjectESt14default_deleteISD_EEPNS5_8PtrMaybeINSC_16ExceptionDetailsEEE+0x286)[0x13ac266]
node(_ZN12v8_inspector8protocol8Debugger20DomainDispatcherImpl19evaluateOnCallFrameERKN8v8_crdtp12DispatchableE+0x30f)[0x1633fff]
node(_ZN8v8_crdtp14UberDispatcher14DispatchResult3RunEv+0x1b)[0x13eda6b]
node(_ZN12v8_inspector22V8InspectorSessionImpl23dispatchProtocolMessageENS_10StringViewE+0x1a0)[0x13b9880]
node[0xc8e1fa]
node[0xca7eb1]
node[0xca63ae]
node[0xca66fe]
node[0xca6b1a]
node(_ZN4node11Environment21RunAndClearInterruptsEv+0x148)[0xb0a378]
node(_ZN4node9inspector19NodeInspectorClient21runMessageLoopOnPauseEi+0x8c)[0xc8ed2c]
node(_ZN12v8_inspector10V8Debugger18handleProgramBreakEN2v85LocalINS1_7ContextEEENS2_INS1_5ValueEEERKSt6vectorIiSaIiEENS1_4base7EnumSetINS1_5debug11BreakReasonEiEENSE_13ExceptionTypeEb+0x2e5)[0x1392bb5]
node(_ZN12v8_inspector10V8Debugger21BreakProgramRequestedEN2v85LocalINS1_7ContextEEERKSt6vectorIiSaIiEENS1_4base7EnumSetINS1_5debug11BreakReasonEiEE+0x1a)[0x1392c0a]
node(_ZN2v88internal5Debug12OnDebugBreakENS0_6HandleINS0_10FixedArrayEEENS0_10StepActionENS_4base7EnumSetINS_5debug11BreakReasonEiEE+0x1b2)[0xe5a4a2]
node(_ZN2v88internal5Debug5BreakEPNS0_15JavaScriptFrameENS0_6HandleINS0_10JSFunctionEEE+0x220)[0xe5a6d0]
node(_ZN2v88internal28Runtime_DebugBreakOnBytecodeEiPmPNS0_7IsolateE+0x246)[0x12cf6a6]
node[0x1703c39]
Segmentation fault (core dumped)
Waiting for the debugger to disconnect...

有没有人能从中读出一些有意义的提示?


新信息:

构造函数导致错误后似乎以下函数:

export class Container extends MarketObject {
    constructor() {...} // <-- the error occurs
    
    saveDBData = async function () { //<--this function causes the error
        await dbHandler.sqlQuery(this.sqlQueries.saveItemData.syntax, 
           this.sqlQueries.saveItemData.variables);
     }
...
};

只是为了您的注意,dbHandler.js 看起来像这样,但我真的不认为它有问题。我在整个程序中都使用它:

import pg from 'pg';
import ini from 'ini';
import fs from 'fs';
import { error } from 'console';

async function getConnection() {
    try {
        let dbaccess = ini.parse(fs.readFileSync('./tools/database/db.ini', 'utf-8'));
        let client = new pg.Client(dbaccess['postgresql_loginData']);
        return client;
    } catch (error) {
        console.error(error);
        console.error(error.message);
    }
}

export async function sqlQuery(syntax, values) {
    try {
        let client = await getConnection();
        await client.connect();
        let res = await client.query(syntax, values);

        await client.end();

        return res;
    } catch (error) {
        console.error(error.stack);
    }
}
JavaScript 节点 .js 调试 分段错误

评论

0赞 Pointy 7/28/2023
在像 Node 这样的平台上,SIGSEGV 几乎总是意味着运行时中的错误。它可能是由代码中的某些内容触发的(嗯,很明显),但它不应该以这种方式失败。
0赞 Pointy 7/28/2023
它是什么 Node 版本?
0赞 MrGreenPepper 7/28/2023
它的节点版本 18.17.0
0赞 Pointy 7/28/2023
这个 Node 错误报告可能会引起人们的兴趣。这表明您正在使用的某些模块(?)可能有问题。.so.node
0赞 MrGreenPepper 7/28/2023
我已经执行了'npm rebuild'。我也刚刚删除了node_modules目录......还是同样的错误

答: 暂无答案