0
  • 操作系统:Linux 5.9.16-1-MANJARO
  • 电子版:10.1.5
  • BetterSqlite版本:7.1.2

我目前正在使用 Electron 和 BetterSqlite 编写应用程序。

我像这样构建 AppImage:

npm run build && electron-builder build

这就是我从代码访问数据库的方式:

db = new Database(
    path.join(__dirname, `/${dbName}`).replace("/app.asar", "")
);

我添加了要使用的数据库文件:

"extraResources": [
    "public/build/Database.db"
],

但是当我打开 AppImage 时,我收到以下错误消息:

SqliteError: attempt to write a readonly database

由于 /tmp/.mountxxx 点是只读的,数据库似乎无法访问。

当我在开发文件夹中打开应用程序时,不会发生此行为,因为它不是只读目录。

有没有办法从 /tmp/.mountxxx 目录使用数据库?

我将如何以另一种方式访问​​数据库?

先感谢您。

4

2 回答 2

0

我已经搜索了一种使用 AppImage 挂载点进行读写的方法,但我没有找到任何东西。我将使用用户的主目录来存储数据库

于 2021-04-18T11:46:10.607 回答
0

正如错误所说,当执行 AppImage 时,AppDir 被挂载为 RO 文件系统。

要解决此问题,您需要使用启动脚本将数据库文件复制到用户主目录中。例如,您可以将其复制到“$HOME/.cache/com.myapp/appdata.db”,然后使用这个新副本。

于 2021-04-30T16:43:18.683 回答