sdkman安装使用

SDKMAN 安装指南 - 自定义安装到 /opt/sdkman

概述

介绍如何在 macOS M4 系统上将 SDKMAN 安装到自定义目录 /opt/sdkman

安装步骤

1. 清理现有配置(重要!)

如果之前安装过 SDKMAN,需要先清理现有配置:

bash 复制代码
# 检查是否有现有配置
cat ~/.zshrc | grep -i sdkman

# 如果有配置,删除 ~/.zshrc 中的 SDKMAN 相关行
# 可以手动编辑或使用以下命令删除
sed -i '' '/SDKMAN/d' ~/.zshrc

# 取消当前会话中的 SDKMAN_DIR 环境变量
unset SDKMAN_DIR

# 删除可能存在的旧安装目录
rm -rf ~/.sdkman

2. 创建目录并设置权限

bash 复制代码
# 创建 sdkman 目录
sudo mkdir -p /opt/sdkman

# 设置目录权限
sudo chown -R $USER:staff /opt/sdkman

3. 验证权限设置

bash 复制代码
# 测试是否可以在目录中创建文件
touch /opt/sdkman/test.txt
ls -la /opt/sdkman/
rm /opt/sdkman/test.txt

4. 安装 SDKMAN

bash 复制代码
# 使用环境变量指定安装目录
SDKMAN_DIR="/opt/sdkman" curl -s "https://get.sdkman.io" | bash

5. 处理默认安装位置

如果安装脚本将文件安装到了 ~/.sdkman,需要移动到目标目录:

bash 复制代码
# 移动文件到目标目录
mv ~/.sdkman/* /opt/sdkman/

# 删除默认目录
rm -rf ~/.sdkman

6. 更新配置文件

修改 ~/.zshrc 文件中的 SDKMAN 路径:

bash 复制代码
# 使用 sed 命令更新路径
sed -i '' 's|$HOME/.sdkman|/opt/sdkman|g' ~/.zshrc

配置文件应该包含以下内容:

bash 复制代码
#THIS MUST BE AT THE END OF THE FILE FOR SDKMAN TO WORK!!!
export SDKMAN_DIR="/opt/sdkman"
[[ -s "/opt/sdkman/bin/sdkman-init.sh" ]] && source "/opt/sdkman/bin/sdkman-init.sh"

7. 验证安装

bash 复制代码
# 重新加载配置
source ~/.zshrc

# 检查版本
sdk version

# 查看帮助
sdk help

预期输出

成功安装后,sdk version 应该显示:

makefile 复制代码
SDKMAN!
script: 5.20.0
native: 0.7.14 (macos aarch64)

常见问题

权限问题

如果遇到权限拒绝错误,确保:

  • 使用 sudo 创建 /opt/sdkman 目录
  • 正确设置目录所有者为当前用户
  • 目录所有者设置正确

安装位置问题

SDKMAN 安装脚本默认安装到 ~/.sdkman,需要手动移动文件并更新配置。

配置文件问题

确保 ~/.zshrc 中的路径指向 /opt/sdkman 而不是 ~/.sdkman

安装失败问题

如果安装时提示"You already have SDKMAN installed"但实际无法使用:

  • 检查 ~/.zshrc 是否有旧的 SDKMAN 配置
  • 使用 unset SDKMAN_DIR 清除环境变量
  • 删除旧配置后重新安装

使用示例

bash 复制代码
# 列出可用的 Java 版本
sdk list java

# 安装 Java
sdk install java 17.0.0-tem

# 切换 Java 版本
sdk use java 17.0.0-tem

# 设置默认版本
sdk default java 17.0.0-tem
相关推荐
bearpping6 小时前
Nginx 配置:alias 和 root 的区别
前端·javascript·nginx
@大迁世界7 小时前
07.React 中的 createRoot 方法是什么?它具体如何运作?
前端·javascript·react.js·前端框架·ecmascript
January12077 小时前
VBen Admin Select 选择框选中后仍然显示校验错误提示的解决方案
前端·vben
. . . . .7 小时前
前端测试框架:Vitest
前端
xiaotao1317 小时前
什么是 Tailwind CSS
前端·css·css3
战南诚8 小时前
VUE中,keep-alive组件与钩子函数的生命周期
前端·vue.js
发现一只大呆瓜8 小时前
React-彻底搞懂 Redux:从单向数据流到 useReducer 的终极抉择
前端·react.js·面试
霍理迪9 小时前
Vue的响应式和生命周期
前端·javascript·vue.js
李剑一9 小时前
别再瞎写了!Cesium 模型 360° 环绕,4 套源码全公开,项目直接用
前端