RedHat Linux Shell常用命令(多数也适用于Unix和AIX)

目的:通过对日常使用的一些Linux命令进行总结分享,希望能给大家一些帮助。
说明:本文的命令都是在RedHat Linux下测试的,Unix和IBM AIX下的命令有所不同,具体查看 man page。如有错误,欢迎指正。

建议:读者在操作的过程中希望形成参考 man page的习惯,非常有用。

1.# 表示权限用户(如:root),$ 表示普通用户
  开机提示:Login:输入用户名
  password:输入口令   用户是系统注册用户成功登陆后,可以进入相应的用户环境.
  退出当前shell,输入:exit

1   [[email protected]02 bin]$
2   [[email protected]02 bin]#

2.useradd netseek 添加一个netseek用户(添加用户前要考虑该用户放在那个用户组,方便日后管理,groupadd)
  passwd netseek  给netseek这个用户设置密码.
  (/etc/passwd /etc/group)
  userdel netseek 删除账号
  userdel -r netseek 删除账号连同自家目录.
  [更详细的操作请参阅man page,和账号管理篇]

3.查看目录和文件命令
  ls -l  显示文件列表(类似于Windows的详细列表)(常用)
  ls -al        -a 显示所有档案及目录 (ls内定将档案名或目录名称开头为"."的视为隐藏档,不会列出)
  ls -al |grep ‘^d‘   显示目录
  ls -al |grep ‘^[^d]‘ 在一个目录中查询不包含目录的所有文件
  ls -sh        (man ls 查看man帮助.)
 
  linux几种文件类型:
  d    表示此文件是一个目录
  -    表示此文件是一个普通文件
  b    表示此文件是一个特殊的块设备I/O文件
  c    表示此文件是一个特殊的字符设备I/O文件
  l    表示此文件是一个连接文件。在其文件名称后紧跟与它连接的文件路径及名称
 
  实例:

1   [[email protected]02 bin]$ ls -l
2   -rw-r-----. 1 etl etl 152023  7月 13 01:06 hs_err_pid8675.log
3   drwxr-x---. 2 etl etl  4096  7月 13 11:04 bin

其中-rw-r-----. 表示该文件的权限,其中第一个‘-‘或者‘d‘表示文件类型,后面的每三个为一组,分别是user,user_group,others的权限信息。
  改变文件权限可以用chmod来实现,后续会讲到或者参见 [man chmod]
 
  file 命令通过探测文件内容判断文件类型

4.建立文件和目录
  touch 1.txt
  cat > 2.txt (用定向符创建文件,填写内容后,按ctrl+d保存内容)
  mkdir mywork 建立mywork这个目录
  rmdir 删除目录(类似于rm -r)

5.拷贝文件或目录
  cp filename1 filename2  目标文件filename2如果存在则覆盖(常用)
  cp -r dir1 dir2 复制目录
  cp -rf 参数f是删除已经存在的目标文件而不提示
  cp -i  参数i和f相反,在覆盖目标文件之前将给出提示要求用户确认,回答y时目标文件将被覆盖,是交互式拷贝.

6.删除文件和目录(删除文件或目录都可以用rm搞定)
  rm 1.c //将1.c这个文件删除(常用)
  rm -rf (强制删除文件或目录,删除时不提示.慎用,考虑帐号的权限和文件的使用者有哪些。)

7.移走目录或者改文件名
  mv [opitons] 源文件或目录   目标文件或目录(常用)
  [options]主要参数
  -i:交互方式操作,如果mv操作将导致对已存在的目标文件的覆盖,此时系统询问是否重写,要求用户回答“y”或“n”,
     这样可以避免误覆盖文件.
  -f:禁止交互操作。mv操作要覆盖某个已有的目标文件时不给任何指示,指定此参数后i参数将不再起作用。
  mv hello ../ 将hello目录或者文件移动上一级.
 
8.alias 别名
  alias dir=‘ls -l‘   输入dir,其实就相当于执行了ls -l
  查看alias 可以用type命令,如

1   [[email protected]02 ~]$ type ll
2   ll is aliased to ‘ls -l --color=auto‘

9.权限的控制,Linux的权限系统为安全提供一层强的保障,(rwx 421)
  chmod +x hello.sh 赋于可执行权限.
  (详细介绍一下权限的控制)
  chmod 命令 权限修改 用法:chmod 一位8进制数 filename (rwx 421)
 eg: chmod u+x filenmame      只想给自己运行,别人只能读
  chown netseek.netseek mydir  改变用户属组

u:表示文件所有者
    g:表示同组用户
    o:表示其它用户
    a:表示所有用户
    opt则是代表操作,可以为:
    +:添加某个权限
    -:取消某个权限
    =:赋予给定的权限,并取消原有的权限
    而mode则代表权限:
    r:可读 4
    w:可写 2
    x:可执行 1

10.pwd 显示当前目录完整路径和改变目录(常用)
  cd netseek 进入netseek这个目录
  cd 退出当前目录
  cd ../ 进入上一级目录.
  cd - 返回上一次目录(非常实用的一个操作,可以快速的在两个目录间切换)(常用)
  cd ~ 返回主目录

11. 查看文本信息cat,more,less,vi,tail 命令
  将某个文件的内容显示出来,两个命令不同的是:cat 把文件内容一直打印出来,而more则分展显示。
  less 可以上下翻滚查看内容,支持vi命令的翻页。
  cat > 1.txt 可以填写或者复制内容,按ctrl+d保存
  cat 1.c
  more 1.c
  head -n filename 显示第N行的内容
 
  tail -n filename 显示后N行的内容
  tail -n 20 /var/log/message 显示最新的20行日志
  tail -10f filename  显示后N行的内容,并打印更新(常用)

12.设置linux时间和日期
  date 命令("date MMDDhhmmYYYY.ss")
  2006年7月24日12:37 ,30秒
  date 072412372006.30
  date -s 20:30:30 #设置系统时间为20: 30:30
  date -s 2006-7-24 #设置系统时期为2006-7-24
  clock -r #对系统Bios中读取时间参数
  clock -w #将系统时间(如由date设置的时间)写入Bios
 
  time - time a simple command or give resource usage
  time 命令用于计算程序消耗的系统时间,使用方法是:

1   [[email protected]02 ~]$ time test.sh
2   test.sh is done.
3   real    0m1.003s
4   user    0m2.000s
5   sys     0m0.003s

13.查看找文件(find,grep,awk更多的请参照man page或shell编程专题讲解)
  几种介绍:
  find 路径  -name 文件名
  find /etc -name named.conf   结合-exec参数能实现很灵活的查找(常用)
  locate 通过文件名搜索文件的工具(要先通过updatedb建立索引数据库)
  localte named.conf
  whereis 是寻找二进制文件,同时也会找到其帮助文件
  which 和where 相似,只是我们所设置的环境变量中设置好的路径中寻找;比如;

14.查杀进程
  ps 给出一个系统当前的进程拍照
  配合grep能灵活地找出自己关心的进程

ps -ef |grep dss
  ps aux
  ps -ef |grep  (常用)  
  kill -9  
  看看哪个进程占用的内存最大  
  ps -aux|sort +5n

找出进程后比较多的操作是kill进程, (常用)

1  [[email protected]02 ~]$ ps -ef |grep etl
2  etl       1758 29117  0 Jul12 pts/8    00:00:00 vim dpi_mon.sh
3  [[email protected]02 ~]$ kill -9 1758

列出一种比较酷的快速杀程序的方式(先理解在使用,避免误杀):
  ps -ef |grep "dss -s tm_user_*.tcl" | grep -v grep | awk ‘{print $2}‘ | xargs kill -9

将程序放在前后台执行
  cp file1 file2 &
  &与ctrl+z 你可以使用&或ctrl+z来将命令放在后台执行.
  fg 是将放在后台执行的程序再放回前台.
  jobs

15.dd命令备份
  dd if="input_file" of="out_file" bs="block_size" count="number"
  参数:
  if:就是input file可以是设备
  of:就是output file也可以是设备
  bs:规划的一个block的大小,如果没有设定时,预设是512bytes
  count:多少个bs的意思.
  dd if=/etc/password of=/tmp/passwd.bak 备份
 
16.mount 加载一个硬件设备
  用法:mount [参数] 要加载的设备 载入点
  eg: mount /dev/cdrom
  cd /mnt/cdrom //进入光盘目录
   u盘:
   mkdir /mnt/usb;(注:创建挂载目录)
   mount /mnt/sda1 /mnt/usb;(注:挂载U盘)
   现在就可以使用U盘了,在/mnt/usb目录下的内容就是U盘里的内容了;
   使用完后,用以下命令卸载U盘即可。
   umount /mnt/usb
   mount     列出系统所有的分区
   mount -t iso9660 /dev/cdrom /mnt/cdrom   挂载光盘
   mount -t vfat /dev/fd0 /mnt/floppy       挂载软盘
   mount -t vfat -o iocharset=utf8,umask=000 /dev/hda2 /mnt/hda2   挂载fat32分区
   mount -t ntfs -o nls=utf8,umask=000 /dev/hda3 /mnt/hda3         挂载ntfs分区
   Linux-NTFS Project: http://linux-ntfs.sourceforge.net/
   umount /mnt/hda3 缷载
   注:挂载设备前,请先fdisk -l 看一下.

17.su在不退出登陆的情况下,切换到另一个身份
    用法: su -l 用户名(如果用户名缺省,则切换到root状态)
  eg:su -l netseek (切换到netseek这个用户,将提示输入密码),加上-表示切换到用户的环境变量.
    sudo 利用他可以执行root执行的权限

su -      切换到root用户

18.whoami,id,w,lastlog,users,groups
   w       查看用户登陆信息
   who     查看当前登陆用户
   last    最近一个月用户登陆情况
   lastlog 检查某特定用户上次登录的时间,并格式化输出上次登录日志/var/log/lastlog的内容
   whoami  确认自己身份.
   id      打印出自己的UID以及GID.(UID:用户身份唯一标识.GID:用户组身份唯一标识.每一个用户只能有一个唯一的UID和GID.)
   users
   groups  用户所归属的用户组查询;
   finger -l netseek root
   finger -s 或者直接finger
   可以让使用者查询一些其他使用者的资料
  eg: finger //查看所用用户的使用资料
  finger root //查看root的资料

19.用户用过的命令和执行历史执行的命令
   history 显示用户过去命用的命令,用于查找以前执行过的命令,避免重复编写命令,配合grep使用
   !!执行最近一次的命令

!vi  执行前一次的vi命令,参数也是上一次执行的(常用)

20.uname 查看linux系统信息
   参数:-a 所有信息 -r 版本号 -n 主机名
   cat /etc/issue   查看系统分发版本

21.建立软连接
   ln [-sf] source target
   ln souce-file hard-link
   ln -sf source-file soft-link
   s表示软连接,f表示,若有同名文件在,则将它覆盖过去.
   注:硬链接不能为目录创建,只有文件才能创建硬链接。

22.查看目录
   du -sh   目录或者文件(常用)
   du -m    du系统默认输出是以KB,以参数-m表示以MB显示.
   cat /etc/fstab   查看分区列表
   fdisk -l
   df -h
   df -ah

23.查看linux系统占用的资源(top,free,uptime)都是非常实用的,当然还有外部命令如nmon,也是很优秀的。
   top   查看后台程序,监控系统性能(常用)
   top -d 2 每两秒列新一次
   top -d -2 -p3690 查看某个PID
   top -b -n 2 >/tmp/top.txt 将top的信息进行2次,然后将结果输出到/tmp/top.txt
 
   free -m 查看系统内存使用情况

1    [[email protected]02 ~]$ free -m
2                 total       used       free     shared    buffers     cached
3    Mem:        129040      57877      71163          0         31       6654
4    -/+ buffers/cache:      51190      77850
5    Swap:        81919        231      81687

uptime  显示目前系统开机时间(查看开机多久,多少人登陆,过去1,5,15分钟系统的负载)

1    [[email protected]02 ~]$ uptime
2    11:38:17 up 102 days, 14:19, 11 users,  load average: 1.43, 1.57, 2.27

24.文件比软件(文本文件比较明显):
   cmp  cmp(“compare”的缩写)命令用来简要指出两个文件是否存在差异,它的使用权限是所有用户
   diff diff命令用于两个文件之间的比较,并指出两者的不同,它的使用权限是所有用户

25.远程操作与文件传输
   ssh [email protected]   远程登录主机(常用)
   scp [email protected]:/remote/path /local/path  远程拷贝文件
   scp /local/path [email protected]:/remote/path

26.编译c/c++文件
   gcc
   gcc -v 查看GCC版本
   gcc -o test test.c 2>errfile 编译test.c时若有错误信息,则将错误信息重定向到errfile

27.chattr +i filename 禁止删除,chattr -i filename 取消禁止
   lsattr 查看隐藏档属性

28.任务自动化执行
   at 执行一次
   crontab 定时循环执行程序(常用)
   crontab 介绍
   1 以root登录
   2 # crontab -e
   3 加入一行
   1 */12 * * * /usr/sbin/ntpdate pool.ntp.org
   分钟 (0-59)
   小時 (0-23)
   日 期 (1-31)
   月份 (1-12)
   星期 (0-6)//0代表星期天
   
   常用命令(查看、编辑):

1    [[email protected]02 ~]$ crontab -l
2    [[email protected]02 ~]$ crontab -e

29.关机和重启(非管理员勿动):
   shutwond [-t 秒数] [-rkhncff] 时间 [警告信息]
   -t 秒数:设置在切换至不同的runlevel之前,警告和删除两信号之彰间的延迟时间(秒)
   -k 发出警告信息,但不是真的要shutdown
   -r shutdown这后重新开机
   -h shutdown这后开机
   -n 不经过init,由shutdown命令本身来做开机工作(不建议你使用)
   -f 重新开机时,跳过fsck指令,不检查文件系统.
   -F 重新开机时,强迫做fsck检查.
   -c 将已经正在shutdown的动作取消
   shutdown -h now 立刻关机,其中now相当于时间为0,halt,poweroff也可以关机,或者直接init 0
   shutdown -h 20:30  系统将在今晚的8:30关机
   shutdown -h +10    系统再过十分钟后自动关机.
   shutdown -t3 -r now  立刻重新开机,但在警告和删除processes这间,
   shutdown -k now  ‘Hey! Go away! now...‘ 发出警告信息,但没有真的关机.
 
   reboot:
   shutdown -r now 几乎与reboot相同,不关建议用reboot执行如下:
   shutdown -r +30 ‘The system wiil reboot‘
   shutdown -r +10 ‘Hey!Go away!‘  10分钟后系统重启.
   #sync; sync; sync; reboot   注:sync将数据同步写入硬盘
   halt命令相当于shutdown -h now ,表示立刻关机。
   reboot命令相当于shutown -r now ,表示立刻重起。
   
   last reboot命令可以查看近期的机器重启情况

30.如何改变启动模式运行级别
   vi /etc/inittab
   将5改成3,启动后就可以变成字符模式。
   startx 或者 init 5 就可以进入图形化界面.
   runlevel 显示当前运行级别

如何切换至单用户模式
  利用telinit或init(其实telinit只是一个synbol link to init)
  telinit 1 或者 init S 即可,当然telinit S也是可以的.

如何使ctrl+alt+del 三键失效的方法
  #vi /etc/inittab
  在ca::ctrlaltdel:/sbin/shutdonw -t3 -r now之前加上注释#
  然后执行#telinit q ,参数q是要telinit重新检查一次/etc/inittab

31.TAB  巧用tab键,当你不知道文件或命令的全名是请连续按两下tab键.(常用)
 
32.clear 清屏

33.dmesg |more 显示开机信息(查看系统启动时硬件信息)
 
34.改变程序执行的优秀级
   nice    设置优先权 nice -n -5 vi & 用root给一个nice值为-5,用于执行vi
   renice  调整已存在优先权

35.模块相关的命令
   lsmod 显示已经载入系统的模块
   depmod 分析可载入系统的相依性
   modinfo 显示kernel模块的信息
   insmod  载入模块
   modprobe 自动处理可载入模块
   rmmod    删除模块
 
36.chkconfig --list 显示各种服务的状态,利用chkconfig可以轻松管理init脚本.

37.linux的几种解压缩命令,很实用,对文本文件的压缩比通常较高,建议大文件压缩后下载
   compress aaa  将aaa文件压缩成为aaa.Z
   compress -d aaa.z 将aaa.z文件压缩成aaa
 
   gzip aaa 压缩命令(常用)
   gzip -d aaa.gz  解压命令
 
   bzip2 -z filename 压缩,同上加-d参数解压
   bzcat filename.bz 查看压缩文件内容
 
   tar -czvf aaa.tar.gz aaa 将目录aaa压缩成aaa.tar.gz   (常用)
   tar -N ‘2007/03/01‘ -zcvf home.tar.gz /home 在/home当中,比2007/03/01新的文件才备份.
   tar --exclude /home/cao -zxvf myfile.tar.gz /home/* /etc 要备份/home,/etc,但不要/home/cao
   cd /tmp; tar -cvf -/etc | tar -xvf - 将/etc/打包后直接解开/tmp底下,而不产生文件.
   tar zxvf aaa.tar.gz 解压缩命令.
   tar jxvf aaa.tar.bz2 解压命令
   tar zxvf aaa.tar.gz -C /var/www 将aaa.tar.gz解压到/var/www目录下
   cpio -covB > [file|device] 备份
   cpio -icduv < [file|device] 还原

38.网络命令
   ifconfig 显示或设置网络设备,可以查看当前ip,类似于windows里的ipconfig(常用)
   service network restart(/etc/rc.d/init.d/network restart) 重启网卡
   ifdown eth0 关闭网卡
   ifup eth0 开启网卡
   route -n 查看路由表
   route add -net 192.168.20.1 netmask 255.255.255.0 dev eth0
 
   traceroute
   
   hostname 显示主机名
   hostname -i 显示当前主机名的IP.

39.系统集成管理菜单.
   setup   系统服务管理命令
   ntsysv  设置系统服务

40.fdisk /mbr 删除GRUB

41.数据库启动,开源的mysql用的比较普遍
 启动mysql:
 service mysqld start(/etc/rc.d/init.d/mysqld start)
 mysql -uroot -p 输入密码即可操作mysql数据库.

启动Oracle
 su - oracle
 $lsnrctl stop
 $lsnrctl start
 sqlplus /nolog
 conn /as sysdba(connected)
 startup

42.安装软件包放较多,其中rpm为最简单易用切不用连网
 rpm包安装:
 rpm -ivh xxx.rpm         安装rpm包
 rpm -qa --last | less    根据安装日期显示已经安装的包
 rpm -qa |grep mysql -i   查询系统是否安装mysql包(-i,忽略大小写)
 rpm -e                   删除安装的软件包
 rpm -e mysql* --nodpes   强制删除相关的软件包
 rpm --test               测试安装
 rpm -qi                  查询mysql套件的说明资料
 rpm -qpl xxx.rpm         查看rpm包内含的内容.
 rpm -qc[d]               设定档与说明档
 rpm -Uvh                 升级安装
 rpmbuild --bb SPECS/xxx.spec 重新装将xxx.spec编译成rpm包.
 rpmbuild --rebuild packagename.src.rpm 重新把.src.rpm编译成rpm包.
 
 源码编译安装(经典)
 ./configure              检查系统信息(./configure --help | more 帮助信息,可以看到相关的参数设定)
 make clean               清除之前留下的文件
 make                     编译
 make install             安装
 注:源码包安装,一般先将文件解压,安装过程大致上面几步,具体说明一般见解压后目录里的(INSTALL,READEME说明.)

43.查看系统的编码
 locale  查看系统编码设置,将crt软件的编码配置一致以保证远程登录正常显示

1  [[email protected]02 ~]$ locale
2  LANG=zh_CN.UTF-8
3  LC_CTYPE="zh_CN.UTF-8"
4  LC_NUMERIC="zh_CN.UTF-8"

44.查看网络端口的使用情况
 netstat  查询网络连接、路由表、端口使用情况、多播用户关系等。
 通常服务器上应用都有自己专属的侦听端口,灵活地使用netstat能很好的知道端口的使用情况。
   netstat 查看网络连接情况
   netstat -i 显示网卡运行情况
   netstat -r 查看主机的路由列表
 详细的参数,请参见man page

1  [[email protected]02 ~]$ netstat -anp |grep 7502
2  (Not all processes could be identified, non-owned process info
3   will not be shown, you would have to be root to see it all.)
4  tcp        0      0 :::7502                     :::*                        LISTEN      11513/etl_realstream5  tcp   7663357      0 ::ffff:10.173.255.85:7502   ::ffff:10.168.33.97:59381   ESTABLISHED 11513/java
6  tcp   7673984      0 ::ffff:10.173.255.85:7502   ::ffff:10.168.33.97:59363   ESTABLISHED 11513/java
7  tcp   7678747      0 ::ffff:10.173.255.85:7502   ::ffff:10.168.33.97:59437   ESTABLISHED 11513/java    

参考: http://www.cnblogs.com/czh-liyu/archive/2008/04/11/1148722.html

时间: 2024-10-24 19:47:48

RedHat Linux Shell常用命令(多数也适用于Unix和AIX)的相关文章

Linux Shell常用命令总结

1.   find       find pathname -options [-print -exec -ok]       让我们来看看该命令的参数:       pathname find命令所查找的目录路径.例如用.来表示当前目录,用/来表示系统根目录.       -print find命令将匹配的文件输出到标准输出.       -exec find命令对匹配的文件执行该参数所给出的shell命令.相应命令的形式为'command' {} \;,注意{}和\:之间的空格,同时两个{}

Linux shell 常用命令大全 每日一更

大一上学期学习了Linux的基本操作,已经很久没使用了,虚拟机也近半年没开(作为一个计算机类专业的少年真的不应该).为了补回这些知识和为将来的学习打下基础,现在每天更新一条shell命令及其子命令,欢迎查看.命令主要按字母顺序排列,网上也可以找到,以作用排列比较方便查看,也不容易漏掉一些命令. Linux下常用文件管理命令: pwd          显示当前目录绝对路径名,个人觉得挺好用的一个命令 ls -参数 显示当前目录下的文件 参数选项:-a ->列举目录中所有文件,包括目录下的隐藏文件

Linux Shell 常用命令

Linux Shell 中的反引号,单引号,双引号的区别 1.反引号位 (`):在Linux中起着命令替换的作用.命令替换是指shell能够将一个命令的标准输出插在一个命令行中任何位置. 和$()是一样的.在执行一条命令时,会先将其中的 `` ,或者是$() 中的语句当作命令执行一遍,再将结果加入到原命令中重新执行, 例如:echo `ls` 会先执行 ls 得到 xx.sh等,再替换原命令为:echo xx.sh [[email protected] ~]# echo today is $(d

Linux Shell常用命令总结(51cto 博客搬迁)

1.   find      find pathname -options [-print -exec -ok]      让我们来看看该命令的参数:      pathname find命令所查找的目录路径.例如用.来表示当前目录,用/来表示系统根目录.      -print find命令将匹配的文件输出到标准输出.      -exec find命令对匹配的文件执行该参数所给出的shell命令.相应命令的形式为'command' {} \;,注意{}和\:之间的空格,同时两个{}之间没有空

Linux Shell常用命令手册(Updating)

检查远程端口是否对bash开放: nc -nvv $IP $PORT telnet $IP $PORT 当前任务的前后台切换: Ctrl + z fg 截取变量前5个字符: ${variable:0:5} SSH debug 模式: ssh -vvv [email protected]_address SSH with pem key: ssh [email protected]_address -i key.pem 监视日志文件 tail -f $FILE_NAME 多个监视的脚本 multi

linux shell常用命令

for循环 applist=(app1 app2 app3);for app in ${applist[@]};do echo $app;done; 获取IP地址 ifconfig |grep -Po '(?<=addr:).*(?=Bc)' ifconfig|awk -F"[: ]+" '$4~/[0-9].+[^0-9]+/{print $4}/lo/{exit}' ifconfig|sed -nr 's/^[[:space:]]+inet addr:(.*) Bcast.*

Linux——note shell常用命令 cut 、sort、unqi、tee、tr、split和shell中连接符&& ||

1.cut 常用作将一个文件分段 cut -d'分隔符' [-cf] n -d 后面指定分隔符,用单引号引起来. -f 指定第几段 -c 后面只有一个数字表示截取第几个字符,后面跟一个数字区域,表示截取从几到几. [[email protected] ~]# cut -d: -f 3 /etc/passwd [[email protected] ~]# cut -d: -f 3,4 /etc/passwd [[email protected] ~]# cut -c 10 /etc/passwd

linux下常用命令备忘

转自:Linux 命令集锦 linux下查看监听端口对应的进程 # lsof -i:9000 # lsof -Pnl +M -i4 如果退格键变成了:"^h". 终端连接unix删除退格键,按住CTL键同时按delete Linux搜索 # find / -name "xxx.conf" 查看linux是32位还是64位的命令 #file /sbin/init #getconf LONG_BIT #getconf -a 在Linux和Windows下都可以用nslo

Linux Shell常用技巧(一)

一.    特殊文件: /dev/null和/dev/tty Linux系统提供了两个对Shell编程非常有用的特殊文件,/dev/null和/dev/tty.其中/dev/null将会丢掉所有写入它的数据,换句换说,当程序将数据写入到此文件时,会认为它已经成功完成写入数据的操作,但实际上什么事都没有做.如果你需要的是命令的退出状态,而非它的输出,此功能会非常有用,见如下Shell代码:    /> vi test_dev_null.sh        #!/bin/bash    if gre