【发布时间】:2021-08-18 22:19:04
【问题描述】:
这是我们在 Firebase 上看到的堆栈跟踪:
Fatal Exception: java.lang.RuntimeException
Using WebView from more than one process at once with the same data directory is not supported. https://crbug.com/558377 : Current process [Our package] (pid 28562), lock owner [Our package] (pid 13324)
org.chromium.android_webview.AwDataDirLock.b (AwDataDirLock.java:27)
as0.i (as0.java:30)
as0.b (as0.java:17)
as0.k (as0.java:2)
com.android.webview.chromium.WebViewChromiumFactoryProvider.g (WebViewChromiumFactoryProvider.java:2)
com.android.webview.chromium.WebViewChromium.init (WebViewChromium.java:14)
android.webkit.WebView.<init> (WebView.java:435)
android.webkit.WebView.<init> (WebView.java:355)
android.webkit.WebView.<init> (WebView.java:337)
android.webkit.WebView.<init> (WebView.java:324)
android.webkit.WebView.<init> (WebView.java:314)
[Our code initializing the webview]
android.os.Handler.handleCallback (Handler.java:938)
android.os.Handler.dispatchMessage (Handler.java:99)
android.os.Looper.loop (Looper.java:246)
android.app.ActivityThread.main (ActivityThread.java:8506)
java.lang.reflect.Method.invoke (Method.java)
com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run (RuntimeInit.java:602)
com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1130)
我们无法重现这一点,但我们在 Firebase 上遇到了数百/数千次此类崩溃。奇怪的是,99% 的崩溃都发生在运行 Android 11 的三星设备上。我们的应用程序也是单进程应用程序,因此它不应该运行多个进程。我已经在铬问题跟踪器中发布了,但似乎三星操作系统的错误更多,而不是 webview 本身,所以我想我也会在这里发布。
似乎有些用户有一个我们的应用程序运行几个小时的进程,持有这个 Webview 锁。但是,当他们尝试打开我们的应用时,它会启动一个新进程而不是现有进程,并导致崩溃。
我正在尝试获取更多信息:有没有人知道为什么这会在三星 Android 11 上特别发生?我们的应用程序或我们的用户可以做些什么来缓解这个问题吗?有没有其他人遇到过这个问题并找到了解决方法?
【问题讨论】:
-
您是否尝试过将三星切换到 DeX 模式或从 DeX 模式切换?这是我可以看到三星在流程方面做一些奇怪的事情的一种情况。此外,您是否看到这些相同用户的其他崩溃?我想知道您的旧进程是否以没有清理他们正在使用的锁定文件(?)的方式终止。
-
@CommonsWare 我们确实在 Firebase 上跟踪用户 ID,至少对于我现在和过去查找过的少数用户而言,这是他们在 Firebase 上报告的唯一一次崩溃过去 90 天。我不知道是否有可能是内存泄漏之类的原因,但仍然很奇怪,它是三星特有的。不过我从来没有听说过 DeX 模式,我们会调查一下,看看我们是否可以用它重现任何东西,谢谢!
-
我可能错了,但您是否使用this Localization 库(或类似的东西)this bug in it 在我们的应用程序上创建了十几个崩溃,其中一个具有与您相同的堆栈跟踪我提供了
-
我没有使用那个本地化库,无论如何看起来他们已经解决了这个特定问题。但是感谢您的评论,Amin... 我可以试试some of the changes they made to fix that library。 (不过,尚不清楚为什么这些崩溃集中在运行 Android 11 的三星设备上。)
-
@RapunzelVanWinkle 您能找到问题的根源或解决方法吗?
标签: android webview crash samsung-mobile