共计 1677 个字符,预计需要花费 5 分钟才能阅读完成。
export 命令用于将 shell 变量输入为环境变量,或者将 shell 函数输入为环境变量。
一个变量创立时,它不会主动地为在它之后创立的 shell 过程所知。而命令 export 能够向前面的 shell 传递变量的值。
命令语法
export [参数]
命令参数
- -f:指向函数。
- -n:删除变量的导出属性。
- -p:显示全副领有导出属性的变量。
- -pf:显示全副领有导出属性的函数。
- -nf:删除函数的导出属性。
列出以后所有的环境变量
> export -p
declare -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_1
123
在一个 bash 脚本中调用
func_1
> vim test.sh
#!/bin/bash
func_1
// 执行这个脚本, 报错
> bash test.sh
test.sh: line 3: func_1: command not found
在脚本中也能失常调用
func_1
函数, 这时候就用到了export
> export -f func_1
// 查看定义的函数
> export -pf
func_1 ()
{echo '123'}
declare -fx func_1
删除
func_1
的导出属性
> export -fn func_1
// 再执行脚本
> bash test.sh
test.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.8
export 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/…
微信公众号: 入门小站
正文完