关于linux:Linux-之-export-命令

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

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理