linux 环境变量 删除,linux java环境变量
大家好,今天小编来为大家解答以下的问题,关于linux 环境变量 删除,linux java环境变量这个很多人还不知道,现在让我们一起来看看吧!
linux环境变量怎么设置方法
Linux环境变量的设置和查看方法
Linux TCP/IP协议的使用和建立 Windows批处理切换IP地址使用方法
1.显示环境变量HOME
$ echo$HOME
/home/redbooks
2.设置一个新的环境变量hello
$ export HELLO="Hello!"
$ echo$HELLO
Hello!
3.使用env命令显示所有的环境变量
$ env
HOSTNAME=redbooks.safe.org
PVM_RSH=/usr/bin/rsh
Shell=/bin/bash
TERM=xterm
HISTSIZE=1000
...
4.使用set命令显示所有本地定义的Shell变量
$ set
BASH=/bin/bash
BASH_VERSINFO=([0]="2"[1]="05b"[2]="0"[3]="1"[4]="release"[5]="i386-redhat-linux-gnu")
BASH_VERSION='2.05b.0(1)-release'
COLORS=/etc/DIR_COLORS.xterm
COLUMNS=80
DIRSTACK=()
DISPLAY=:0.0
...
5.使用unset命令来清除环境变量
set可以设置某个环境变量的值。清除环境变量的值用unset命令。如果未指定值,则该变量值将被设为NULL。示例如下:
$ export TEST="Test..."#增加一个环境变量TEST
$ env|grep TEST#此命令有输入,证明环境变量TEST已经存在了
TEST=Test...
$ unset$TEST#删除环境变量TEST
$ env|grep TEST#此命令没有输出,证明环境变量TEST已经存在了
6.使用readonly命令设置只读变量
如果使用了readonly命令的话,变量就不可以被修改或清除了。示例如下:
$ export TEST="Test..."#增加一个环境变量TEST
$ readonly TEST#将环境变量TEST设为只读
$ unset TEST#会发现此变量不能被删除
-bash: unset: TEST: cannot unset: readonly variable
$ TEST="New"#会发现此也变量不能被修改
-bash: TEST: readonly variable
环境变量的设置位于/etc/profile文件
如果需要增加新的环境变量可以添加下属行
export path=$path:/path1:/path2:/pahtN
-----------------------------------------------------------------------------------------------------------------------
1.Linux的变量种类
按变量的生存周期来划分,Linux变量可分为两类:
1.1永久的:需要修改配置文件,变量永久生效。
1.2临时的:使用export命令声明即可,变量在关闭shell时失效。
2.设置变量的三种方法
2.1在/etc/profile文件中添加变量【对所有用户生效(永久的)】
用VI在文件/etc/profile文件中增加变量,该变量将会对Linux下所有用户有效,并且是“永久的”。
例如:编辑/etc/profile文件,添加CLASSPATH变量
# vi/etc/profile
export CLASSPATH=./JAVA_HOME/lib;$JAVA_HOME/jre/lib
注:修改文件后要想马上生效还要运行# source/etc/profile不然只能在下次重进此用户时生效。
2.2在用户目录下的.bash_profile文件中增加变量【对单一用户生效(永久的)】
用VI在用户目录下的.bash_profile文件中增加变量,改变量仅会对当前用户有效,并且是“永久的”。
例如:编辑guok用户目录(/home/guok)下的.bash_profile
$ vi/home/guok/.bash.profile
添加如下内容:
export CLASSPATH=./JAVA_HOME/lib;$JAVA_HOME/jre/lib
注:修改文件后要想马上生效还要运行$ source/home/guok/.bash_profile不然只能在下次重进此用户时生效。
2.3直接运行export命令定义变量【只对当前shell(BASH)有效(临时的)】
在shell的命令行下直接使用[export变量名=变量值]定义变量,该变量只在当前的shell(BASH)或其子shell(BASH)下是有效的,shell关闭了,变量也就失效了,再打开新shell时就没有这个变量,需要使用的话还需要重新定义。
3.环境变量的查看
3.1使用echo命令查看单个环境变量。例如:
echo$PATH
3.2使用env查看所有环境变量。例如:
env
3.3使用set查看所有本地定义的环境变量。
unset可以删除指定的环境变量。
4.常用的环境变量
PATH决定了shell将到哪些目录中寻找命令或程序
HOME当前用户主目录
HISTSIZE历史记录数
LOGNAME当前用户的登录名
HOSTNAME指主机的名称
SHELL当前用户Shell类型
LANGUGE语言相关的环境变量,多语言可以修改此环境变量
MAIL当前用户的邮件存放目录
PS1基本提示符,对于root用户是#,对于普通用户是$
linux设置环境变量
Linux不像window界面那样可视化更明显、操作也便利;因此大多数人对Linux的设置都比较头疼,一般来说,配置交叉编译工具链的时候需要指定编译工具的路径,此时就需要设置环境变量。例如我的mips-linux-gcc编译器在“/opt/au1200_rm/build_tools/bin”目录下,build_tools就是我的编译工具,则有如下三种方法来设置环境变量。
Linux环境变量基础配置说明
1、直接用export命令:#exportPATH=$PATH:/opt/au1200_rm/build_tools/bin查看是否已经设好,可用命令export查看: [root@localhostbin]#export declare-xBASH_ENV="/root/.bashrc" declare-xG_BROKEN_FILENAMES="1" declare-xHISTSIZE="1000" declare-xHOME="/root" declare-xHOSTNAME="localhost.localdomain" declare-xINPUTRC="/etc/inputrc" declare-xLANG="zh_CN.GB18030" declare-xLANGUAGE="zh_CN.GB18030:zh_CN.GB2312:zh_CN" declare-xLESSOPEN="|/usr/bin/lesspipe.sh%s" declare-xLOGNAME="root" declare-xLS_COLORS="no=00:fi=00:di=01;34:ln=01;36:pi=40;33:so=01;35:bd=40;33;01:cd=40;33;01:or=01;05;37;41:mi=01;05;37;41:ex=01;32:*NaNd=01;32:*.exe=01;32:*.com=01;32:*.btm=01;32:*.bat=01;32:*.sh=01;32:*.csh=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.gz=01;31:*.bz2=01;31:*.bz=01;31:*.tz=01;31:*.rpm=01;31:*.cpio=01;31:*.jpg=01;35:*.gif=01;35:*.bmp=01;35:*.xbm=01;35:*.xpm=01;35:*.png=01;35:*.tif=01;35:" declare-xMAIL="/var/spool/mail/root" declare-xOLDPWD="/opt/au1200_rm/build_tools" declare-xPATH="/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin:/opt/au1200_rm/build_tools/bin" declare-xPWD="/opt/au1200_rm/build_tools/bin" declare-xSHELL="/bin/bash" declare-xSHLVL="1" declare-xSSH_ASKPASS="/usr/libexec/openssh/gnome-ssh-askpass" declare-xSSH_AUTH_SOCK="/tmp/ssh-XX3LKWhz/agent.4242" declare-xSSH_CLIENT="10.3.37.152223622" declare-xSSH_CONNECTION="10.3.37.152223610.3.37.18622" declare-xSSH_TTY="/dev/pts/2" declare-xTERM="linux" declare-xUSER="root" declare-xUSERNAME="root"可以看到,环境变量已经设好,PATH里面已经有了我要加的编译器的路径。
2、修改profile文件:#vi/etc/profile在里面加入: exportPATH="$PATH:/opt/au1200_rm/build_tools/bin"让环境变量立即生效需要执行如下命令:#source/etc/profile
3.修改.bashrc文件:#vi/root/.bashrc在里面加入: exportPATH="$PATH:/opt/au1200_rm/build_tools/bin"
特别说明:方法2、3一般需要重新注销系统才能生效,最后可以通过echo命令测试一下:#echo$PATH看看输出里面是不是已经有了/my_new_path这个路径了。
Linux环境变量配置注意事项
标准位置及非标注位置环境变量:对于:“/bin”、“/sbin”、“/usr/bin”、“/usr/sbin”、“/usr/local/bin”等路径已经在系统环境变量中了,如果可执行文件在这几个标准位置,在终端命令行输入该软件可执行文件的文件名和参数(如果需要参数),回车即可。如果不在标准位置,文件名前面需要加上完整的路径。不过每次都这样跑就太麻烦了,一个“一劳永逸”的办法是把这个路径加入环境变量。命令“PATH=$PATH:路径”可以把这个路径加入环境变量,但是退出这个命令行就失效了。要想永久生效,需要把这行添加到环境变量文件里。有两个文件可选:“/etc/profile”和用户主目录下的“.bash_profile”,“/etc/profile”对系统里所有用户都有效,用户主目录下的“.bash_profile”只对这个用户有效。“PATH=$PATH:路径1:路径2:...:路径n”,意思是可执行文件的路径包括原先设定的路径,也包括从“路径1”到“路径n”的所有路径。当用户输入一个一串字符并按回车后,shell会依次在这些路径里找对应的可执行文件并交给系统核心执行。那个“$PATH”表示原先设定的路径仍然有效,注意不要漏掉。某些软件可能还有“PATH”以外类型的环境变量需要添加,但方法与此相同,并且也需要注意“$”。
注意,与DOS/Window不同,Linux类系统环境变量中路径名用冒号分隔,不是分号。另外,软件越装越多,环境变量越添越多,为了避免造成混乱,建议所有语句都添加在文件结尾,按软件的安装顺序添加。格式如下():#软件名-版本号 PATH=$PATH:路径1:路径2:...:路径n其他环境变量=$其他环境变量:...在“profile”和“.bash_profile”中,“#”是注释符号,写在这里除了视觉分隔外没有任何效果。设置完毕,注销并重新登录,设置就生效了。如果不注销,直接在shell里执行这些语句,也能生效,但是作用范围只限于执行了这些语句的shell。相关的环境变量生效后,就不必老跑到软件的可执行文件目录里去操作了。
Linux配置示例:配置java环境变量
1.修改/etc/profile文件如果你的计算机仅仅作为开发使用时推荐使用这种方法,因为所有用户的shell都有权使用这些环境变量,可能会给系统带来安全性问题。(1)用文本编辑器打开/etc/profile(2)在profile文件末尾加入: JAVA_HOME=/usr/share/jdk1.5.0_05 PATH=$JAVA_HOME/bin:$PATH CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar exportJAVA_HOME exportPATH exportCLASSPATH(3)重新登录注解: a.你要将/usr/share/jdk1.5.0_05jdk改为你的jdk安装目录 b.linux下用冒号“:”来分隔路径 c.$PATH/$CLASSPATH/$JAVA_HOME是用来引用原来的环境变量的值,在设置环境变量时特别要注意不能把原来的值给覆盖掉了,这是一种常见的错误。 d.CLASSPATH中当前目录“.”不能丢,把当前目录丢掉也是常见的错误。 e.export是把这三个变量导出为全局变量。 f.大小写必须严格区分。
2.修改.bashrc文件这种方法更为安全,它可以把使用这些环境变量的权限控制到用户级别,如果你需要给某个用户权限使用这些环境变量,你只需要修改其个人用户主目录下的.bashrc文件就可以了。(1)用文本编辑器打开用户目录下的.bashrc文件(2)在.bashrc文件末尾加入: setJAVA_HOME=/usr/share/jdk1.5.0_05 exportJAVA_HOME setPATH=$JAVA_HOME/bin:$PATH exportPATH setCLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar exportCLASSPATH(3)重新登录
3.直接在shell下设置变量不赞成使用这种方法,因为换个shell,你的设置就无效了,因此这种方法仅仅是临时使用,以后要使用的时候又要重新设置,比较麻烦。只需在shell终端执行下列命令: exportJAVA_HOME=/usr/share/jdk1.5.0_05 exportPATH=$JAVA_HOME/bin:$PATH exportCLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
LinuxRedHat 9.0环境变量配置
变量简介 Linux是一个多用户的操作系统。每个用户登录系统后,都会有一个专用的运行环境。通常每个用户默认的环境都是相同的,这个默认环境实际上就是一组环境变量的定义。用户可以对自己的运行环境进行定制,其方法就是修改相应的系统环境变量。
常见的环境变量$PATH:决定了shell将到哪些目录中寻找命令或程序$HOME:当前用户主目录$MAIL:是指当前用户的邮件存放目录。$SHELL:是指当前用户用的是哪种Shell。$HISTSIZE:是指保存历史命令记录的条数$LOGNAME:是指当前用户的登录名。$HOSTNAME:是指主机的名称,许多应用程序如果要用到主机名的话,通常是从这个环境变量中来取得的。$LANG/LANGUGE:是和语言相关的环境变量,使用多种语言的用户可以修改此环境变量。$PS1:是基本提示符,对于root用户是#,对于普通用户是$,也可以使用一些更复杂的值。$PS2:是附属提示符,默认是“”。可以通过修改此环境变量来修改当前的命令符,比如下列命令会将提示符修改成字符串“Hello,MyNewPrompt:)”。#PS1="Hello,MyNewPrompt:)"$IFS:输入域分隔符。当shell读取输入时,用来分隔单词的一组字符,它们通常是空格、制表符和换行符。$0:shell脚本的名字。例如,在我的Linux系统中:$echo$0/bin/bash$#:传递给脚本的参数个数。:shell脚本的进程号,脚本程序通常会用它生成一个唯一的临时文件,如/tmp/tmfile_例如,在我的Linux系统中:$echo$$ 31038#表示当前shell进程号为31038
export命令 export命令将作为他参数的变量导入到子shell中,并使之在子shell中有效。export命令把自己的参数创建为一个环境变量,而这个环境变量可以被其他脚本和当前程序调用的程序看见。 4.1实验导出变量(1)我们先列出脚本程序export2#!/bin/sh echo"$foo" echo"$bar"(2)然后是脚本export1。在这个脚本的结尾,我们调用export2:#!/bin/sh foo="Thefirstmeta-syntacticvariable" exportbar="Thesecondmeta-syntacticvariable" export2运行这个脚本,将得到如下的输出:$export1#这是个空格,是因为变量foo在export2中不可用,所以$foo被复制为空 Thesecondmeta-syntacticvariable$ 4.2设置一个新的环境变量WELCOME$exportWELCOME="Hello!"$echo$WELCOME Hello!
定制环境变量环境变量是和Shell紧密相关的,用户登录系统后就启动了一个Shell。对于Linux来说一般是bash,但也可以重新设定或切换到其它的Shell。根据发行版本的情况,bash有两个基本的系统级配置文件:/etc/bashrc和/etc/profile。这些配置文件包含两组不同的变量:shell变量和环境变量。前者只是在特定的shell中固定(如bash),后者在不同shell中固定。很明显,shell变量是局部的,而环境变量是全局的。环境变量是通过Shell命令来设置的,设置好的环境变量又可以被所有当前用户所运行的程序所使用。对于bash这个Shell程序来说,可以通过变量名来访问相应的环境变量,通过export来设置环境变量。下面通过几个实例来说明。 5.1使用命令echo显示环境变量#本例使用echo显示常见的变量HOME$echo$HOME/home/lqm 5.2设置一个新的环境变量$exportHELLO=“Hello!”$echo$HELLO Hello! 5.3使用env命令显示所有的环境变量$env SSH_AGENT_PID=1875 HOSTNAME=lqm SHELL=/bin/bash TERM=xterm HISTSIZE=1000…… 5.4使用set命令显示所有本地定义的Shell变量$set BASH=/bin/bash…… 5.5使用unset命令来清除环境变量$exportTEST=“test”#增加一个环境变量TEST$env|grepTEST#此命令有输出,证明环境变量TEST已经存在了 TEST=test$unset$TEST#删除环境变量TEST$env|grepTEST#此命令无输出,证明环境变量TEST已经存在了 5.6使用readonly命令设置只读变量如果使用了readonly命令的话,变量就不可以被修改或清除了。示例如下:$exportTEST="Test"#增加一个环境变量TEST$readonlyTEST#将环境变量TEST设为只读$unsetTEST#会发现此变量不能被删除-bash:unset:TEST:cannotunset:readonlyvariable$TEST="New"#会发现此变量不能被修改-bash:TEST:readonlyvariable 5.7用C程序来访问和设置环境变量对于C程序的用户来说,可以使用下列三个函数来设置或访问一个环境变量。 getenv()访问一个环境变量。输入参数是需要访问的变量名字,返回值是一个字符串。如果所访问的环境变量不存在,则会返回NULL。 setenv()在程序里面设置某个环境变量的函数。 unsetenv()清除某个特定的环境变量的函数。另外,还有一个指针变量environ,它指向的是包含所有的环境变量的一个列表。下面的程序可以打印出当前运行环境里面的所有环境变量:#includestdio.h externchar**environ; intmain(){ char**var; for(var=environ;*var!=NULL;++var) printf("%s\n",*var); return0;} 5.8通过修改环境变量定义文件来修改环境变量。需要注意的是,一般情况下,这仅仅对于普通用户适用,避免修改根用户的环境定义文件,因为那样可能会造成潜在的危险。$vi/etc/bashrc#修改shell变量$vi/etc/profile#修改环境变量定义文件然后编辑你的PATH声明,其格式为: PATH=$PATH:PATH1:PATH2:PATH3:------:PATHN你可以自己加上指定的路径,中间用冒号隔开。环境变量更改后,在用户下次登陆时生效,如果想立刻生效,则可执行下面的语句:$source.bash_profile
定制环境变量需要注意的是,最好不要把当前路径“./”放到PATH里,这样可能会受到意想不到的攻击。完成后,可以通过$echo$PATH查看当前的搜索路径。这样定制后,就可以避免频繁的启动位于shell搜索的路径之外的程序了。
linux环境变量被我删了
在Linux系统中,使用命令行中的unset命令删除环境变量时,该操作仅在当前会话中生效,一旦退出当前会话,环境变量就会恢复原状。如果觉得每次重新设置环境变量过于麻烦,可以采取两种方法来恢复。一种方法是执行source/etc/profile命令,这将使/etc/profile文件中的配置生效,从而恢复环境变量。另一种方法是,如果之前已经将PATH等关键环境变量的内容通过echo命令记录下来,那么可以将这些内容重新设置回去,以确保环境变量的持久性。
以PATH环境变量为例,假设之前使用echo命令将其内容记录在了文件中,那么可以使用cat命令读取该文件的内容,然后通过export命令将其重新设置。具体步骤如下:
1.使用cat命令读取保存的PATH内容:
cat~/.path_backup
2.将读取的内容设置为PATH环境变量:
export PATH="读取的内容"
3.验证设置是否成功:
echo$PATH
这种方法不仅可以帮助你快速恢复已删除的环境变量,还可以避免每次都手动设置环境变量的繁琐操作。需要注意的是,设置环境变量时应确保其路径正确无误,否则可能会影响系统的正常运行。
此外,对于频繁需要设置环境变量的用户,还可以考虑将这些设置写入到shell配置文件(如~/.bashrc或~/.bash_profile)中,这样每次启动新的shell会话时,这些环境变量就会自动被加载,无需手动设置。具体操作步骤如下:
1.打开shell配置文件进行编辑:
vi~/.bashrc
2.在文件末尾添加需要设置的环境变量:
export PATH="/usr/local/bin:/usr/bin:/bin:/usr/local/games:/usr/games"
3.保存并退出编辑器。
4.使更改生效:
source~/.bashrc
通过这种方式,可以确保环境变量在每次启动新的shell会话时都会被正确加载,从而提高工作效率。