
alias 不能跨终端生效,必须写入 shell 配置文件才能持久化。
alias 命令只在当前 Shell 会话有效
直接运行 alias ll='ls -la' 确实能立刻用 ll,但新开一个终端或执行子 shell(比如脚本里调用 bash)就失效了。这不是 bug,是设计如此——alias 是 shell 内建命令,作用域仅限当前 shell 实例。
- 验证方式:新开终端后执行
ll,报错command not found - 临时调试可用,但生产环境或日常使用必须落盘
- 别试图在脚本开头写
alias然后期望后续命令能用——脚本默认不继承交互式 shell 的 alias
写入 ~/.bashrc 还是 ~/.bash_profile?
绝大多数 Linux 桌面环境和 SSH 登录默认启动的是 交互式非登录 shell,它读取 ~/.bashrc;而 ~/.bash_profile 只在登录 shell(如图形界面首次登录、SSH 首次连接)时读取一次。
- 日常终端开多个标签页/窗口 → 读
~/.bashrc - 想让 alias 在所有场景生效,就写进
~/.bashrc - 如果用了 zsh(如 macOS Catalina 后默认),对应文件是
~/.zshrc - 改完记得执行
source ~/.bashrc,否则不会立即生效
带参数的 alias 怎么办?别硬扛,用函数
alias 不支持位置参数(比如 alias grepn='grep -n' 可以,但 alias cdlog='cd /var/log' 就没法传额外路径)。真要动态行为,得上 shell 函数。
grepn() {
grep -n "$1" "$2"
}
- 函数可以访问
$1、$2等参数,还能加条件判断、循环 - 函数定义也写在
~/.bashrc里,和 alias 并列即可 - 别写成
alias grepn='grep -n $1 $2'—— 这里的$1是定义时展开,不是执行时展开,基本等于废
注意 alias 和原命令同名时的覆盖风险
比如 alias ls='ls --color=auto' 是安全的,但 alias cp='cp -i' 虽然防误覆盖,却可能破坏脚本逻辑(脚本依赖 cp 默认无提示)。
- 系统级脚本或定时任务中,
cp行为可能意外被干扰 - 用
\cp可绕过 alias,但得记住并手动加反斜杠 - 更稳妥的做法:给别名起新名字,比如
alias cpi='cp -i',明确语义又不污染原命令 - 查看当前所有 alias 用
alias(不带参数),排查冲突很方便
alias 看似简单,但配置位置、作用域、参数处理、命名冲突这四点,漏掉任一都可能让你花十分钟 debug 为什么“明明写了却不生效”。










