1.环境变量

            按字面意思理解,环境可以理解为整个linux系统的环境,而变量则是一个可以变化的量或是一个命令。

我们就可以理解为linux的环境变量,就是针对于linux的整个系统而言的,文件或命令。

既然是环境,那么自然就可以理解为一个路径,以及在这个路径目录下存在的文件或命令。

        那我们就可以总结为:

         1,环境变量,是整个系统都可以用的。

         2,环境变量,是储存在系统某个(路径)目录下的文件或命令。

     a 如查看环境变量;

        echo $PATH

          如:

nfyx@nfyx:~$ echo $PATH
/home/nfyx/bin:/home/nfyx/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin

         那么,上面所显示的路径(目录),下的所有文件,都可以在系统的任何地方使用。

(好处,就是不需要再输入绝对路径来执行某条命令了,跟alias 有点相似)

当你输入一个命令时,它会自动去这个路径下搜索,若有就直接执行,若没有,就会弹出(未找到命令)如:

nfyx@nfyx:~$ ddadasd
ddadasd:未找到命令
nfyx@nfyx:~$
若我们自己有一些命令文件,需要当成环境变量来使用呢?

那么,我们就得把这些命令文件的路径(目录),加入到环境变量的路径中去;

如:(我们把一个cp 命令改成一个cpp命令)

nfyx@nfyx:~$ cp /bin/c   (把bin下的cp 复制到test目录下)
cat    chacl  chgrp  chmod  chown  chvt   cp     cpio   
nfyx@nfyx:~$ cp /bin/cp ./test/ 

nfyx@nfyx:~$ cd test/
nfyx@nfyx:~/test$ ls      (进入并查看)
66  77  cp
nfyx@nfyx:~/test$ cp -r ./66 ./88

nfyx@nfyx:~/test$ ls
66  77  88  cp
nfyx@nfyx:~/test$ mv cp ccp  (把cp  改名为ccp)
nfyx@nfyx:~/test$ ls                    (查看)

66  77  88  ccp
nfyx@nfyx:~/test$ ccp                 (运行改过后的命令)
未找到 'ccp' 命令,有28 个相似命令
ccp:未找到命令

nfyx@nfyx:~/test$ pwd
/home/nfyx/test

nfyx@nfyx:~/test$ export PATH=$PATH:/home/nfyx/test(把环境变量后面加一个当前路径,并广播)
nfyx@nfyx:~/test$ ccp                (再运行,显示的效果就不一样了)
ccp: 缺少了文件操作数
Try 'ccp --help' for more information.
nfyx@nfyx:~/test$ ls              
66  77  88  ccp
nfyx@nfyx:~/test$  ccp -r 88 99    (这样子我们就可以直接运行ccp 命令了)
nfyx@nfyx:~/test$ ls
66  77  88  99  ccp
nfyx@nfyx:~/test$

但以上操作只是暂时,把环境变量多加一个目录或路径,一旦重启,就会消息。

若要永久加入,得进行以下操作:

a:

vim /etc/profile    在适当位置添加

PATH=$PATH:/home/nfyx/test

b:

添加一个

customer.sh 文本文件到

/etc/profile.d/目录下,打开它并写入

export PATH=$PATH:/home/nfyx/test

保存退出,若要立即生效输入

source /etc/profile

这样子保存后,就会一直生效,并且对此操作系统的所有用户。

c:

若是只针对某一个用户,那就进行以下操作

vim  ~/.bash_profile

在PATH里面的后面加入/home/nfyx/test

PATH=$PATH:$HOME/.local/bin:$HOME/bin:/home/nfyx/test
export PATH

保存退出就可以了


cp 命令 (复制文件或目录)

复制文件:

cp soure   destination  (soure= 源文件,destination=目标文件 )

cp  file1  file2 

复制目录带参数 -r(单个或多个)

cp soure soure1 ...  destination

cp -r  dir1 dir2     (单个)

cp -r dir1 dir2 ...    dest_dir (多个)

扩展两台linux机器之间的数据传输:

scp 命令:-P 端口 -r  dir

scp -P 端口 /source_file  username@www.xxxxx.com:/dest_dir

scp  -P username@www.xxxx.com:/filename  ./dest_dir


mv  命令 (移动或改名)

若在当前文件下移动,就可理变相的改名。

比如:

nfyx@nfyx:~/test/99$ ls
77  88  aa  bb  cc
nfyx@nfyx:~/test/99$ mv 77 66     (这里把77改名为66)
nfyx@nfyx:~/test/99$ ls
66  88  aa  bb  cc
nfyx@nfyx:~/test/99$ mv aa ./66      (这里把aa移动到66下面)
nfyx@nfyx:~/test/99$ ls ./66
aa
nfyx@nfyx:~/test/99$ ls
66  88  bb  cc
nfyx@nfyx:~/test/99$
这个命令相对来说比较简单。

cat  more less head tail  命令

这个是命令都是查看文件的命令(但cat 命令经常和more 或者less同共使用)

如:

cat /etc/passwd

这样子是显示整个全部,无法看以部分,若要看到部分则需要和more 或 less共同使用

比如: cat /etc/passwd | less  或者  cat /etc/passwd | more
这样子就可以一屏一屏的看。

而 head 和 tail 功能相对来说要强一点

head  命令看一文件的前面的行数(默认为10行)。

如:

head /etc/passwd 
nfyx@nfyx:~/test/99/88$ head /etc/passwd
root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/usr/sbin/nologin
man:x:6:12:man:/var/cache/man:/usr/sbin/nologin
lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologin
mail:x:8:8:mail:/var/mail:/usr/sbin/nologin
news:x:9:9:news:/var/spool/news:/usr/sbin/nologin

若要看多行,则可以用

head -# /etc/passwd  (#=数字)

如:

nfyx@nfyx:~/test/99/88$ head -5 /etc/passwd
root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
sync:x:4:65534:sync:/bin:/bin/sync

tail 命令和head 命令相反,是看一个文件的后面的行数

如:

nfyx@nfyx:~/test/99/88$ tail /etc/passwd
dnsmasq:x:112:65534:dnsmasq,,,:/var/lib/misc:/bin/false
colord:x:113:123:colord colour management daemon,,,:/var/lib/colord:/bin/false
speech-dispatcher:x:114:29:Speech Dispatcher,,,:/var/run/speech-dispatcher:/bin/false
hplip:x:115:7:HPLIP system user,,,:/var/run/hplip:/bin/false
kernoops:x:116:65534:Kernel Oops Tracking Daemon,,,:/:/bin/false
pulse:x:117:124:PulseAudio daemon,,,:/var/run/pulse:/bin/false
rtkit:x:118:126:RealtimeKit,,,:/proc:/bin/false
saned:x:119:127::/var/lib/saned:/bin/false
usbmux:x:120:46:usbmux daemon,,,:/var/lib/usbmux:/bin/false
nfyx:x:1000:1000:nfyx,,,:/home/nfyx:/bin/bash

同理

tail  -# /etc/passwd  (#=数字)

也是一样的。

到些,这几个简单的命令,就可以拿来使用了。

2017.10.25


转载于:https://blog.51cto.com/ainfyx/1976018