Linux 新手必备的 10个命令
2013-08-10 13:58:12   来源:51cto   评论:0 点击: 收藏

你打算从Windows换到Linux上来,还是你刚好换到Linux上来?哎哟!!!我说什么呢,是什么原因你就出现我的世界里了。从我以往的经 验来说...

你打算从Windows换到Linux上来,还是你刚好换到Linux上来?哎哟!!!我说什么呢,是什么原因你就出现我的世界里了。从我以往的经 验来说,当我刚使用Linux,命令,终端啊什么的,吓了我一跳。我担心该记住多少命令,来帮助我完成所有任务。毫无疑问,在线文档,书籍,man pages以及社区帮了我一个大忙,但是我还是坚信有那么一篇文章记录了如何简单学习和理解命令的秘籍。这激发了我掌握Linux和使它容易使用的积极 性。本文就是通往那里的阶梯。

1. ls命令

ls命令是列出目录内容(List Directory Contents)的意思。运行它就是列出文件夹里的内容,可能是文件也可能是文件夹。

  1. root@tecmint:~# ls 
  2. Android-Games                     Music 
  3. Pictures                          Public 
  4. Desktop                           Tecmint.com 
  5. Documents                         TecMint-Sync 
  6. Downloads                         Templates 

“ls -l”命令已详情模式(long listing fashion)列出文件夹的内容。

  1. root@tecmint:~# ls -l 
  2. total 40588 
  3. drwxrwxr-x 2 ravisaive ravisaive     4096 May  8 01:06 Android Games 
  4. drwxr-xr-x 2 ravisaive ravisaive     4096 May 15 10:50 Desktop 
  5. drwxr-xr-x 2 ravisaive ravisaive     4096 May 16 16:45 Documents 
  6. drwxr-xr-x 6 ravisaive ravisaive     4096 May 16 14:34 Downloads 
  7. drwxr-xr-x 2 ravisaive ravisaive     4096 Apr 30 20:50 Music 
  8. drwxr-xr-x 2 ravisaive ravisaive     4096 May  9 17:54 Pictures 
  9. drwxrwxr-x 5 ravisaive ravisaive     4096 May  3 18:44 Tecmint.com 
  10. drwxr-xr-x 2 ravisaive ravisaive     4096 Apr 30 20:50 Templates 

“ls -a”命令会列出文件夹里的所有内容,包括以"."开头的隐藏文件。

  1. root@tecmint:~# ls -a 
  2. .  .gnupg  .dbus  .goutputstream-PI5VVW   .mission-control 
  3. .adobe  deja-dup  .grsync  .mozilla  .themes 
  4. .gstreamer-0.10   .mtpaint   .thumbnails   .gtk-bookmarks              .thunderbird 
  5. .HotShots   .mysql_history    .htaccess  .apport-ignore.xml          .ICEauthority 
  6. .profile                .bash_history           .icons                  .bash_logout                    .fbmessenger 
  7. .jedit                  .pulse                  .bashrc                 .liferea_1.8                .pulse-cookie 
  8. .Xauthority     .gconf                  .local                  .Xauthority.HGHVWW      .cache 
  9. .gftp      .macromedia             .remmina                .cinnamon                       .gimp-2.8 
  10. .ssh   .xsession-errors    .compiz   .gnome                          teamviewer_linux.deb 
  11. .xsession-errors.old    .config    .gnome2                 .zoncolor 

注意:在Linux中,文件以“.”开头的就是隐藏文件,并且每个文件,文件夹,设备或者命令都是以文件对待。ls -l 命令输出:

  • d (代表了是目录).
  • rwxr-xr-x 是文件或者目录对所属用户,同一组用户和其它用户的权限。
  • 上面例子中第一个ravisaive 代表了文件文件属于用户ravisaive
  • 上面例子中的第二个ravisaive代表了文件文件属于用户组ravisaive
  • 4096 代表了文件大小为4096字节.
  • May 8 01:06 代表了文件最后一次修改的日期和时间.
  • 最后面的就是文件/文件夹的名字

2. lsblk命令

“lsblk”就是列出块设备。除了RAM外,以标准的树状输出格式,整齐地显示块设备。

  1. root@tecmint:~# lsblk 
  2. NAME   MAJ:MIN RM   SIZE RO TYPE MOUNTPOINT 
  3. sda      8:0    0 232.9G  0 disk 
  4. ├─sda1   8:1    0  46.6G  0 part / 
  5. ├─sda2   8:2    0     1K  0 part 
  6. ├─sda5   8:5    0   190M  0 part /boot 
  7. ├─sda6   8:6    0   3.7G  0 part [SWAP] 
  8. ├─sda7   8:7    0  93.1G  0 part /data 
  9. └─sda8   8:8    0  89.2G  0 part /personal 
  10. sr0     11:0    1  1024M  0 rom 

“lsblk -l”命令以列表格式显示块设备(而不是树状格式)。

  1. root@tecmint:~# lsblk -l 
  2. NAME MAJ:MIN RM   SIZE RO TYPE MOUNTPOINT 
  3. sda    8:0    0 232.9G  0 disk 
  4. sda1   8:1    0  46.6G  0 part / 
  5. sda2   8:2    0     1K  0 part 
  6. sda5   8:5    0   190M  0 part /boot 
  7. sda6   8:6    0   3.7G  0 part [SWAP] 
  8. sda7   8:7    0  93.1G  0 part /data 
  9. sda8   8:8    0  89.2G  0 part /personal 
  10. sr0   11:0    1  1024M  0 rom 

注意:lsblk是最有用和最简单的方式来了解新插入的USB设备的名字,特别是当你在终端上处理磁盘/块设备时。

3. md5sum命令

“md5sum”就是计算和检验MD5信息签名。md5 checksum(通常叫做哈希)使用匹配或者验证文件的文件的完整性,因为文件可能因为传输错误,磁盘错误或者无恶意的干扰等原因而发生改变。

  1. root@tecmint:~# md5sum teamviewer_linux.deb 
  2. 47790ed345a7b7970fc1f2ac50c97002  teamviewer_linux.deb 

注意:用户可以使用官方提供的和md5sum生成签名信息匹对以此检测文件是否改变。Md5sum没有sha1sum安全,这点我们稍后讨论。

4. dd命令

“dd”命令代表了转换和复制文件。可以用来转换和复制文件,大多数时间是用来复制iso文件(或任何其它文件)到一个usb设备(或任何其它地方)中去,所以可以用来制作USB启动器。

  1. root@tecmint:~# dd if=/home/user/Downloads/debian.iso of=/dev/sdb1 bs=512M; sync 

注意:在上面的例子中,usb设备就是sdb1(你应该使用lsblk命令验证它,否则你会重写你的磁盘或者系统),请慎重使用磁盘的名,切忌。

dd 命令在执行中会根据文件的大小和类型 以及 usb设备的读写速度,消耗几秒到几分钟不等。

5. uname命令

"uname"命令就是Unix Name的简写。显示机器名,操作系统和内核的详细信息。

  1. root@tecmint:~# uname -a 
  2. Linux tecmint 3.8.0-19-generic #30-Ubuntu SMP Wed May 1 16:36:13 UTC 2013 i686 i686 i686 GNU/Linux 

注意: uname显示内核类别, uname -a显示详细信息。上面的输出详细说明了uname -a

  • “Linux“: 机器的内核名
  • “tecmint“: 机器的分支名
  • “3.8.0-19-generic“: 内核发布版本
  • “#30-Ubuntu SMP“: 内核版本
  • “i686“: 处理器架构
  • “GNU/Linux“: 操作系统名

6. history命令

“history”命令就是历史记录。它显示了在终端中所执行过的所有命令的历史。

  1. root@tecmint:~# history 
  2. 1  sudo add-apt-repository ppa:tualatrix/ppa 
  3. 2  sudo apt-get update 
  4. 3  sudo apt-get install ubuntu-tweak 
  5. 4  sudo add-apt-repository ppa:diesch/testing 
  6. 5  sudo apt-get update 
  7. 6  sudo apt-get install indicator-privacy 
  8. 7  sudo add-apt-repository ppa:atareao/atareao 
  9. 8  sudo apt-get update 
  10. 9  sudo apt-get install my-weather-indicator 
  11. 10 pwd 
  12. 11 cd && sudo cp -r unity/6 /usr/share/unity/ 
  13. 12 cd /usr/share/unity/icons/ 
  14. 13 cd /usr/share/unity 

注意:按住“CTRL + R”就可以搜索已经执行过的命令,它可以你写命令时自动补全。

  1. (reverse-i-search)`if': ifconfig 

7. sudo命令

“sudo”(super user do)命令允许授权用户执行超级用户或者其它用户的命令。通过在sudoers列表的安全策略来指定。

  1. root@tecmint:~# sudo add-apt-repository ppa:tualatrix/ppa 

注意:sudo 允许用户借用超级用户的权限,然而"su"命令实际上是允许用户以超级用户登录。所以sudo比su更安全。

并不建议使用sudo或者su来处理日常用途,因为它可能导致严重的错误如果你意外的做错了事,这就是为什么在linux社区流行一句话:

 “To err is human, but to really foul up everything, you need root password.”

8. mkdir命令

“mkdir”(Make directory)命令在命名路径下创建新的目录。然而如果目录已经存在了,那么它就会返回一个错误信息"不能创建文件夹,文件夹已经存在了"("cannot create folder, folder already exists")

  1. root@tecmint:~# mkdir tecmint 

注意:目录只能在用户拥有写权限的目录下才能创建。mkdir:不能创建目录`tecmint`,因为文件已经存在了。(上面的输出中不要被文件迷惑了,你应该记住我开头所说的-在linux中,文件,文件夹,驱动,命令,脚本都视为文件)。

9. touch 命令

“touch”命令代表了将文件的访问和修改时间更新为当前时间。touch命令只会在文件不存在的时候才会创建它。如果文件已经存在了,它会更新时间戳,但是并不会改变文件的内容。

  1. root@tecmint:~# touch tecmintfile 

注意:touch 可以用来在用户拥有写权限的目录下创建不存在的文件。

10. chmod 命令

“chmod”命令就是改变文件的模式位。chmod会根据要求的模式来改变每个所给的文件,文件夹,脚本等等的文件模式(权限)。

在文件(文件夹或者其它,为了简单起见,我们就使用文件)中存在3中类型的权限。

  1. Read (r)=4 
  2. Write(w)=2 
  3. Execute(x)=1 

所以如果你想给文件只读权限,就设置为'4';只写权限,设置权限为'2';只执行权限,设置为1; 读写权限,就是4+2 = 6, 以此类推。

现在需要设置3种用户和用户组权限。第一个是拥有者,然后是用户所在的组,最后是其它用户。

  1. rwxr-x--x   abc.sh 

这里root的权限是 rwx(读写和执行权限),

所属用户组权限是 r-x (只有读写权限, 没有写权限),

对于其它用户权限是 -x(只有只执行权限)

为了改变它的权限,为拥有者,用户所在组和其它用户提供读,写,执行权限。

  1. root@tecmint:~# chmod 777 abc.sh 

三种都只有读写权限:

  1. root@tecmint:~# chmod 666 abc.sh 

拥有者用户有读写和执行权限,用户所在的组和其它用户只有可执行权限:

  1. root@tecmint:~# chmod 711 abc.sh 

注意:对于系统管理员和用户来说,这个命令是最有用的命令之一了。在多用户环境或者服务器上,对于某个用户,如果设置了文件不可访问,那么这个命令就可以解决,如果设置了错误的权限,那么也就提供了为授权的访问。

相关热词搜索:Linux 新手 必备

上一篇:php+sqlrelay+mysql实现连接池及读写负载均衡
下一篇:如何保持Linux服务器间的文件同步