一、Linux基本命令

1.1 文件的创建和查看命令

touch 创建文件

可以通过touch命令创建文件
语法:touch [Linux路径]
touch命令无选项,参数必填,表示要创建的文件路径,相对、绝对、特殊路径符均可以使用


cat命令 查看文件内容

有了文件后,我们可以通过cat命令查看文件的内容。
不过,现在我们还未学习vi编辑器,无法向文件内编辑内容,所以,暂时,我们先通过图形化
在图形化中,手动向文件内添加内容,以测试cat命令
在这里插入图片描述

准备好文件内容后,可以通过cat查看内容。
语法:cat [Linux路径]
cat同样没有选项,只有必填参数,参数表示:被查看的文件路径,相对、绝对、特殊路径符都可以使用
在这里插入图片描述


more命令

more命令同样可以查看文件内容,同cat不同的是:

  • cat是直接将内容全部显示出来
  • more支持翻页,如果文件内容过多,可以一页页的展示

语法:more [Linux路径]
同样没有选项,只有必填参数,参数表示:被查看的文件路径,相对、绝对、特殊路径符都可以使用

Linux系统内置有一个文件,路径为:/etc/services,可以使用more命令查看more /etc/services

  • 在查看的过程中,通过空格翻页
  • 通过q退出查看

1.2 文件的复制移动删除等命令

cp命令复制文件文件夹

cp命令可以用于复制文件\文件夹,cp命令来自英文单词:copy
语法:cp [-r] 参数1 参数2
-r选项,可选,用于复制文件夹使用,表示递归
参数1,Linux路径,表示被复制的文件或文件夹
参数2,Linux路径,表示要复制去的地方

在这里插入图片描述


mv移动文件或文件夹

mv命令可以用于移动文件\文件夹,mv命令来自英文单词:move
语法:mv 参数1 参数2
参数1,Linux路径,表示被移动的文件或文件夹
参数2,Linux路径,表示要移动去的地方,如果目标不存在,则进行改名,确保目标存在


rm删除文件、文件夹

rm命令来自英文单词:remove
语法:rm [-r -f] 参数1 参数2...参数n

  • 同cp命令一样,-r选项用于删除文件夹
  • -f表示force,强制删除(不会弹出提示确认信息)

普通用户删除内容不会弹出提示,只有root管理员用户删除内容会有提示,所以一般普通用户用不到-f选项
参数1、参数2、…参数N 表示要删除的文件或文件夹路径,按照空格隔开

删除文件:
在这里插入图片描述
删除文件夹:
在这里插入图片描述
尝试同时删除多种类型的文件(报错):
在这里插入图片描述

rm命令支持通配符 ,用来做模糊匹配
符号
表示通配符,即匹配任意内容(包含空),示例:
test*,表示匹配任何以test开头的内容
*test,表示匹配任何以test结尾的内容
test,表示匹配任何包含test的内容

1.3 查找命令

which命令

我们在前面学习的Linux命令,其实它们的本体就是一个个的二进制可执行程序。
和Windows系统中的.exe文件是一个意思。
我们可以通过which命令,查看所使用的一系列命令的程序文件存放在哪里
语法:which 要找的命令

在这里插入图片描述


find命令 - 按文件名查找文件

该功能类似于windows中的搜索功能
在这里插入图片描述

同样,在Linux系统中,我们可以通过find命令去搜索指定的文件。
语法:find 起始路径 -name "被查找的文件"

为了确保后续演示,拥有最大的权限,可以在整个系统完成搜索
我们可以切换到root用户以获得管理员权限
执行命令:su - root
输入密码:123456(和你普通用户的密码一样)
ps:账户、权限等内容,在后续章节讲解,现在先简单用一下
在这里插入图片描述

该方法与rm一样,也可以使用通配符,在双引号内填入要匹配的通配符

通过大小筛选文件补充:
语法:find 起始路径 -size +|-n[kMG]

  • +、- 表示大于和小于
  • n表示大小数字
  • kMG表示大小单位,k(小写字母)表示kb,M表示MB,G表示GB

1.4 文件的筛选和管道的使用

grep命令

可以通过grep命令,从文件中通过关键字过滤文件行。
语法:grep [-n] 关键字 文件路径

  • 选项-n,可选,表示在结果中显示匹配的行的行号。
  • 参数,关键字,必填,表示过滤的关键字,带有空格或其它特殊符号,建议使用””将关键字包围起来
  • 参数,文件路径,必填,表示要过滤内容的文件路径,可作为内容输入端口

一般的grep:
在这里插入图片描述
带选项的grep:
在这里插入图片描述


wc命令做数量统计

可以通过wc命令统计文件的行数、单词数量等
语法:wc [-c -m -l -w] 文件路径

  • 选项,-c,统计bytes数量
  • 选项,-m,统计字符数量
  • 选项,-l,统计行数
  • 选项,-w,统计单词数量
  • 参数,文件路径,被统计的文件,可作为内容输入端口

示例:
在这里插入图片描述


管道符

学习了grep命令后,我们在来学习一个新的特殊符号,管道符:|
管道符的含义是:将管道符左边命令的结果,作为右边命令的输入
如图:
在这里插入图片描述
cat test2.txt的输出结果(文件内容)
作为右边grep命令的输入(被过滤文件)

管道还可以嵌套使用:
在这里插入图片描述

1.5 echo、tail和重定向符

echo命令

可以使用echo命令在命令行内输出指定内容
语法:echo "输入内容"
无需选项,只有一个参数,表示要输出的内容,复杂内容可以用””包围
演示:在这里插入图片描述
在终端上显示:Hello Linux

  • 带有空格或\等特殊符号,建议使用双引号包围
  • 因为不包围的话,空格后很容易被识别为参数

反引号`

看一下如下命令:echo pwd
在这里插入图片描述
本意是想,输出当前的工作路径,但是pwd被作为普通字符输出了。
在这里插入图片描述

我们可以通过将命令用反引号(通常也称之为飘号),被包围的内容会被作为命令执行,而非普通字符。


重定向符:>和>>

>,将左侧命令的结果,覆盖写入到符号右侧指定的文件中
>>,将左侧命令的结果,追加写入到符号右侧指定的文件中

如:echo “Hello Linux” > test.txt
ls > tset.txt
如:echo “Hello Linux” >>test.txt


tail命令

使用tail命令,可以查看文件尾部内容,跟踪文件的最新更改
语法如下:tail [-f -num] Linux路径

  • 参数,Linux路径,表示被跟踪的文件路径
  • 选项,-f,表示持续跟踪
  • 选项, -num,表示,查看尾部多少行,不填默认10行

可以通过新建一个窗口来更改文件,另一个窗口持续追踪文件的更改
在这里插入图片描述
停止更改:Ctrl + C

二、via编辑器

vi\vim是visual interface的简称, 是Linux中最经典的文本编辑器同图形化界面中的文本编辑器一样,vi是命令行下对文本文件进行编辑的绝佳选择。

vim 是 vi 的加强版本,兼容 vi 的所有指令,不仅能编辑文本,而且还具有 shell 程序编辑的功能,可以不同颜色的字体来辨别语法的正确性,极大方便了程序的设计和编辑性。

在这里插入图片描述

  • 命令模式(Command mode)
    命令模式下,所敲的按键编辑器都理解为命令,以命令驱动执行不同的功能。此模式下,不能自由进行文本编辑。
  • 输入模式(Insert mode)
    也就是所谓的编辑模式、插入模式。
    此模式下,可以对文件(如txt)内容进行自由编辑。
  • 底线命令模式(Last line mode)
    开始,通常用于文件的保存、退出

进入vimvim 文件路径
命令模式常用快捷键
在这里插入图片描述
在这里插入图片描述

底线命令模式快捷键
在这里插入图片描述

三、权限控制

3.1 root用户(超级管理员)

普通用户的权限,一般在其HOME目录内是不受限的,一旦出了HOME目录,大多数地方,普通用户仅有只读和执行权限,无修改权限。

su命令就是用于账户切换的系统命令,其来源英文单词:Switch User
语法:su [- ] [用户名]

  • -符号是可选的,表示是否在切换用户后加载环境变量(后续讲解),建议带上
  • 参数:用户名,表示要切换的用户,用户名也可以省略,省略时默认切换到root用户
  • 切换用户后,可以通过exit命令退回上一个用户,也可以使用快捷键:Ctrl + D

使用普通用户,切换到其它用户需要输入密码,如切换到root用户
使用root用户切换到其它用户,无需密码,可以直接切换

sudo命令
在我们得知root密码的时候,可以通过su命令切换到root得到最大权限。
但是我们不建议长期使用root用户,避免带来系统损坏。

我们可以使用sudo命令,为普通的命令授权,临时以root身份执行。

语法:sudo 其他命令

在其它命令之前,带上sudo,即可为这一条命令临时赋予root授权,但是并不是所有的用户,都有权利使用sudo,我们需要为普通用户配置sudo认证。

sudo su -:以 root 用户身份切换

3.2 用户和用户组

Linux系统中可以:

  • 配置多个用户
  • 配置多个用户组
  • 用户可以加入多个用户组中

Linux中关于权限的管控级别有2个级别,分别是:

  • 针对用户的权限控制
  • 针对用户组的权限控制
    在这里插入图片描述

针对某文件,可以控制用户的权限,也可以控制用户组的权限。


演示用户管理
以下命令需root用户执行

  • 创建用户组:groupadd 用户组名
  • 删除用户组:groupdel 用户组名

在这里插入图片描述

以下命令需root用户执行
创建用户
useradd [-g -d] 用户名

  • 选项:-g指定用户的组,不指定-g,会创建同名组并自动加入,指定-g需要组已经存在,如已存在同名组,必须使用-g
  • 选项:-d指定用户HOME路径,不指定,HOME目录默认在:/home/用户名
    在这里插入图片描述

删除用户
userdel [-r] 用户名

  • 选项:-r,删除用户的HOME目录,不使用-r,删除用户时,HOME目录保留

查看用户所属组
id [用户名]
参数:用户名,被查看的用户,如果不提供则查看自身

修改用户所属组
usermod -aG 用户组 用户名,将指定用户加入指定用户组

3.3 权限信息

通过ls 指令可以看见每个文件的使用权限:
在这里插入图片描述

序号1,表示文件、文件夹的权限控制信息

在这里插入图片描述
软连接l在之后会讲到

r表示读权限,w表示写权限,x表示执行权限
针对文件、文件夹的不同,rwx的含义有细微差别

  • r,针对文件可以查看文件内容
    针对文件夹,可以查看文件夹内容,如ls命令
  • w,针对文件表示可以修改此文件
    针对文件夹,可以在文件夹内:创建、删除、改名等操作
  • x,针对文件表示可以将文件作为程序执行
    针对文件夹,表示可以更改工作目录到此文件夹,即cd进入

序号2,表示文件、文件夹所属用户

序号3,表示文件、文件夹所属用户组

3.4 chmod命令

我们可以使用chmod命令,修改文件、文件夹的权限信息。
注意:只有文件、文件夹的所属用户或root用户可以修改。

语法:chmod [-R] 权限 文件或文件夹

  • 选项:-R,对文件夹内的全部内容应用同样的操作

示例:
chmod u=rwx,g=rx,o=x hello.txt ,将文件权限修改为:rwxr-x–x
其中:u表示user所属用户权限,g表示group组权限,o表示other其它用户权限
chmod -R u=rwx,g=rx,o=x test,将文件夹test以及文件夹内全部内容权限设置为:rwxr-x–x

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部