export命令用于将shell变量输入为环境变量,或者将shell函数输入为环境变量。

一个变量创立时,它不会主动地为在它之后创立的shell过程所知。而命令export能够向前面的shell传递变量的值。

命令语法

export [参数]

命令参数

  • -f:指向函数。
  • -n:删除变量的导出属性。
  • -p:显示全副领有导出属性的变量。
  • -pf:显示全副领有导出属性的函数。
  • -nf:删除函数的导出属性。

列出以后所有的环境变量

> export -pdeclare -x CLASSPATH=".:/opt/java/jdk1.8.0_231/lib:/opt/java/jdk1.8.0_231/jre/lib"declare -x HISTCONTROL="ignoredups"declare -x HISTSIZE="1000"declare -x HOME="/root"declare -x HOSTNAME="JD"declare -x JAVA_HOME="/opt/java/jdk1.8.0_231"declare -x JAVA_OPTS="-server -Xms4096m -Xmx4096m -XX:PermSize=256M -XX:MaxNewSize=512m -XX:MaxPermSize=512m"declare -x JRE_HOME="/opt/java/jdk1.8.0_231/jre"declare -x LANG="en_US.UTF-8"declare -x LESSOPEN="||/usr/bin/lesspipe.sh %s"declare -x LOGNAME="root"

定义环境变量

> export RUMENZ

定义环境变量赋值

> export RUMENZ=7

导出一个函数

导出一个func_1的函数
> function func_1(){ echo "123"; }
测试函数输入
> func_1123
在一个bash脚本中调用func_1
> vim test.sh#!/bin/bashfunc_1//执行这个脚本,报错> bash test.shtest.sh: line 3: func_1: command not found
在脚本中也能失常调用func_1函数,这时候就用到了export
> export -f func_1//查看定义的函数> export -pffunc_1 () {     echo '123'}declare -fx func_1
删除func_1的导出属性
> export -fn func_1//再执行脚本> bash test.shtest.sh: line 3: func_1: command not found

让导出的变量永恒失效

在命令行导出的各种变量,函数只是长期无效,下次从新登录,之前定义的变量,函数都将不存在。如果想让咱们定义的变量,函数每次登录零碎都能够用,那么就须要把变量的定义和导出都定义在一个文件外面,而后每次登录零碎都会执行一遍该文件就能够达到目标。

失常登录配置文件程序加载过程,所谓失常登录指用户通过输出用户名和明码登录的状态。

如果想对系统所有用户都失效,能够把变量和导出定义在以下文件

/etc/profile/etc/profile.d/*.sh/etc/bashrc
如:定义JAVA_HOME环境变量
> vim /etc/profile# 在最初加上export JAVA_HOME=/usr/local/jdk1.8export PATH=${JAVA_HOME}/bin:$PATH//立刻失效操作> source /etc/profile

如果只想对某个用户失效,能够在用户的家目录的以下文件中定义变量和导出

~/.bash_profile~/.bashrc
自定义命令行后面的显示。显示用户名、主机名、shell名称
> vim ~/.bashrc# 最初面加上export PS1="\u@\h>\s "//立刻失效> source ~/.bashrc
命令行后面由[root@local ~]#变成root@local>-bash

原文链接:https://rumenz.com/rumenbiji/...
微信公众号:入门小站