0

0

如何在Linux系统中设置环境变量?自定义PATH和其他变量的详细步骤

蓮花仙者

蓮花仙者

发布时间:2025-09-03 11:47:01

|

1085人浏览过

|

来源于php中文网

原创

答案:在Linux中设置环境变量需编辑shell配置文件(如~/.bashrc、~/.zshrc)或系统文件(如/etc/environment),临时设置用export,永久设置则追加到PATH避免覆盖,Zsh配置集中于~/.zshrc,Bash推荐~/.bashrc并由~/.bash_profile加载,确保交互式终端生效。

如何在linux系统中设置环境变量?自定义path和其他变量的详细步骤

在Linux系统中设置环境变量,主要是通过编辑shell的配置文件(如

~/.bashrc
,
~/.profile
, `
~/.zshrc
等)或系统级别的配置文件(如
/etc/environment
,
/etc/profile
),然后让这些更改生效。对于自定义
PATH
,通常的做法是把你的新目录路径添加到现有的
PATH
变量后面,确保系统能找到你常用的命令和脚本。

解决方案

设置Linux环境变量这事儿,说白了就是告诉你的操作系统和shell,去哪里找程序,或者某个特定值是什么。这不像Windows那样点点鼠标,但一旦理解了,你会发现它灵活得多。

最直接、最常用的方法,是修改你当前用户家目录下的shell配置文件。如果你用的是Bash,那通常是

~/.bashrc
~/.profile
;Zsh用户则会用到
~/.zshrc

1. 临时设置环境变量: 如果你只是想在当前终端会话中临时使用某个变量,或者测试一下,可以直接在命令行里用

export
命令。 比如,我想让系统知道我的Java安装路径:

export JAVA_HOME="/usr/lib/jvm/java-11-openjdk-amd64"

或者,想把一个自定义的脚本目录加到

PATH
里:

export PATH=$PATH:/home/youruser/my_scripts

这种方式,一旦你关闭当前终端窗口,或者开启一个新的终端,这些设置就消失了。方便快捷,但不够持久。

2. 永久设置用户级环境变量: 这是我们最常做的。打开你的shell配置文件,比如

~/.bashrc
(如果你是Bash用户,并且主要用于交互式非登录shell),或者
~/.profile
(通常用于登录shell,也会被其他shell读取)。我个人倾向于把大部分自定义的路径和变量放在
~/.bashrc
里,因为我大部分时间都在交互式终端里工作。

用你喜欢的文本编辑器打开文件,比如

nano
vim

nano ~/.bashrc

在文件末尾添加你的变量。

添加自定义变量:

# 我的自定义应用路径
export MY_APP_HOME="/opt/my_cool_app"
# 另一个自定义配置
export MY_CONFIG_DIR="/etc/my_config"

修改PATH变量: 为了避免覆盖系统原有的

PATH
,我们通常会把新路径追加到现有
PATH
的后面。这样做更安全,也更符合预期。

# 将我的脚本目录添加到PATH
export PATH=$PATH:/home/youruser/bin
# 将自定义应用的可执行文件目录添加到PATH
export PATH=$PATH:$MY_APP_HOME/bin

注意,

:
是路径分隔符。
$PATH
代表当前
PATH
变量的值。

3. 使设置生效: 修改完配置文件后,你需要让当前的shell重新加载它,或者干脆退出当前会话再重新登录。 重新加载的方法是使用

source
命令:

source ~/.bashrc
# 或者
. ~/.bashrc

如果修改的是

~/.profile
,可能需要注销并重新登录才能完全生效。

4. 系统级环境变量(针对所有用户): 如果你希望所有用户都能使用某个环境变量,或者某个应用程序需要全局的变量,可以修改系统级别的配置文件。

  • /etc/environment
    : 这个文件通常用于设置系统级的、与shell无关的环境变量。它只包含
    KEY=VALUE
    对,不支持逻辑或命令。
    JAVA_HOME="/usr/lib/jvm/java-11-openjdk-amd64"
  • /etc/profile
    : 这是所有用户登录时都会执行的脚本。你可以在这里设置
    PATH
    或其他变量。
  • /etc/profile.d/
    : 这个目录下的脚本(通常以
    .sh
    结尾)也会在用户登录时被执行。这是推荐的方式,因为它可以让你为不同的应用程序或服务创建独立的配置文件,便于管理。 例如,创建一个
    /etc/profile.d/my_app.sh
    # /etc/profile.d/my_app.sh
    export MY_APP_HOME="/opt/my_cool_app"
    export PATH=$PATH:$MY_APP_HOME/bin

    修改这些文件需要

    root
    权限,并且更改后通常需要重启系统或者至少让所有用户重新登录才能生效。

我个人的经验是,除非有明确的全局需求,否则尽量在用户自己的

~/.bashrc
~/.zshrc
里处理。这样既安全,又不会影响到其他用户或系统服务。

PATH变量究竟有什么用,以及如何安全地对其进行扩展?

PATH
变量,说白了,就是操作系统在你敲下一个命令(比如
ls
grep
python
)时,它会去哪里找这个命令的可执行文件。它是一个由冒号(
:
)分隔的目录列表。当你输入一个命令,shell会从
PATH
列表的第一个目录开始,逐个查找这个命令对应的可执行文件。一旦找到,就执行它;如果找遍了所有目录都没找到,你就会看到“command not found”的错误。

它的作用不言而喻,没有

PATH
,你每次执行命令都得输入完整的路径,比如
/usr/bin/ls
,这简直是噩梦。

如何安全地扩展

PATH

安全扩展

PATH
的核心原则是:追加,而不是覆盖

错误的做法(会覆盖原有

PATH
):

export PATH="/home/youruser/bin" # 这样会丢失所有系统自带的PATH路径!

正确的做法(追加到现有

PATH
后面):

export PATH=$PATH:/home/youruser/bin

这里

$PATH
是引用了当前
PATH
变量的值,然后用冒号分隔,把你的新路径
/home/youruser/bin
加到后面。这样,系统会先在它原有的那些目录里找命令,如果没找到,才会到你的自定义目录里找。这通常是最佳实践,因为你不想你的自定义脚本覆盖掉系统自带的同名命令。

有时候,你可能希望你的自定义命令优先于系统命令执行。比如,你有一个自己写的

python
脚本,想让它优先于系统自带的
python
解释器被调用。这时候你可以选择将新路径放在
$PATH
的前面:

Glimmer Ai
Glimmer Ai

基于GPT-3和DALL·E2的PPT制作工具

下载
export PATH=/home/youruser/bin:$PATH

这样做需要谨慎,因为它可能会导致你意外地运行了自己版本的命令,而不是系统版本,尤其是在使用一些基础工具时,可能会引发不兼容的问题。我通常只在非常确定的情况下才会这么做,比如某个特定项目的工具链。

一个好的习惯是,把你所有自定义的脚本或者应用的可执行文件都放在一个统一的目录里,比如

~/bin
或者
~/.local/bin
,然后只把这一个目录添加到
PATH
里。这样管理起来会非常方便,也清晰明了。

不同Shell(Bash, Zsh)的环境变量配置有何异同?

虽然Bash和Zsh在很多方面都非常相似,它们在环境变量的加载和配置文件使用上还是有一些微妙但重要的区别。这主要是因为它们处理“登录shell”和“非登录shell”的方式不同。

Bash (Bourne Again SHell):

  • 登录Shell: 当你通过控制台登录(比如物理机登录,或者SSH远程登录),Bash会启动一个“登录shell”。
    • 它会读取
      /etc/profile
      (系统级配置),然后按顺序查找并读取
      ~/.profile
      ,
      ~/.bash_profile
      ,
      ~/.bash_login
      中的第一个存在的配置文件。
    • 我的理解:
      ~/.profile
      通常被设计成一个通用的配置文件,可以被其他shell(比如sh)读取。而
      ~/.bash_profile
      则是Bash特有的。如果你只有Bash,并且想把所有登录shell的配置都放一起,可以只用
      ~/.bash_profile
      。如果想让其他shell也能读取一部分配置,那就把通用部分放在
      ~/.profile
      里,然后在
      ~/.bash_profile
      source ~/.profile
  • 非登录Shell: 当你打开一个新的终端窗口(比如在图形界面下打开
    gnome-terminal
    ),Bash会启动一个“非登录shell”。
    • 它会读取
      ~/.bashrc
    • 我的理解:
      ~/.bashrc
      是存放别名、函数、以及交互式shell特有的环境变量的最佳地点。很多
      ~/.bash_profile
      文件里会有一行代码来
      source ~/.bashrc
      ,这样登录shell也能加载
      ~/.bashrc
      里的配置。这是一个很常见的模式。

Zsh (Z Shell):

Zsh的设计哲学在配置文件加载上略有不同,它更注重模块化和统一性。

  • 登录Shell:
    • 会读取
      /etc/zprofile
      (系统级,类似
      /etc/profile
      ),然后读取
      ~/.zprofile
    • 之后,它还会读取
      /etc/zshrc
      ~/.zshrc
    • 我的理解: Zsh的登录shell会同时处理
      zprofile
      zshrc
      ,这和Bash有点不一样。
  • 非登录Shell:
    • 会读取
      /etc/zshrc
      (系统级)和
      ~/.zshrc
    • 我的理解:
      ~/.zshrc
      是Zsh的核心配置文件,无论登录还是非登录,它都会被读取。因此,大多数Zsh用户会把所有的环境变量、别名、函数等都放在
      ~/.zshrc
      里。这使得Zsh的配置相对更集中和简单。

主要异同总结:

  1. 核心配置文件: Bash主要用
    ~/.bashrc
    (非登录)和
    ~/.profile
    ~/.bash_profile
    (登录)。Zsh则主要依赖
    ~/.zshrc
    ,它同时处理登录和非登录shell的大部分配置。
  2. 加载顺序: Bash对登录和非登录shell有更严格的区别对待。Zsh则更统一,
    ~/.zshrc
    几乎总是被加载。
  3. 通用性:
    ~/.profile
    在Bash中可以被其他兼容sh的shell读取,而
    ~/.bash_profile
    是Bash专有。Zsh的
    ~/.zprofile
    ~/.zshrc
    都是Zsh专有。

实际操作建议:

  • Bash用户:
    • 将只在登录时需要的环境变量(比如设置
      JAVA_HOME
      这种全局路径)放在
      ~/.profile
      ~/.bash_profile
    • 将别名、函数、
      PATH
      扩展(如果你想让所有交互式shell都生效)以及其他交互式shell的配置放在
      ~/.bashrc
    • 确保你的
      ~/.bash_profile
      ~/.profile
      中有一行类似
      [[ -f ~/.bashrc ]] && . ~/.bashrc
      的代码,这样登录shell也能加载
      ~/.bashrc
  • Zsh用户:
    • 直接把所有配置(环境变量、别名、函数等)都放在
      ~/.zshrc
      里。这是最常见和推荐的做法,因为它在登录和非登录shell中都会被读取。

理解这些差异能帮助你避免一些常见的“为什么我的环境变量不生效”的问题,尤其是在从Bash切换到Zsh或者反过来的时候。

我应该把环境变量写在哪里?.bashrc还是.profile?

这是一个非常经典的问题,也是很多初学者容易混淆的地方。简单来说,选择哪个文件取决于你的变量是想在“登录shell”中生效,还是在“所有交互式shell”中生效,以及你是否希望这些变量被其他类型的shell读取。

~/.profile
(或
~/.bash_profile
,
~/.bash_login
):

  • 何时加载: 当你以“登录shell”的方式启动Bash时(例如,通过SSH远程登录,或者在文本控制台登录,或者图形界面启动时会话管理器启动的第一个shell)。
  • 用途: 适合放置那些只在登录时需要设置一次的环境变量,或者你希望在所有登录会话中都可用的变量。比如:
    • JAVA_HOME
      ANDROID_HOME
      等指向特定软件安装目录的变量。
    • PATH
      变量的全局性扩展,如果你希望它对所有登录shell都生效。
    • 其他一些只在会话开始时设置一次的配置。
  • 兼容性:
    ~/.profile
    是一个更通用的文件,可以被其他遵循POSIX标准的shell(如
    sh
    )读取。而
    ~/.bash_profile
    ~/.bash_login
    是Bash特有的。通常,如果你有
    ~/.bash_profile
    ,Bash会优先读取它,并忽略
    ~/.profile
    。很多用户会在
    ~/.bash_profile
    source ~/.profile
    ,以达到兼容性。

~/.bashrc

  • 何时加载: 当你启动一个“非登录交互式shell”时(例如,在图形界面中打开一个新的终端窗口,或者在已有的终端中运行
    bash
    命令)。很多
    ~/.bash_profile
    也会
    source ~/.bashrc
    ,这样登录shell也会加载
    ~/.bashrc
  • 用途: 适合放置那些与交互式会话紧密相关的配置,比如:
    • 别名 (aliases):
      alias ll='ls -alF'
    • 函数 (functions): 自定义的shell函数。
    • PS1
      提示符配置:
      自定义你的命令行提示符。
    • PATH
      变量的追加:
      如果你希望这个
      PATH
      只在你打开的每个终端窗口中生效。
    • 其他一些只在交互式会话中需要的环境变量。

我的个人实践和建议:

我通常会把大部分环境变量和

PATH
的追加都放在
~/.bashrc
里。为什么?因为我的大部分工作都在交互式终端里完成,我希望每次打开新终端都能立即获得这些配置。

我的

~/.bash_profile
通常会比较精简,它会检查
~/.bashrc
是否存在,如果存在就
source
它:

# ~/.bash_profile
if [ -f "$HOME/.bashrc" ]; then
    . "$HOME/.bashrc"
fi

# 可以在这里放一些只在登录时执行一次的命令或变量
# export MY_LOGIN_VAR="This is only set on login"

这样一来,无论我是登录shell还是非登录shell,

~/.bashrc
中的配置都会被加载。这简化了管理,因为我只需要维护一个文件。

例外情况:

  • 系统级变量: 如果是所有用户都需要,或者是非交互式脚本也需要(比如cron job),那么应该考虑
    /etc/environment
    /etc/profile.d/
    下的文件。
  • 非交互式脚本: 如果你的脚本不是通过交互式shell运行的(例如,由
    cron
    定时任务执行),它通常不会读取
    ~/.bashrc
    。在这种情况下,你需要确保脚本所需的变量在脚本内部设置,或者在脚本执行的环境中已经存在(例如,通过
    ~/.profile
    设置的变量,如果
    cron
    环境是登录shell)。

总的来说,对于大多数用户来说,将大部分自定义的环境变量和

PATH
修改放入
~/.bashrc
,并确保
~/.bash_profile
(如果存在)会
source ~/.bashrc
,是一个既简单又高效的策略。这确保了你的交互式终端拥有你所需的一切,同时避免了在多个文件中分散配置的复杂性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1496

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1170

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

835

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

463

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2362

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

874

2023.08.10

windows boot manager
windows boot manager

windows boot manager无法开机的解决方法:1、系统文件损坏,使用Windows安装光盘或USB启动盘进入恢复环境,选择修复计算机,然后选择自动修复;2、引导顺序错误,进入恢复环境,选择命令提示符,输入命令"bootrec /fixboot"和"bootrec /fixmbr",然后重新启动计算机;3、硬件问题,使用硬盘检测工具进行扫描和修复;4、重装操作系统。本专题还提供其他解决

1976

2023.08.28

windows锁屏快捷键
windows锁屏快捷键

windows锁屏快捷键是Windows键+L、Ctrl+Alt+Del、Windows键+D、Windows键+P和Windows键+R。本专题为大家提供windows相关的文章、下载、课程内容,供大家免费下载体验。

1670

2023.08.30

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Linux系统运维及项目正式上线
Linux系统运维及项目正式上线

共14课时 | 2.4万人学习

Linux负载均衡视频教程
Linux负载均衡视频教程

共7课时 | 1.7万人学习

自学IT网Linux进阶视频教程
自学IT网Linux进阶视频教程

共20课时 | 3.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号