解决 bash 命令实际执行路径与 which 路径不匹配的问题
目录
背景
简单写写这周遇到的一个有意思的小问题。
之前用 AWS 的命令行工具 aws-cli
,遇到点儿问题。看官方文档,说如果用的是 1.x
版本,那么最好先卸载,然后重装 2.x
版本的 aws-cli
。
我看了一下,我用的果然是1.x
版本,于是卸载掉,重装了一个 2.x
版本的 aws-cli
。
但奇怪的事情发生了,我在执行 aws
的时候,会提示该文件不存在:
$ aws
-bash: /old/path/to/aws: No such file or directory # 这是 1.x 老版本的路径
这个文件不存在是对的,因为我已经把旧版本卸载了。可我也安装了新版本啊,难道不应该执行新版本吗?于是我运行了一下 which
:
$ which aws
/new/path/to/aws # 这是 2.x 新版本的路径
这个新路径明明是对的呀!那为什么我实际执行的时候,还是试图执行旧版本的路径呢?
bash 的命令执行路径缓存
上网搜了一下发现,原来 bash 对命令执行的路径也是有缓存的!真是没想到!
检查缓存
可以使用 type
命令检查 bash 是否缓存了某命令的执行路径:
$ type aws
aws is hashed (/old/path/to/aws)
果然,发现 bash 缓存了旧版本的 aws-cli
路径。
删除缓存
执行 hash -d
可以删除相应的执行路径缓存:
$ hash -d aws # 这样就可以了!
果然,现在就可以正常执行 aws
了!