.bashrc 和 .profile(或 .bash_profile)分工明确:.profile/.bash_profile 仅登录时执行一次,负责全局 环境变量;.bashrc 每次新建终端即执行,管理 alias、PS1 等交互配置;二者应合理配合,避免重复或失效。

.bashrc 和 .profile(或 .bash_profile)不是“选一个用”,而是分工明确、互相配合的两个文件 。搞清它们各自什么时候执行、管什么内容,才能避免改了不生效、重复设置、 环境变量 丢失等问题。
登录时才跑的:.profile 或 .bash_profile
这个文件只在你 真正登录系统时执行一次,比如通过 ssh 远程登录、图形界面输入密码进入桌面、或者 Ctrl+Alt+F2 切到 TTY 登录。它负责初始化整个会话的“起点环境”——比如 PATH、LANG、EDITOR、java_HOME 这类影响全局行为的变量。
常见情况:
- debian/ubuntu 系统默认用
~/.profile,里面通常有source ~/.bashrc这行,所以它会顺带加载 .bashrc - centos/RHEL 默认用
~/.bash_profile,同样一般也包含source ~/.bashrc - 如果你手动创建了 .bash_profile,但没写 source ~/.bashrc,那每次新开终端就看不到你在 .bashrc 里设的 alias 或 prompt
每次开终端都跑的:.bashrc
只要你点一下“新建终端窗口”、按 Ctrl+Shift+T、或者在 shell 里再输一遍 bash,~/.bashrc 就会被重新读取。它专管 交互式、非登录 shell 的日常体验:
- 别名(alias ll=’ls -l’)
- Shell 提示符(PS1)
- 函数定义(比如 quickcd() { cd ~/projects/$1;})
- 局部 PATH 追加(如加个 bin 目录到当前用户路径末尾)
注意:/etc/bashrc 是系统级的 .bashrc,对所有用户生效,但普通用户一般不需要动它。
系统级配置:/etc/profile 和 /etc/profile.d/
这些是给 所有用户统一兜底 的配置:
-
/etc/profile在每个用户首次登录时执行,设置基础 PATH、umask、系统级变量 -
/etc/profile.d/*.sh是它的扩展机制,比如 Java、node.js、SDK 工具 链常把环境变量写在这里,便于集中管理和卸载 - 修改后不用重启系统,但新登录用户才会看到效果;已登录用户需手动
source /etc/profile或新开终端
怎么改才不踩坑?
推荐做法很直接:
- 通用环境变量(PATH、JAVA_HOME、EDITOR)写进
~/.profile或~/.bash_profile,并确保它source ~/.bashrc - 日常用的 alias、PS1、函数、小 工具 路径,全放在
~/.bashrc里 - 想让所有用户都有某项配置?放进
/etc/profile.d/myenv.sh,比硬改 /etc/profile 更安全、易维护 - 改完记得测试:
source ~/.bashrc看当前终端是否生效;新开一个终端验证非登录场景;SSH 登录一次验证登录场景
基本上就这些。不复杂,但容易忽略执行时机和父子关系。