浅谈bash shell的种类以及linux系统中的profile和bashrc配置文件

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/LEON1741/article/details/100120749

相信不少玩过linux的人,看到诸如~/.bash_profile、~/.bashrc、~/.profile、/etc/profile、/etc/bashrc之类的文件,都会有似曾相识的感觉,依稀记得配置什么参数或者路径的时候用过这些文件,又或者是修改系统设置的时候改过它们。也有厉害一点的,能指出这些文件其实可以分为两个类别,分别是bashrc和profile,它们都是用来配置环境变量的,当你安装了一些开发工具的时候就要修改这些文件来使得安装的内容能够全局生效。但是,如果要详细的分析一下bashrc和profile究竟是个什么东东,上面这些文件各自的作用,各自的区别,又是否能解释的清楚呢?不急,下面我们就来详细展开。

一、shell的种类

要彻底搞清上面这些个文件的含义和作用,首先要弄明白什么是interactive shell(交互式shell)和non-interactive shell(非交互式shell),什么是login shell(登入式shell)和non-login shell(非登入式shell)。

  • interactive shell(交互式shell)就是shell等待你的输入,并且执行你提交的命令。这种模式被称作交互式是因为shell与用户进行交互。这种模式也是大多数用户非常熟悉的:登录、执行一些命令、签退。当你签退后,shell也终止了。

  • 除了上述的交互式模式,shell也可以运行在另外一种模式:non-interactive shell(非交互式shell)。在这种模式下,shell不与你进行交互,而是读取存放在文件中的命令并且执行它们。当它读到文件的结尾,shell也就终止了。

  • login shell(登入式shell)指的是在取得bash时需要完整的登陆流程。什么时候取得bash呢?当然就是用户登陆的时候。当你在tty1~tty6登陆时,系统会叫你输入账号和密码,此时取得的bash就是一种login shell。

  • non-login shell(非登入式shell)就是取得bash不需要重复登录,就像你在桌面视图中用ctrl+alt+T启动的shell输入窗口就是non-login shell。还有就是你在shell窗口直接su切换的用户,都属于non-login shell。

这两种分类方法是交叉的,也就是说一个login shell可能是一个interactive shell,也可能是个non-interactive shell。

interactive shell(交互式shell)和non-interactive shell(非交互式shell)其实很好理解,无非就是有没有一个显式的交互界面。比较难理解的是login shell(登入式shell)和non-login shell(非登入式shell)。根据网上牛人的总结,login shell与non-login shell的主要区别在于它们启动时会读取不同的配置文件,从而导致各自工作的环境不一样。

  • login shell启动时首先读取/etc/profile全局配置,然后依次查找/.bash_profile、/.bash_login、~/.profile三个配置文件,并且读取第一个找到的并且可读的文件。login shell退出时读取并执行~/.bash_logout中的命令。

  • 交互式的non-login shell启动时读取/.bashrc资源文件。如果我们修改了我们的/.bashrc如果想让配置立即生效,我们只需要用source命令。例如:$ source ~/.bashrc;

  • 非交互式的non-login shell则不读取上述所有配置文件,而是查找环境变量BASH_ENV,读取并执行BASH_ENV指向的文件中的命令;

这样一对比,详细大家应该就比较清楚了。

二、bashrc与profile文件

下面我们就来谈谈bashrc与profile文件。bashrc与profile都用于保存用户的环境信息:

  • bashrc用于交互式non-login shell;

  • profile用于交互式login shell;

如上所述,系统中一般会存在多个bashrc和profile文件,下面逐一介绍:

  • 文件【/etc/profile】:为系统的每个用户设置环境信息。当系统第一个用户登录时,该文件被执行;

  • 文件【/etc/bashrc】:为每一个运行bash shell的用户设置环境信息。当bash shell被打开时,该文件被执行;

  • 文件【~/.profile】:每个用户都可使用该文件输入专用于自己使用的shell信息,该文件仅仅在用户登录的时候执行一次,以后就不再执行,除非你登出之后再重新登录。默认情况下,它设置一些环境变量,然后执行用户的.bashrc文件;

  • 文件【~/.bashrc】:包含专用于某个用户的bash shell的bash信息,当该用户登录时以及每次打开新的shell时,该文件被读取;

另外,/etc/profile中设定的变量的可以作用于任何用户,是全局变量,而~/.bashrc等中设定的变量只能继承/etc/profile中的变量,是局部变量,他们是"父子"关系;

也可以这么解释:

  • 文件【/etc/profile】和【/etc/bashrc】用于设定系统全局的环境变量 ;
  • 文件【/.profile】和【/.bashrc】用于设定单个用户的私有环境变量;

当登入系统时候获得一个shell进程时,其读取环境设定档有三步:

  1. 首先读入的是全局环境变量设定档【/etc/profile】,然后根据其内容读取额外的设定的文档,如
    【/etc/profile.d】和【/etc/inputrc】;
  2. 然后根据不同使用者帐号,去其HOME目录下读取【/.bash_profile】,如果这个文件读取不了就读取【/.bash_login】,这个也读取不了才会读取【~/.profile】,这三个文件设定基本上是一样的,但是读取的时候有优先顺序关系;
  3. 最后在根据用户帐号读取【~/.bashrc】;

猜你喜欢

转载自blog.csdn.net/LEON1741/article/details/100120749