Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[BUG]arm64 xmx8g JSON.config(JSONWriter.Feature.WriteMapNullValue); 有问题 #2456

Open
lion000 opened this issue Apr 17, 2024 · 4 comments
Labels
bug Something isn't working

Comments

@lion000
Copy link

lion000 commented Apr 17, 2024

问题描述

简要描述您碰到的问题。
JSON.config(JSONWriter.Feature.WriteMapNullValue);

#
# A fatal error has been detected by the Java Runtime Environment:
#
#  SIGSEGV (0xb) at pc=0x0000ffffa90c9604, pid=354216, tid=0x0000fffe845fa120
#
# JRE version: Java(TM) SE Runtime Environment (8.0_411) (build 1.8.0_411-b09)
# Java VM: Java HotSpot(TM) 64-Bit Server VM (25.411-b09 mixed mode linux-aarch64 compressed oops)
# Problematic frame:
# J 7868 C2 java.util.LinkedHashMap$LinkedEntryIterator.next()Ljava/lang/Object; (5 bytes) @ 0x0000ffffa90c9604 [0x0000ffffa90c95c0+0x44]

环境信息

请填写以下信息:
arm64 xmx8g
JRE version: Java(TM) SE Runtime Environment (8.0_411) (build 1.8.0_411-b09)

  • 版本信息:[e.g.:Fastjson2 2.0.49]

重现步骤

如何操作可以重现该问题:

  1. 使用 xxx.xxx 方法
  2. 输入 ... 数据
  3. 出现 ... 错误
//可在此输入示例代码

期待的正确结果

对您期望发生的结果进行清晰简洁的描述。

相关日志输出

请复制并粘贴任何相关的日志输出。

附加信息

如果你还有其他需要提供的信息,可以在这里填写(可以提供截图、视频等)。

@lion000 lion000 added the bug Something isn't working label Apr 17, 2024
@lion000
Copy link
Author

lion000 commented Apr 17, 2024

JSON.config(JSONWriter.Feature.WriteMapNullValue);
大量数据转换时
zymzdzblPo.setContent(content.toJSONString());
jvm直接crash

@wenshao
Copy link
Member

wenshao commented Apr 17, 2024

这个没看到fastjson2的堆栈啊

@lion000
Copy link
Author

lion000 commented Apr 18, 2024

昨天在找问题,提的比较急
情况是这样的,用上面的代码,做javabean转json再转json字符串,javabean属性为空时,默认会丢失key,所以添加JSON.config(JSONWriter.Feature.WriteMapNullValue);全局配置,调用方式时设置,效果一样
添加之后,大概几万的数据量,做批量转换时,jvm崩溃,详细的堆栈如下,还有一些堆栈日志,需要的话,可以提供

#
# A fatal error has been detected by the Java Runtime Environment:
#
#  SIGSEGV (0xb) at pc=0x0000ffffa90c9604, pid=354216, tid=0x0000fffe845fa120
#
# JRE version: Java(TM) SE Runtime Environment (8.0_411) (build 1.8.0_411-b09)
# Java VM: Java HotSpot(TM) 64-Bit Server VM (25.411-b09 mixed mode linux-aarch64 compressed oops)
# Problematic frame:
# J 7868 C2 java.util.LinkedHashMap$LinkedEntryIterator.next()Ljava/lang/Object; (5 bytes) @ 0x0000ffffa90c9604 [0x0000ffffa90c95c0+0x44]
#
# Core dump written. Default location: Core dumps may be processed with "/usr/lib/systemd/systemd-coredump %P %u %g %s %t %c %h" (or dumping to /home/ntservice/quality/core.354216)
#

Stack: [0x0000fffe843fb000,0x0000fffe845fb000],  sp=0x0000fffe845f87b0,  free space=2037k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
J 7868 C2 java.util.LinkedHashMap$LinkedEntryIterator.next()Ljava/lang/Object; (5 bytes) @ 0x0000ffffa90c9604 [0x0000ffffa90c95c0+0x44]
J 9869 C1 com.alibaba.fastjson2.JSONWriterUTF16.write(Lcom/alibaba/fastjson2/JSONObject;)V (545 bytes) @ 0x0000ffffa9a47924 [0x0000ffffa9a47180+0x7a4]
J 9804 C1 com.alibaba.fastjson2.JSONObject.toString([Lcom/alibaba/fastjson2/JSONWriter$Feature;)Ljava/lang/String; (52 bytes) @ 0x0000ffffa9a13e64 [0x0000ffffa9a13c00+0x264]
J 9743 C1 com.ningtang.quality.infra.repo.emr.ZymzdzblDaoImpl.toPo(Lcom/ningtang/quality/domain/emr/entity/ZydzblDo;)Lcom/ningtang/quality/infra/repo/emr/po/ZymzdzblPo; (100 bytes) @ 0x0000ffffa99f3664 [0x0000ffffa99f1300+0x2364]
j  com.ningtang.quality.infra.repo.emr.ZymzdzblDaoImpl.save(Ljava/util/List;)V+39
j  com.ningtang.quality.domain.emr.ZymzdzblDomainService.save(Ljava/util/List;)V+25
j  com.ningtang.quality.domain.emr.ZymzdzblDomainService$$FastClassBySpringCGLIB$$a10396ed.invoke(ILjava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+42
j  org.springframework.cglib.proxy.MethodProxy.invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;+19
j  org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint()Ljava/lang/Object;+19
j  org.springframework.aop.framework.ReflectiveMethodInvocation.proceed()Ljava/lang/Object;+19
j  org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed()Ljava/lang/Object;+1
j  org.springframework.transaction.interceptor.TransactionInterceptor$1.proceedWithInvocation()Ljava/lang/Object;+4
j  org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(Ljava/lang/reflect/Method;Ljava/lang/Class;Lorg/springframework/transaction/interceptor/TransactionAspectSupport$InvocationCallback;)Ljava/lang/Object;+291
j  org.springframework.transaction.interceptor.TransactionInterceptor.invoke(Lorg/aopalliance/intercept/MethodInvocation;)Ljava/lang/Object;+40
j  org.springframework.aop.framework.ReflectiveMethodInvocation.proceed()Ljava/lang/Object;+120
j  org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed()Ljava/lang/Object;+1
j  org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(Ljava/lang/Object;Ljava/lang/reflect/Method;[Ljava/lang/Object;Lorg/springframework/cglib/proxy/MethodProxy;)Ljava/lang/Object;+131
j  com.ningtang.quality.domain.emr.ZymzdzblDomainService$$EnhancerBySpringCGLIB$$5a065e8e.save(Ljava/util/List;)V+36
j  com.ningtang.quality.application.EmrApp.lambda$save$0(ILjava/util/List;Lcn/hutool/core/date/DateTime;Lcn/hutool/core/date/DateTime;ILjava/util/concurrent/CountDownLatch;)V+33
j  com.ningtang.quality.application.EmrApp$$Lambda$1831.run()V+28
j  java.util.concurrent.ThreadPoolExecutor.runWorker(Ljava/util/concurrent/ThreadPoolExecutor$Worker;)V+95
j  java.util.concurrent.ThreadPoolExecutor$Worker.run()V+5
j  java.lang.Thread.run()V+11
v  ~StubRoutines::call_stub
V  [libjvm.so+0x5ce558]  JavaCalls::call_helper(JavaValue*, methodHandle*, JavaCallArguments*, Thread*)+0xb58
V  [libjvm.so+0x5cc1d8]  JavaCalls::call_virtual(JavaValue*, KlassHandle, Symbol*, Symbol*, JavaCallArguments*, Thread*)+0x258
V  [libjvm.so+0x5cc71c]  JavaCalls::call_virtual(JavaValue*, Handle, KlassHandle, Symbol*, Symbol*, Thread*)+0x4c
V  [libjvm.so+0x643698]  thread_entry(JavaThread*, Thread*)+0xa4
V  [libjvm.so+0x974f90]  JavaThread::thread_main_inner()+0xe0
V  [libjvm.so+0x8343c4]  java_start(Thread*)+0x174
C  [libc.so.6+0x7f09c]
C  [libc.so.6+0xe48dc]

Deoptimization events (10 events):
Event: 21.931 Thread 0x0000ffff203b7000 Uncommon trap: reason=intrinsic action=none pc=0x0000ffffa8aba910 method=java.time.Instant.toEpochMilli()J @ 55
Event: 21.932 Thread 0x0000ffff203b4000 Uncommon trap: reason=intrinsic action=none pc=0x0000ffffa8aba910 method=java.time.Instant.toEpochMilli()J @ 55
Event: 21.933 Thread 0x0000ffff203b4000 Uncommon trap: reason=intrinsic action=none pc=0x0000ffffa8aba910 method=java.time.Instant.toEpochMilli()J @ 55
Event: 21.944 Thread 0x0000ffff203bc000 Uncommon trap: reason=unstable_if action=reinterpret pc=0x0000ffffa9967e50 method=com.alibaba.fastjson2.internal.asm.Frame.execute(IILcom/alibaba/fastjson2/internal/asm/Symbol;Lcom/alibaba/fastjson2/internal/asm/SymbolTable;)V @ 1650
Event: 21.946 Thread 0x0000ffff203b8800 Uncommon trap: reason=unstable_if action=reinterpret pc=0x0000ffffa9967e50 method=com.alibaba.fastjson2.internal.asm.Frame.execute(IILcom/alibaba/fastjson2/internal/asm/Symbol;Lcom/alibaba/fastjson2/internal/asm/SymbolTable;)V @ 1650
Event: 22.289 Thread 0x0000ffff203c1000 Uncommon trap: reason=unstable_if action=reinterpret pc=0x0000ffffa8887abc method=com.alibaba.fastjson2.JSONWriterUTF16JDK8UF.writeString(Ljava/lang/String;)V @ 113
Event: 22.429 Thread 0x0000ffff203b4000 Uncommon trap: reason=unstable_if action=reinterpret pc=0x0000ffffa9a2db60 method=com.alibaba.fastjson2.JSONWriterUTF16JDK8UF.writeString(Ljava/lang/String;)V @ 205
Event: 22.435 Thread 0x0000ffff203c1000 Uncommon trap: reason=intrinsic action=none pc=0x0000ffffa8aba910 method=java.time.Instant.toEpochMilli()J @ 55
Event: 22.441 Thread 0x0000ffff203c1000 Uncommon trap: reason=intrinsic action=none pc=0x0000ffffa8aba910 method=java.time.Instant.toEpochMilli()J @ 55
Event: 22.442 Thread 0x0000ffff203c1000 Uncommon trap: reason=intrinsic action=none pc=0x0000ffffa8aba910 method=java.time.Instant.toEpochMilli()J @ 55

@wenshao
Copy link
Member

wenshao commented May 12, 2024

https://github.com/alibaba/fastjson2/releases/tag/2.0.50
能否帮忙用2.0.50版本验证下是否问题还存在

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

2 participants