David Planella Asked: 2016-04-26 03:13:31 +0800 CST2016-04-26 03:13:31 +0800 CST 2016-04-26 03:13:31 +0800 CST Ubuntu可以在哪里快照写入数据? 772 在 Ubuntu 中打包为 snap 的应用程序安装(挂载)在该/snap/$SNAPPNAME位置下。下的所有/snap内容都安装为只读文件系统,因此应用程序无法写入该空间,无论是在其他应用程序的目录中还是在它们自己的目录中。 虽然 snaps 有一个home 接口可以指定读/写用户的主目录,但出于安全原因,它是保留的,需要用户手动连接(启用)。 那么快照内的应用程序可以在哪里写入其配置、数据和其他文件呢?是否有 API 可以访问特殊的可写位置? snap 1 个回答 Voted Best Answer kyrofa 2016-04-26T04:59:14+08:002016-04-26T04:59:14+08:00 当您在 中声明应用程序时snapcraft.yaml,会在安装时生成一个二进制包装器并将其放入/snap/bin/以您的包和应用程序名称命名的二进制包装器(请注意,如果应用程序是服务,则此包装器是 systemd .service 文件)。 该包装器包含应用程序运行的大部分环境。与这个问题最相关的两个环境变量是SNAP_DATA和SNAP_USER_DATA。您可以在文档中找到有关这些的更多信息,但我也会在此处对其进行描述: SNAP_DATA是一个系统范围的可写区域(in /var/snap/)。例如,这可能用于托管服务的日志。 SNAP_USER_DATA是运行应用程序的用户主目录中的用户特定可写区域(特别是/home/<user>/snap/)。这可能用于用户特定的配置文件等。 这两个目录对于升级/回滚功能都非常重要,因为它们都是版本化的。也就是说,给定快照的每个修订版都有自己的这些目录的副本。让我用一个例子来解释。 假设您安装了“foo”快照的修订版 1。这将创建两个目录: /var/snap/foo/1( SNAP_DATA) /home/<user>/snap/foo/1( SNAP_USER_DATA) 现在说“foo”同时使用了这两种方法。也许它有一个托管数据库的服务SNAP_DATA,以及一个使用配置文件的二进制文件SNAP_USER_DATA。 现在“foo”的第 2 版已经发布,并且会自动更新。发生的第一件事是/var/snap/foo/1被复制到/var/snap/foo/2并被/home/<user>/snap/foo/1复制到/home/<user>/snap/foo/2. 然后启动新的修订版。它应该注意到它在旧数据上运行,并且可能有一些数据库迁移要运行到SNAP_DATA. 它这样做了,然后它就走了。 现在说这些迁移由于某种原因而失败,并且该应用程序需要回滚。它开始使用 /snap/foo 应用程序的旧版本,其中SNAP_DATA指向/var/snap/foo/1和SNAP_USER_DATA指向/home/<user>/snap/foo/1. 这会在迁移运行之前在旧版本上进行处理,因为这些操作是在数据副本上运行的。 长话短说:不要使用home接口来存储可以存储在SNAP_DATAor中的数据SNAP_USER_DATA,因为它们是升级/回滚策略的组成部分。好好利用他们! v2.0.10 的更新: 还引入了两个新的数据目录: SNAP_COMMON坐在旁边SNAP_DATA,但特别是未版本化。特定快照的每个修订版都可以访问此目录,因此不会在升级/回滚等时复制它。这可能用于特别大的未版本化文件(例如,不是真正特定于版本的原始数据)。 SNAP_USER_COMMON坐在旁边SNAP_USER_DATA,但又是特别未版本化的。它可能用于为每个用户存储非特定于版本的数据。 v2.15 的更新: 放置在其中的文件/snap/bin不再是定义环境的包装器,而是指向/usr/bin/snap. 因此,确定应用程序运行环境的方法是使用snap run --shell <snap>.<app>,例如: $ sudo snap install hello-world $ snap run --shell hello-world To run a command as administrator (user "root"), use "sudo <command>". See "man sudo_root" for details. $ env | grep SNAP SNAP_USER_COMMON=/home/kyrofa/snap/hello-world/common SNAP_REEXEC= SNAP_LIBRARY_PATH=/var/lib/snapd/lib/gl: SNAP_COMMON=/var/snap/hello-world/common SNAP_USER_DATA=/home/kyrofa/snap/hello-world/27 SNAP_DATA=/var/snap/hello-world/27 SNAP_REVISION=27 SNAP_NAME=hello-world SNAP_ARCH=amd64 SNAP_VERSION=6.3 SNAP=/snap/hello-world/27
当您在 中声明应用程序时
snapcraft.yaml
,会在安装时生成一个二进制包装器并将其放入/snap/bin/
以您的包和应用程序名称命名的二进制包装器(请注意,如果应用程序是服务,则此包装器是 systemd .service 文件)。该包装器包含应用程序运行的大部分环境。与这个问题最相关的两个环境变量是
SNAP_DATA
和SNAP_USER_DATA
。您可以在文档中找到有关这些的更多信息,但我也会在此处对其进行描述:SNAP_DATA
是一个系统范围的可写区域(in/var/snap/
)。例如,这可能用于托管服务的日志。SNAP_USER_DATA
是运行应用程序的用户主目录中的用户特定可写区域(特别是/home/<user>/snap/
)。这可能用于用户特定的配置文件等。这两个目录对于升级/回滚功能都非常重要,因为它们都是版本化的。也就是说,给定快照的每个修订版都有自己的这些目录的副本。让我用一个例子来解释。
假设您安装了“foo”快照的修订版 1。这将创建两个目录:
/var/snap/foo/1
(SNAP_DATA
)/home/<user>/snap/foo/1
(SNAP_USER_DATA
)现在说“foo”同时使用了这两种方法。也许它有一个托管数据库的服务
SNAP_DATA
,以及一个使用配置文件的二进制文件SNAP_USER_DATA
。现在“foo”的第 2 版已经发布,并且会自动更新。发生的第一件事是
/var/snap/foo/1
被复制到/var/snap/foo/2
并被/home/<user>/snap/foo/1
复制到/home/<user>/snap/foo/2
. 然后启动新的修订版。它应该注意到它在旧数据上运行,并且可能有一些数据库迁移要运行到SNAP_DATA
. 它这样做了,然后它就走了。现在说这些迁移由于某种原因而失败,并且该应用程序需要回滚。它开始使用 /snap/foo 应用程序的旧版本,其中
SNAP_DATA
指向/var/snap/foo/1
和SNAP_USER_DATA
指向/home/<user>/snap/foo/1
. 这会在迁移运行之前在旧版本上进行处理,因为这些操作是在数据副本上运行的。长话短说:不要使用
home
接口来存储可以存储在SNAP_DATA
or中的数据SNAP_USER_DATA
,因为它们是升级/回滚策略的组成部分。好好利用他们!v2.0.10 的更新:
还引入了两个新的数据目录:
SNAP_COMMON
坐在旁边SNAP_DATA
,但特别是未版本化。特定快照的每个修订版都可以访问此目录,因此不会在升级/回滚等时复制它。这可能用于特别大的未版本化文件(例如,不是真正特定于版本的原始数据)。SNAP_USER_COMMON
坐在旁边SNAP_USER_DATA
,但又是特别未版本化的。它可能用于为每个用户存储非特定于版本的数据。v2.15 的更新:
放置在其中的文件
/snap/bin
不再是定义环境的包装器,而是指向/usr/bin/snap
. 因此,确定应用程序运行环境的方法是使用snap run --shell <snap>.<app>
,例如: