这篇文章给大家分享的是有关Linux命令相关的基本知识有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
功能
简单介绍该命令功能。
举例
给出该命令最常使用的例子。
描述
详细描述该命令。
其他
该命令其他杂乱或者补充性的内容。
以orgmode格式做为文档格式, orgmode格式一方面可读性强,另一方面便于将来导出为各种格式.
对于单个命令操作+
开始的列表项第一行给出要操作的目的,然后是具体的命令,最后给出该命令的详细解释。
例如:
+ 列出当前目录的内容 =$ls= 这里,将会列出当前目录所文件。
如果命令过长,则使用
#+BEGIN_SRC/#+END_SRC
对。
对于某个系列的命令
具体的命令使用列表给出,而命令所述的系列使用子标题(orgmode中,列表的排版比较容易出错,所以使用子标题,尽量避免嵌套列表)。
例如:
** 使用vi编辑: + 编辑之前首先打开文件<filename>: =$vi filename= 打开文件之后,操作如下: + 插入 输入 =a= + 退出 输入 =:q=
这里简单介绍linux命令行的一般语法格式。这对初学者很重要,尤其是查找某个命令的帮助手册(
man
手册)的时候,不会什么也看不懂。
一般linux的命令语法格式如下:
命令名称 项 项参数(值) 命令参数(值)
例如:
od [OPTION]... [FILE]... 这里,命令名称是 =od= ,项是OPTION。这里项用'[]'括起来表示这个部分在 =od= 命令里面可可无。命令的参数是FILE也是可可无;'...'表示其前面的东西(这里是OPTION和FILE可以不只一个.一般来说(不是绝对的),在 =man= 手册里面,命令中像OPTION和FILE这样的变量形式的参数(即其值取决于用户的键入部分会用特殊颜色显示出来;而 =od= 这样本身是固定的部分(即不是用户能改变的用另外一种颜色显示(例如加粗)。也有的描述中把可变的部分用'<>'括起来。
再如:
cp [OPTION]... SOURCE... DIRECTORY 从这里可以看出,=cp= 命令参数SOURCE和DIRECTORY,其中SOURCE参数可以是多个,DIRECTORY只能一个。OPTION部分可可无,但是SOURCE和DIRECTORY部分必须要。 具体的例子: =$cp -r file1 file2 dir=
项简单书写形式也复杂书写形式。简单形式的项一般用
-
引出,复杂形式一般用
--
引出等等。
例如:
$cp -v file1 file2
等价于
$cp --verbose file1 file2
这里,=-v= 和
--verbose
是一样的,
-v
是简写形式,
--verbose
是复杂形式。
又例如:
cp -r src des
其中,
-r
就是其中的[OPTION]部分,也可以是
--recursive
。
另外,有些命令的项不用
-
来引出,例如:
$unrar e test.rar
使用
e
项指定
unrar
命令解压
test.rar
文件。
有些命令项用
-
做为前缀,然后可以接多个选项,例如:
$tar -czvf dir.tgz dir
这个命令使用
tar
命令的
-c -z -v -f
四个项,给
dir
目录打包并且压缩,生成结果文件为
dir.tgz
.
在项用’[]’包含起来表示可的同时,如果几个值其中只能出现一个的话那么用’|’来分开。例如:
command [-a|-b]
这里,
command
是假设的一个命令,这表示这个命令
command
中,
-a
和
-b
项,两者要么都没,要么只一个。
不光是命令,命令的项也可以参数。
这里举一个复杂点的命令
gdb [-help] [-nx] [-q] [-batch] [-cd=dir] [-f] [-b bps] [-tty=dev] [-s symfile] [-e prog] [-se prog] [-c core] [-x cmds] [-d dir] [prog[core|procID]]
这是
gdb
命令的语法格式,关键的几个部分如下:[-d dir]
就是指,运行gdb命令,可以添加一个可的项
-d
,这个项的参数是
dir
.在本文的描述中,不太容易一下子看出
[-d dir]
里面哪部分是固定的字符串,哪部分是随用户输入而变的字符串,但是
man
手册里面都把它们标记为不同的颜色了,实际通过分析也很容易知道哪个部分是可变的。
有些命令项和项的参数之间可以没空格,的项和项参数之间用 = 连接,例如这里的 ~[-cd=dir]’
再举一个例子
minicom [-somMlwz8] [-c on|off] [-S script] [-d entry] [-a on|off] [-t term] [-p pty] [-C capturefile] [configuration]
这是minicom的命令语法,其中[-c on|off]表示-c项是可的(即在命令中可可无,它一个选项参数,参数值可以是on或者off.
这里是经常使用的linux命令,用于平时查阅之用.
一般而言,超级用户(root)的命令提示符号是
#
,一般用户的命令提示符号是
$
.
创建名字为1的目录
$mkdir 1
创建名字为1的文件
$touch 1
删除名字为1的文件
$rm 1
查看文件1的内容
$cat 1
强制删除一个目录
$rm -rf dirname
这里,
rm -r dirname
是递归删除的意思,如果加上
-i
项,表示删除之前提示是否删除。
重命名/移动文件
$mv ./origin ./newname
这里,Linux中没专门的重命名命令,这里实际是使用了移动命令来进行的。原来的文件名
origin
,新文件名
newname
.
把文件file1拷贝一份到file2
$cp file1 file2
这里,操作都是在当前目录下面进行的,如果拷贝到别的目录,可以指定路径,例如
cp file1 /anotherdir/file2
.
把目录dir1考到另一个地方为dir2
$cp -r dir1 dir2
这里,
-r
表示递归拷贝所子目录。
进入到一个目录中
$cd dirname
查看目录dirname中所包含的文件
$ls dirname
查看目录dirname中所包含的文件的详细信息
$ls -l
这样,会显示相应文件的详细信息,包括属主,大小,权限等信息。
查看当前的目录
$pwd
这样,会输出当前所在目录的路径。
创建文件file的硬链接
$ln file lnfile
这里,使用链接的目录格式类似
cp
。建立硬链接之后,如果删除源,还可以通过这个硬链接访问到这个文件的内容,除非所的硬链接都被删除了,否则文件内容就一直存在的。硬链接不能够跨越文件系统,不能够建立目录的硬链接。
创建文件
file
的软链接
$ln -s file lnfile
这里,创建软链接,文件名里面
$
就用了转义
\$
表示
$
,尽量用绝对路径防止出错。软链接可以跨越文件系统,可以为目录创建软链接,但是软链接的文件,如果删除源,链接会失效,类似windows中的快捷方式。
修改文件的权限为所人可读可写可执行
$chmod 777 filename
这里,文件属主必须是当前用户,否则就只能进入超级用户才能执行这个命令了。
修改文件filename的权限,为other用户添加写权限:
$chmod o+w filename
修改目录以及所子目录的权限为777
$chmod 777 -R dir
查看在线登陆用户
$who
将一个用户添加到用户组中
#usermod -a -G groupA user
这里,不要忘记
-a
项。如果用:
usermod -G groupA
,这做会使
user
用户离开其他用户组,仅仅做为这个用户组
groupA
的成员。
更改用户user的组为groupA
#usermod -G groupA user
查看所的用户
$cat /etc/passwd
这里,用户都保存在了
passwd
文件中,所以查看这个文件的内容就可以看到所的用户了。
成功创建一个新用户以后,在
/etc/passwd
文件中就会增加一行该用户的信息,其格式如下:
〔用户名〕:〔密码〕:〔UID〕:〔GID〕:〔身份描述〕:〔主目录〕:〔登陆Shell〕
其中每个字段被冒号
:
分成7各部分。
由于小于500的
UID
和
GID
一般都是系统自己保留,不用做普通用户和组的标志,所以新增加的用户和组一般都是
UID
和
GID
大于500的。
查看所的组
$cat etc/group
查看所的组
$cat etc/group
这里,用户都保存在了
group
文件中,所以查看这个文件的内容就可以看到所的用户了。
添加一个用户testusr
#useradd testusr
这里,注意在超级用户模式才能用,刚建立没密码,没自己的home,其他项可以参见man
添加一个用户testusr,并自动建立其用户主目录
#useradd -m testusr
运行完毕,自动生成用户的家目录,目录里面
.bashrc
等文件。
删除一个用户
testusr
#userdel testusr
这里,命令不会把主目录删除.
删除一个用户testusr,连同主目录和邮箱缓存等
#userdel -r testusr
切换到用户testusr
$su testusr
如果用户需要密码,那么需要输入密码才能登录这个用户。
切换到超级用户
$su
这样,会提示输入超级用户的密码,输入之后,就会切换成超级用户了。
以超级用户身份运行一个程序
$sudo app
这样,会以超级用户身份运行app程序,如果当前权限不够的时候,这条命令是很用的。当然,运行之前需要输入自己的密码。还有如
sudo su
也是类似的。
设置更改一个用户testusr的密码
#passwd testusr
这里,需要在超级用户下,输入之后,按照提示输入旧密码和新密码就行了。如果运行的
passwd
没参数,那么会修改当前用户的密码。更改自己的密码只需输入
passwd
不用切换到超级用户下。
修改用户testusr的主目录和登录的shell
#usermod -d/home/quietheart -s/bin/bash testusr
这里,用户名
testusr
的主目录路径设置在
/home/testusr
,登陆的Shell设置为
/usr/bin/gcc
(
-d
更新使用者新的登陆目录,
-s
指定新用户Shell),空格无均可.
修改用户testusr名称为test
#usermod -l test testusr
把用户名
testusr
改成
test
(
-l
变更用户登陆时的名称,手册说同时使用者目录名也会跟着更动成新的名称(实践了没变目录呀))
usermod
不允许改变正在线上的使用者帐号名称.
查看当前用户属于的组
$groups
查看testusr用户属于的组
$groups testusr
查看当前目录大小
$du -sh
查看文件的大小
$du -sh filename
这里,
filename
是将要查看的文件名称。
查看分区信息
fdisk -l
这里,会显示你的电脑上面的所磁盘的信息,例如分区,文件系统等。当前必须是
root
用户,否则没权限。
你的linux系统必须将其他硬盘的其他分区(例如windows分区)挂载到根目录树中,才能访问相应的分区。
挂载分区
/dev/sda7
到
/mnt/win
#mount -t vfat /dev/sda7 /mnt/win
这样的挂载可能会出现显示中文的时候乱码,因为可能没指定解码的字符集。必须是超级用户才能执行。
指定gb2312字符集的挂载
#mount -t vfat -o iocharset=gb2312 /dev/sda7 /mnt/win
这样的挂载的时候,指定使用gb2312字符集,这样就可能没乱码了。其他常用的字符包括cp936,utf8等等(ntfs的一般用utf8挂载)。必须是超级用户才能执行。
查看已经挂载的分区
#mount
卸载已经挂载的分区
#umount /mnt/win
或
#umount /dev/sda7
这里,是把
/dev/sda7
分区挂载到了
/mnt/win
上面。
重新挂载
#mount -o rw,remount /mnt/data
这里,时候文件系统变为只读了,试试这个命令.
设置系统启动自动挂载某个分区
方法之一是在
/etc/fstab
中加入如下内容:
/dev/sda8 /mnt/winG vfat defaults,rw,exec,iocharset=utf8,umask=0000 0 0
必须
umask=0000
, 否则只
root
可以写,并且
root
也不能更改
chmod 777 -R ...
这是自己尝试出来的。
清屏
$clear
这样,当前用户的屏幕会被“清理”,并被重新刷新,原来输入的命令和命令的输出都被清理掉了,也可以使用
[Ctrl]l
来达到相同的效果。
查看系统的编码
$locale
输入之后,例如我的机器输出如下:
LANG=zh_CN.UTF-8 LC_CTYPE="zh_CN.UTF-8" LC_NUMERIC="zh_CN.UTF-8" LC_TIME="zh_CN.UTF-8" LC_COLLATE="zh_CN.UTF-8" LC_MONETARY="zh_CN.UTF-8" LC_MESSAGES="zh_CN.UTF-8" LC_PAPER="zh_CN.UTF-8" LC_NAME="zh_CN.UTF-8" LC_ADDRESS="zh_CN.UTF-8" LC_TELEPHONE="zh_CN.UTF-8" LC_MEASUREMENT="zh_CN.UTF-8" LC_IDENTIFICATION="zh_CN.UTF-8" LC_ALL=
启动xwindow图形界面
$startx
这个命令是在纯粹的命令行下面运行的命令。
切换到第一个纯命令行终端
输入:
[Ctrl][Alt][F1]
这样,如果在图形界面中运行这个命令,会切换到第一个命令终端上面。可以是
[F1]~[F7]
等。
切换到图形界面
输入:
[Ctrl][Alt][F7]
这样,如果在命令行终端,那么会切换到图形终端上面的是
[F7]
、
[F8]
等等,都不一定,一般是
[F7]
。
退出图形界面
两种方法,
方法1, 注销(不会
umount
)
方法2, 输入:
[Ctrl][Alt][Backspace]
退出图形界面之后,不会
umount
之前
mount
过的分区。
查看内核版本号
$uname -r
这里,如果输入
uname -a
会显示所的内核信息。
查看发行的Linux版本号
$cat /etc/issue
搜索最近匹配的历史命令
使用如下步骤进行:
输入
[Ctrl]r
输入以前输入的命令的子字符串
根据 2 的输入会自动匹配最近的命令。
如果匹配了一个,但是我们需要的命令是更早的,那么再输入一下
[Ctrl]r
。
输入回车,运行匹配的命令。
在当前目录中寻找指定的文件
$find -name filename
这样,会在当前目录下递归地寻找名称为
filename
的文件,并且返回它的位置,这里支持通配符号。
在指定的目录中寻找指定的文件
$find dirname -name filename
这样,会在
dirname
中递归地寻找名称为
filename
的文件。
在文件中查找字符串
$grep 'string' filename
这样会在文件
filename
中查找指定的字符串’string’并且返回那个字符串的位置。
在当前目录中所文件中查找指定的字符串
$grep -r 'string' *
这里,使用了通配符号。
查看当前时间
$date
切换桌面工作区域
输入
[Ctrl][Alt]<左右方向键>
锁屏幕
输入
[Ctrl][Alt]l
切换不同任务窗口的快捷键
输入
[Alt][Tab]
在桌面和上次的程序之间进行切换
输入
[Ctrl][Alt]d
假设我们运行了多个vi编辑器,以及其他程序(无论前台还是后台,实际上只一个前台的程序)。
将当前的程序放到后台停止
输入
[Ctrl]z
查看所在后台运行的程序
$jobs
输入之后,输出如下:
[1]- Stopped vi [2]+ Stopped vi lex
这里,使用前面的数字来标记每一个后台运行的程序。
将后台停止的指定程序变成后台运行
$bg %1
这样会把第一个后台的作业调到后台运行,实际上,用
bg 1
就行了。
这样做之后,效果相当于运行了
app &
,其中app是运行的程序,&表示放在后台。
将指定的后台运行的作业号放到前台运行
$fg %1
这样会把第一个后台的作业调到前台运行,实际上,用
fg 1
就行了。
将最近的被停止的程序放到前台运行
$fg
杀掉指定的后台运行的程序
$kill %1
这样,会在后台运行的作业
%1
给杀掉。注意:这里的作业号用%来进行标记,而不像进程直接用数字了。
这里提供了使用
vi
编辑文件的最基本的操作,能够实现大多数的编辑目的。
用
vi
打开一个文件
输入
vi filename
这里,
filename
就是你要打开的文件的名字,默认打开文件后
vi
处于指令模式。
进入编辑模式编辑打开的文件
输入
i
.
或输入
a
.
进入编辑模式后,你可以直接敲入想要输入的字符到文件,两者的区别是
i
在当前字符前面开始插入,
a
在当前字符后面开始插入。
退出编辑模式
输入
[Esc]
这样,将返回指令模式,准备接收你要传达给
vi
的指令并执行,如果之前已经在指令模式下,那么系统将响铃提醒一下。
撤销修改
输入
u
这里,相比以前的vi来说,vim支持多步撤销。
恢复修改
输入
[Ctrl]r
这里,和撤销命令相反,是撤销的撤销,也可多步。
复制行到剪切板
输入
yy
复制定内容到剪切板
输入
v
。
方向键将高亮择的内容。
输入
y
。
这里,开始输入
v
使vi临时进入了一个”选择模式”,输入方向键可以择,输入
y
将择的内容复制剪切板。
删除行
输入
dd
注意,vi的删除等价于剪切,删除的内容会保存到剪切板中。
删除定内容
输入
v
。
方向键将高亮择的内容。
输入
d
。
这里,开始输入
v
使vi临时进入了一个“选择模式”,输入方向键可以择,输入
d
将择的内容删除。
粘贴
输入
p
这样会将剪切板的内容粘贴到光标位置或者光标下一行。
查找字符并定位到第一个匹配处
输入
/character
这里
character
是待查找的字符,只要先输入
/
,再输入待查字符,最后回车即可定位到第一个匹配的字符处。
定位到匹配查找的下一个字符处
输入
n
定位到匹配查找的上一个字符处
输入
N
保存文件
输入
:w
注意
w
前面的
:
,输入
:
之后,vim会将
:
之后的输入解释为待执行的指令。
退出
输入
:q
这里,如果文件没保存,将提示无法退出,除非你强制退出,不保存文件,或者保存退出。
强制退出
输入
:q!
保存退出
输入
:wq
或输入
ZZ
.
察看帮助
输入
:help
感谢各位的阅读!关于“Linux命令相关的基本知识有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。