带你玩转Linux命令行(基础入门篇)

  • Post author:
  • Post category:linux


一、学习前准备

帮助文档

Tab 补全


  • Tab

    补全是非常有用的一个功能,可以用来自动补全命令或文件名,省时准确。
  • 未输入状态下连按两次

    Tab

    列出所有可用命令
  • 已输入部分命令名或文件名,按

    Tab

    进行自动补全,多用你就肯定会喜欢的了。

光标


  • up

    方向键上(可以调出输入历史执行记录,快速执行命令)

  • down

    方向键下(配合 up 选择历史执行记录)

  • Home

    移动光标到本行开头

  • End

    移动光标到本行结尾

  • PgUp

    向上翻页

  • PaDN

    向下翻页

  • Ctrl + C

    终止当前程序

  • Ctrl + L

    清屏 =

    clear

    命令(记住这个快捷键,比

    clear

    高效很多)

*man, info, help


  1. man

    命令:Linux下的帮助指令,通过man指令可以查看Linux中的指令帮助、配置文件帮助和编程帮助等信息。

  2. info

    命令:Linux下info格式的帮助指令。就内容来说,info页面比man page编写得要更好、更容易理解,也更友好,但man page使用起来确实要更容易得多。

  3. help

    命令:用于显示shell内部命令的帮助信息。help命令只能显示shell内部的命令帮助信息。而对于外部命令的帮助信息只能使用man或者info命令查看。

远程连接工具

二、玩转Linux命令行之基础篇

在这里我将介绍10组最常用的基础命令行,也是Linux入门必备的命令行,必须牢记于心,学习的过程中可以在Linux上熟练。这也是作为一个计算机专业人士必须熟练操作的最低要求。

1. cd , pwd

> cd


cd

:cd命令用来切换工作目录至dirname。 其中dirName表示法可为绝对路径或相对路径。(cd = Change Directory)

cd命令示例:

# 进入用户主目录
[root@localhost ~]# cd ~ 
# 返回进入此目录之前所在的目录
[root@localhost ~]# cd -
# 返回上级目录(若当前目录为“/“,则执行完后还在“/";".."为上级目录的意思);  
[root@localhost ~]# cd ..
# 返回上两级目录
[root@localhost ~]# cd ../..
# 把上个命令的参数作为cd参数使用。  
[root@localhost ~]# cd !$

> pwd


pwd

:pwd命令以绝对路径的方式显示用户当前工作目录。(pwd = print working Directory)

pwd命令示例:

[root@localhost ~]# pwd
/root


总结

:cd用来切换目录,pwd用来打印工作目录。这两个是初学Linux的第一个命令行,也是任何操作的基础。

2. mkdir , cp , mv , rm , touch

> mkdir


mkdir

:mkdir命令用来创建目录。该命令创建由dirname命名的目录。如果在目录名的前面没有加任何路径名,则在当前目录下创建由dirname指定的目录;如果给出了一个已经存在的路径,将会在该目录下创建一个指定的目录。在创建目录时,应保证新建的目录与它所在目录下的文件没有重名。 (mkdir = make directory)

mkdir命令示例:

# 在/home/frank目录下创建文件夹"hellolinux"
[root@localhost ~]# mkdir /home/frank/hellolinux
[root@localhost /home/frank]# mkdir hellolinux

# 在目录/usr/meng下建立子目录test,并且只有文件主有读、写和执行权限,其他人无权访问
[root@localhost ~]# mkdir -m 700 /usr/meng/test

> cp


cp

:cp命令用来将一个或多个源文件或者目录复制到指定的目的文件或目录。所有目标文件指定的目录必须是己经存在的,cp命令不能创建目录。如果没有文件复制的权限,则系统会显示出错信息。(cp = CoPy)

cp命令示例:

# 将文件file复制到目录/usr/men/tmp下,并改名为file1
[root@localhost ~]# cp file /usr/men/tmp/file1
# 复制目录aaa下所有到/bbb目录下,这时如果/bbb目录下有和aaa同名的文件,需要按Y来确认并且会略过aaa目录下的子目录。
[root@localhost ~]# cp aaa/* /bbb

> mv


mv

:mv命令用来对文件或目录重新命名,或者将文件从一个目录移到另一个目录中,将一组文件移至一个目标目录中。(mv = MoVe)

mv命令示例:

# 重命名,将~目录下的文件名frank.html修改为abby.html
[root@localhost ~]# mv frank.html abby.html
# 将目录/usr/men中的所有文件移到当前目录(用.表示)中
[root@localhost ~]# mv /usr/men/* .

> touch


touch

:touch命令有两个功能:一是用于把已存在文件的时间标签更新为系统当前的时间(默认方式),它们的数据将原封不动地保留下来;二是用来创建新的空文件。(touch = touch 已经是全称了)

touch命令示例:

# 在当前目录下建立一个空文件ex2,然后,利用ls -l命令可以发现文件ex2的大小为0,表示它是空文件。
[root@localhost ~]# touch ex2

> rm


rm

:rm命令可以删除一个目录中的一个或多个文件或目录,也可以将某个目录及其下属的所有文件及其子目录均删除掉。对于链接文件,只是删除整个链接文件,而原有文件保持不变。(rm = ReMove)


注意

:使用rm命令要格外小心。因为一旦删除了一个文件,就无法再恢复它。所以,在删除文件之前,最好再看一下文件的内容,确定是否真要删除。rm命令可以用-i选项,这个选项在使用文件扩展名字符删除多个文件时特别有用。使用这个选项,系统会要求你逐一确定是否要删除。这时,必须输入y并按Enter键,才能删除文件。如果仅按Enter键或其他字符,文件不会被删除。

千万不要随便尝试

rm -rf /

这个命令行,否则系统会GG了。

知乎:不小心敲了 rm -rf / 后反应是怎样的?

touch命令示例:

# 删除当前目录下除隐含文件外的所有文件和子目录
[root@localhost ~]# rm -r *
# 删除当前目录下,后缀为.cmd的所有文件
[root@localhost ~]# rm *.cmd

3. ls , ll

> ls


ls

:ls命令用来显示目标列表,在Linux中是使用率较高的命令。ls命令的输出信息可以进行彩色加亮显示,以分区不同类型的文件。(ls = list)

ls命令示例:

# 显示当前目录下非影藏文件与目录
[root@localhost ~]# ls
anaconda-ks.cfg  install.log  install.log.syslog  satools

# 显示当前目录下包括影藏文件在内的所有文件列表(这里要注意:.开头的文件就是隐藏文件)
[root@localhost ~]# ls -a
.   anaconda-ks.cfg  .bash_logout   .bashrc  install.log         .mysql_history  satools  .tcshrc   .vimrc
..  .bash_history    .bash_profile  .cshrc   install.log.syslog  .rnd            .ssh     .viminfo

# 输出长格式列表
[root@localhost ~]# ls -1
anaconda-ks.cfg
install.log
install.log.syslog
satools

# 查看文件大小更适合阅读的方式,可以加上-h(h = human)人类更适合阅读的方式。
[root@localhost ~]# ls -lh
-rw-------.  1 root root 1.1K 97 2015 anaconda-ks.cfg
-rw-r--r--   1 root root 408K 99 2015 banner.zip
-rw-r--r--   1 root root   15 115 15:54 C
-rw-r--r--   1 root root 1.7G 1026 2015 db_.sql
-rw-r--r--   1 root root  33M 1026 2015 db_.tar.gz

> ll


ll

:ll并不是linux下一个基本的命令,它实际上是ls -l的一个别名。 我们可以通过修改

~/.bashrc

添加任何其他的命令别名。

打开

~/.bashrc

找到 #alias ll=’ls -l’,去掉前面的#就可以了。(关闭原来的终端才能使命令生效)


ll

安装点击

这里

查看详情。用法和

ls

一样,这里就不重复了。

4. vim , vi , nano

这一组的命令,我们介绍了文件编辑工具。这里介绍三种编辑工具,各有所长,根据自己的喜好来选择。我比较倾向于组合使用,发挥在Linux系统上文件编辑的最高效率。

> vim / vi

它们都是多模式编辑器,不同的是vim 是vi的升级版本,它不仅兼容vi的所有指令,而且还有一些新的特性在里面。所以在这里只要学习vim的基本操作就ok了,本节命令更适合实践演练和操作,故只推荐一个慕课(

点击这里

),和学习的参考文档(

点击这里

)。

> nano


nano

:nano是一个字符终端的文本编辑器,有点像DOS下的editor程序。它比vi/vim要简单得多,比较适合Linux初学者使用。某些Linux发行版的默认编辑器就是nano。

如果你没有安装nano编辑器的话,可以使用yum进行安装:

yum -y install nano

篇幅有限,对于nano编辑器感兴趣的请

点击这里

查看操作说明。


总结

:想要像Geek一样在Linux上开发的话,必须对编辑工具做到行云流水,一定要花点时间记住所有的快捷键,看起来专业点(可以装逼)。

5. find , locate/slocate

> find


find

:find命令用来在指定目录下查找文件。

find命令示例:

# 在/home目录下查找以.txt结尾的文件名
[root@localhost ~]# find /home -name "*.txt"

# 基于正则表达式匹配文件路径
[root@localhost ~]# find . -regex ".*\(\.txt\|\.pdf\)$"

> locate/slocate


locate/slocate

:locate命令和slocate命令都用来查找文件或目录。

locate/slocate命令示例:

# 搜索etc目录下所有以sh开头的文件
[root@localhost ~]# locate /etc/sh

# 搜索用户主目录下,所有以m开头的文件
[root@localhost ~]# locate ~/m

# 搜索用户主目录下,所有以m开头的文件,并且忽略大小写
[root@localhost ~]# locate -i ~/m

6. wget


wget

:wget命令用来从指定的URL下载文件。wget非常稳定,它在带宽很窄的情况下和不稳定网络中有很强的适应性,如果是由于网络的原因下载失败,wget会不断的尝试,直到整个文件下载完毕。如果是服务器打断下载过程,它会再次联到服务器上从停止的地方继续下载。这对从那些限定了链接时间的服务器上下载大文件非常有用。

wget命令示例:

# 使用wget下载单个文件
[root@localhost ~]# wget http://www.linuxde.net/testfile.zip

# 使用wget后台下载
[root@localhost ~]# wget -b http://www.linuxde.net/testfile.zip

# 当你打算进行定时下载,你应该在预定时间测试下载链接是否有效。我们可以增加--spider参数进行检查。
[root@localhost ~]# wget --spider URL

# 下载多个文件(filelist.txt保存了url信息,每行一个URL链接)
[root@localhost ~]# wget -i filelist.txt

7. chmod 修改权限


chmod

:chmod命令用来变更文件或目录的权限。在UNIX系统家族里,文件或目录权限的控制分别以**读取、写入、执行**3种一般权限来区分,另有3种特殊权限可供运用。用户可以使用chmod指令去变更文件与目录的权限,设置方式采用文字或数字代号皆可。符号连接的权限无法变更,如果用户对符号连接修改权限,其改变会作用在被连接的原始文件。

  • 权限范围的表示法如下:

  • u

    :User,即文件或目录的拥有者;

  • g

    :Group,即文件或目录的所属群组;

  • o

    :Other,除了文件或目录拥有者或所属群组之外,其他用户皆属于这个范围;

  • a

    :All,即全部的用户,包含拥有者,所属群组以及其他用户;

  • r

    :读取权限,数字代号为“4”;

  • w

    :写入权限,数字代号为“2”;

  • x

    :执行或切换权限,数字代号为“1”;

  • -

    :不具任何权限,数字代号为“0”;

  • s

    :特殊功能说明:变更文件或目录的权限。
linux文件的用户权限的分析图

image



Type

: 很多种 (最常见的是 – 为文件, d 为文件夹, 其他的还有l, n … 这种东西, 真正自己遇到了, 网上再搜就好, 一次性说太多记不住的).



User

: 后面跟着的三个空是使用 User 的身份能对这个做什么处理 (r 能读; w 能写; x 能执行; – 不能完成某个操作).



Group

: 一个 Group 里可能有一个或多个 user, 这些权限的样式和 User 一样.



Others

: 除了 User 和 Group 以外人的权限

chmod命令示例:

# 通常的修改形式是
[root@localhost ~]# chmod [][怎么修改] [哪个文件]

# 举个最简单的例子, 现在的 t1.py 是 ----rw-r--, 如果我们想让你(user)有读的能力. 下面这样改就行了.
[root@localhost ~]# chmod u+r t1.py
[root@localhost ~]# ls -l
-r--rw-r-- 1 frank frank 34 Oct 12 09:51 t1.py

这里的 u+r 很形象, User + read, 给 t1.py 这个修改.

所以我们的修改形式就能总结出下面这样.

[谁]

– u: 对于 User 修改

– g: 对于 Group 修改

– o: 对于 Others 修改

– a: (all) 对于所有人修改

[怎么修改]

– +, -, =: 作用的形式, 加上, 减掉, 等于某些权限

– r, w, x 或者多个权限一起, 比如 rx

[哪个文件]

– 施加操作的文件, 可以为多个

用数字表示rwx的权限

其中a,b,c各为一个数字,a表示User,b表示Group,c表示Other的权限。

r=4,w=2,x=1

– 若要rwx(可读、可写、可执行)属性,则4+2+1=7

– 若要rw-(可读、可写、不可执行)属性,则4+2=6

– 若要r-w(可读、不可写、可执行)属性,则4+1=5

示例:

chmod a=rwx file 和 chmod 777 file 效果相同
chmod ug=rwx,o=x file 和 chmod 771 file 效果相同
若用chmod 4755 filename可使此程式具有root的权限

8. sudo


sudo

:sudo命令用来以其他身份来执行命令,预设的身份为root。在/etc/sudoers中设置了可执行sudo指令的用户。若其未经授权的用户企图使用sudo,则会发出警告的邮件给管理员。用户使用sudo时,必须先输入密码,之后有5分钟的有效期限,超过期限则必须重新输入密码。

9. ping , telnet , nc/netcat

这一组的命令主要用于测试网络连接状态,在很多配置的过程中有很重要的用途。

> ping


ping

:ping命令用来测试主机之间网络的连通性。执行ping指令会使用ICMP传输协议,发出要求回应的信息,若远端主机的网络功能没有问题,就会回应该信息,因而得知该主机运作正常。

ping命令示例:

[root@localhost ~]# ping www.linuxde.net
PING host.1.linuxde.net (100.42.212.8) 56(84) bytes of data.
64 bytes from 100-42-212-8.static.webnx.com (100.42.212.8): icmp_seq=1 ttl=50 time=177 ms
64 bytes from 100-42-212-8.static.webnx.com (100.42.212.8): icmp_seq=2 ttl=50 time=178 ms
64 bytes from 100-42-212-8.static.webnx.com (100.42.212.8): icmp_seq=3 ttl=50 time=174 ms
64 bytes from 100-42-212-8.static.webnx.com (100.42.212.8): icmp_seq=4 ttl=50 time=177 ms
...按Ctrl+C结束

> telnet


telnet

:telnet命令用于登录远程主机,对远程主机进行管理。telnet因为采用明文传送报文,安全性不好,很多Linux服务器都不开放telnet服务,而改用更安全的ssh方式了。但仍然有很多别的系统可能采用了telnet方式来提供远程登录,因此弄清楚telnet客户端的使用方式仍是很有必要的。

相比

ping

命令来说,telnet还可以测试某个IP的端口是否能够正常连通

telnet命令示例:

# 测试IP:60.191.124.150:8081 是否能够连接的通
[root@localhost ~]# telnet 60.191.124.150 8081

# 另外我们也可以用wget进行模拟下载来测试是否能够连通
[root@localhost ~]# wget 60.191.124.150:8081

> nc/netcat


nc

:nc命令是netcat命令的简称,都是用来设置路由器。安装:

yum install nc


# nc测试端口连接
[root@localhost ~]# nc -u -z -w 1 60.191.124.150 8081

10. ifconfig , netstat


ifconfig

:查看网络情况,

netstat

:显示网络状态信息

>ifconfig


ifconfig

:ifconfig命令被用于配置和显示Linux内核中网络接口的网络参数。用ifconfig命令配置的网卡信息,在网卡重启后机器重启后,配置就不存在。要想将上述的配置信息永远的存的电脑里,那就要修改网卡的配置文件了。

ifconfig示例:

[root@localhost ~]# ifconfig
eth0      Link encap:Ethernet  HWaddr 00:16:3E:00:1E:51  
          inet addr:10.160.7.81  Bcast:10.160.15.255  Mask:255.255.240.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:61430830 errors:0 dropped:0 overruns:0 frame:0
          TX packets:88534 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:3607197869 (3.3 GiB)  TX bytes:6115042 (5.8 MiB)

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:56103 errors:0 dropped:0 overruns:0 frame:0
          TX packets:56103 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:5079451 (4.8 MiB)  TX bytes:5079451 (4.8 MiB)

> netstat


netstat

:netstat命令用来打印Linux中网络系统的状态信息,可让你得知整个Linux系统的网络情况。

更多使用方法

netstat命令示例:

# 在netstat输出中显示 PID 和进程名称
[root@localhost ~]# netstat -pt

# 列出所有端口 (包括监听和未监听的)
netstat -a     #列出所有端口
netstat -at    #列出所有tcp端口
netstat -au    #列出所有udp端口        

...

第三部分:“玩转Linux命令行之入门篇”的高级命令行正在编辑中,敬请期待


联系作者

如果你觉得不错的话,不妨打赏一下,这样我就有更大的动力去完善它,优化它。



版权声明:本文为u012104219原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。