Skip to content

版本

安装版本

shell
asdf install <name> <version>
# asdf install erlang 17.3

如果一个插件支持从源代码下载和编译,你可以指定 ref:foo,其中 foo 是特定的分支、标签或者提交。卸载该版本时,你也需要使用相同的名称和引用。

安装最新稳定版本

shell
asdf install <name> latest
# asdf install erlang latest

安装给定字符串开头的最新稳定版本。

shell
asdf install <name> latest:<version>
# asdf install erlang latest:17

列举已安装版本

shell
asdf list <name>
# asdf list erlang

筛选出以给定字符串开头的版本。

shell
asdf list <name> <version>
# asdf list erlang 17

列举所有可用版本

shell
asdf list all <name>
# asdf list all erlang

筛选出以给定字符串开头的版本。

shell
asdf list all <name> <version>
# asdf list all erlang 17

显示最新稳定版本

shell
asdf latest <name>
# asdf latest erlang

显示以给定字符串开头的最新稳定版本。

shell
asdf latest <name> <version>
# asdf latest erlang 17

设置版本

通过 .tool-versions 文件

shell
asdf set [flags] <name> <version> [<version>...]
# asdf set elixir 1.2.4 # set in current dir
# asdf set -u elixir 1.2.4 # set in .tool-versions file in home directory
# asdf set -p elixir 1.2.4 # set in existing .tool-versions file in a parent dir

asdf set <name> latest[:<version>]
# asdf set elixir latest

asdf set 将版本信息写入当前目录下的 .tool-versions 文件中,若该文件不存在则自动创建。此功能仅为方便使用而设。你可以将其视为执行 echo "<tool> <version>" > .tool-versions 的操作。

使用 -u/--home 选项时,asdf set 将写入位于 $HOME 目录下的 .tool-versions 文件,如果该文件不存在则创建它。

使用 -p/--parent 选项时,asdf set 会寻找在当前目录的最近父目录的 .tool-versions 文件进行操作。

通过环境变量

在确定版本时,系统会查询符合模式的环境变量 ASDF_${TOOL}_VERISON。该版本格式与 .tool-versions 文件中支持的格式一致。如果设置了该环境变量,其值将覆盖任何 .tool-versions 文件中为该工具设置的版本。例如:

shell
export ASDF_ELIXIR_VERSION=1.18.1

这将会告诉 asdf 在当前会话中使用 Elixir 1.18.1

警告

由于这是一个环境变量,它仅在设置的位置生效。其他正在运行的 shell 会话仍将使用在 .tool-versions 文件中设置的版本。

请查看 配置部分.tool-versions 文件了解更多详情。

下面的示例在版本为 1.4.0 的 Elixir 项目上运行测试。

shell
ASDF_ELIXIR_VERSION=1.4.0 mix test

回退到系统版本

要使用工具 <name> 的系统版本而非 asdf 管理版本,你可以将工具的版本设置为 system

使用 asdf set 命令或如上文 设置版本 部分所述的环境变量来设置系统。

shell
asdf set <name> system
# asdf set python system

显示当前版本

shell
asdf current
# asdf current
# erlang          17.3          /Users/kim/.tool-versions
# nodejs          6.11.5        /Users/kim/cool-node-project/.tool-versions

asdf current <name>
# asdf current erlang
# erlang          17.3          /Users/kim/.tool-versions

卸载版本

shell
asdf uninstall <name> <version>
# asdf uninstall erlang 17.3

垫片(Shims)

当 asdf 安装一个包时,它会在 $ASDF_DATA_DIR/shims 目录(默认为 ~/.asdf/shims)中为该包中的每个可执行程序创建垫片。这个位于 $PATH 中(通过 asdf.shasdf.fish 等等实现)的目录是已安装程序在环境中可用的方式。

垫片本身是非常简单的包装器,它 exec (执行)一个辅助程序 asdf exec,向其传递插件的名称和垫片正在包装的已安装包中的可执行程序的路径。

asdf exec 辅助程序确定要使用的软件包版本(比如在 .tool-versions 文件中指定,通过 asdf local ... 或者 asdf global ... 命令选择)、软件包安装目录中的可执行程序的最终路径(这可以在插件中通过 exec-path 回调来操作)以及要在其中执行的环境(也由插件 - exec-env 脚本提供),最后完成执行。

注意

因为此系统使用 exec 调用,所以软件包中的任何脚本如果要由 shell 生效而不是执行的脚本都需要直接访问,而不是通过垫片包装器进行访问。两个 asdf 命令:whichwhere 可以通过返回已安装软件包的路径来帮助解决这个问题。

shell
# 返回当前版本中主要可执行程序的路径
source $(asdf which ${PLUGIN})/../script.sh

# 返回软件包安装目录的路径
source $(asdf where ${PLUGIN})/bin/script.sh

绕过 asdf 垫片

如果由于某种原因,你希望绕过 asdf 垫片,或者希望在进入项目目录时自动设置环境变量,则 asdf-direnv 插件可能会有所帮助。请务必查看其 README 文件了解更多详情。