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/...
微信公众号:入门小站