admin管理员组文章数量:1597400
基本命令
关机: shutdown -h halt init 0 poweroff
重启: shutdown -r reboot init 6
pwd 查看工作目录
ls 查看指定目录的内容
-l 列表显示
-a 显示所有,包括隐藏的文件
-h 人性化的显示
-d 只显示目录,不查看文件
关机 (系统的关机、重启以及登出 )
shutdown -h now 关闭系统(1)
init 0 关闭系统(2)
telinit 0 关闭系统(3)
shutdown -h hours:minutes & 按预定时间关闭系统
shutdown -c 取消按预定时间关闭系统
shutdown -r now 重启(1)
reboot 重启(2)
logout 注销
切换目录
cd 切换到当前用户的主目录
cd~ 切换到当前用户的主目录
cd. . 切换到上级目录
cd. 保持在当前目录
cd- 在两次工作目录间来回切换
目录结构
linux目录与win完全不同,是从’/'开始的,只有他没有上一级目录,因此也叫根目录
详细介绍
/bin 大部分的系统命名
/boot 启动相关的目录
/dev 设备文件目录,linux下一切设备皆文件
/etc 配置文件目录
/home 普通用户的家目录,一个用户对应一个文件夹
/lib 库文件
/lib64 64位库文件
/lost+found 系统异常是临时保存数据,用于恢复等操作
/media 媒体目录
/mnt 挂载目录,通用挂载点
/opt 安装系统非必须软件目录
/proc 虚拟文件系统,会映射硬件信息
/root root用户的家目录
/sbin:超级用户才能执行的命令目录
/selinux:linux一套安全机制,非常复杂,通常不用
/srv:存放本机或本机服务器的数据或服务
/sys:类似于/proc,也是虚拟文件系统,可以映射系统信息
/tmp:临时文件,可能随时销毁
/usr:存放用户安装的应用程序
/var:系统产生的不可自动销毁的文件,如:日志、缓存等
vim终端编辑器
介绍:vim是对vi的扩展,被誉为终端编辑器之神
安装:yum install -y vim
工作模式:正常模式、插入模式、编辑模式
正常模式:使用vim打开文件时的默认模式
vim filename 打开文件,若文件不存在则新建
esc:切换到正常模式
shift + zz:保存退出
常用操作:
vim filename +n 打开文件,定位到第n行
vim filename + 打开文件,定位到末尾
gg 定位到首行
G 定位到尾行
ngg 定位到第n行
^ 定位到行首
$ 定位到行尾
yy 复制光标所在行
p 粘贴
nyy 复制光标开始的n行
dd 删除光标所在行
ndd 删除光标开始的n行
u 撤销操作
ctrl + r 反撤销操作
插入模式:就是可以编辑文件内容的模式,在正常模式下输入以下字符进入:
i:在光标处插入
I:在行首插入
a:在光标下一个字符处插入
A:在行尾插入
o:下光标下一行插入空行
O:下光标上一行插入空行
s:删除光标所在字符并插入
S:删除光标所在行并插入
编辑模式:是对整个文件进行的操作,如:保存,退出
在正常模式下输入’:'即可进入编辑模式
:w 保存
:q 退出
:wq 保存退出,等价于 shift + zz
:x 保存退出,等价于:wq
:q! 强制退出
:set nu 显示行号
:set nonu 隐藏行号
:行号 定位到指定行号
/内容 查找指定内容,n下翻,N上翻
:%s/原内容/新内容 使用新内容替换原内容,全部替换
:m,ns/原内容/新内容 使用新内容替换原内容,替换m到n行
友情提醒:若非正常关闭vim,则会生成临时文件(隐藏的),需要删除
文件及文件夹
touch:创建普通文件
rm:删除文件,-f表示强制删除,-r表示递归删除
cp:拷贝文件,若目标目录写上文件名可以顺便把名字改了,-r可以操作目录
mv:移动文件,若目标目录写上文件名可以顺便把名字改了
mkdir:创建文件夹,-p创建中间目录
rmdir:删除文件夹,只能删除空目录
查看文件
cat:从上到下查看文件,全部内容
tac:从下到上查看文件,全部内容
head:查看开头的指定行内容,默认10行,head -3 1.txt
tail:查看末尾的指定行内容,默认10行,tail -5 1.txt
more:逐渐查看文件,回车下翻一行,空格下翻一屏,看到结尾会自动结束,q退出查看
less:逐渐查看文件,回车下翻一行,空格下翻一屏,看到结尾不会自动结束,可以上下翻
nl:功能同cat,会多显示行号
wc:统计文件信息,显示结果:行数 | 单词数 | 字节数
说明:more/less更多用法是结合管道使用,ls /etc | more
文件查找
tree:查看目录结构,-L指定层级深度,tree / -L 2
find:查找文件
-name:指定名字,find / -name 1.txt
-type:指定类型,(b/c/d/p/l)
-size:指定大小,单位K/M/G,+表示大于,-表示小于,find / -size +1G
-perm:指定权限
-user:指定用户
-group:指定组
-maxdepth:指定最大层级深度
whereis:查找程序,不要使用find(效率太低)
which:专门用来查找命令
alias:给某个命令起别名,alias ls=‘ls --color=auto’
unalias:取消别名
grep:正则匹配查找
-i:忽略大小写
-n:显示行号
例子:
grep root /etc/passwd 在 /etc/passwd文件中查找包含root的行
ls /bin | grep ‘^m’ 查找/bin目录下以m开头的文件
文件和目录
cd /home 进入 ‘/ home’ 目录’
cd … 返回上一级目录
cd …/… 返回上两级目录
cd 进入个人的主目录
cd ~user1 进入个人的主目录
cd - 返回上次所在的目录
pwd 显示工作路径
ls 查看目录中的文件
ls -F 查看目录中的文件
ls -l 显示文件和目录的详细资料
ls -a 显示隐藏文件
ls [0-9] 显示包含数字的文件名和目录名
tree 显示文件和目录由根目录开始的树形结构(1)
lstree 显示文件和目录由根目录开始的树形结构(2)
mkdir dir1 创建一个叫做 ‘dir1’ 的目录’
mkdir dir1 dir2 同时创建两个目录
mkdir -p /tmp/dir1/dir2 创建一个目录树
rm -f file1 删除一个叫做 ‘file1’ 的文件’
rmdir dir1 删除一个叫做 ‘dir1’ 的目录’
rm -rf dir1 删除一个叫做 ‘dir1’ 的目录并同时删除其内容
rm -rf dir1 dir2 同时删除两个目录及它们的内容
mv dir1 new_dir 重命名/移动 一个目录
cp file1 file2 复制一个文件
cp dir/* . 复制一个目录下的所有文件到当前工作目录
cp -a /tmp/dir1 . 复制一个目录到当前工作目录
cp -a dir1 dir2 复制一个目录
ln -s file1 lnk1 创建一个指向文件或目录的软链接
ln file1 lnk1 创建一个指向文件或目录的物理链接
touch -t 0712250000 file1 修改一个文件或目录的时间戳 - (YYMMDDhhmm)
file file1 outputs the mime type of the file as text
iconv -l 列出已知的编码
iconv -f fromEncoding -t toEncoding inputFile > outputFile creates a new from the given input file by assuming it is encoded in fromEncoding and converting it to toEncoding.
find . -maxdepth 1 -name *.jpg -print -exec convert “{}” -resize 80x60 “thumbs/{}” ; batch resize files in the current directory and send them to a thumbnails directory (requires convert from Imagemagick)
系统信息
arch 显示机器的处理器架构(1)
uname -m 显示机器的处理器架构(2)
uname -r 显示正在使用的内核版本
dmidecode -q 显示硬件系统部件 - (SMBIOS / DMI)
hdparm -i /dev/hda 罗列一个磁盘的架构特性
hdparm -tT /dev/sda 在磁盘上执行测试性读取操作
cat /proc/cpuinfo 显示CPU info的信息
cat /proc/interrupts 显示中断
cat /proc/meminfo 校验内存使用
cat /proc/swaps 显示哪些swap被使用
cat /proc/version 显示内核的版本
cat /proc/net/dev 显示网络适配器及统计
cat /proc/mounts 显示已加载的文件系统
lspci -tv 罗列 PCI 设备
lsusb -tv 显示 USB 设备
date 显示系统日期
cal 2007 显示2007年的日历表
date 041217002007.00 设置日期和时间 - 月日时分年.秒
clock -w 将时间修改保存到 BIOS
用户及用户组
whoami:查看当前用户
useradd:创建用户
-d:指定家目录
-u:指定用户id(uid)
-g:指定所属组id(gid)
-s:指定shell解释器
说明:uid和gid要使用大于500的数字,小于500的被系统占用
passwd:设置指定用户的密码,若不指定设置当前用户的密码
userdel:删除用户,-rf删除用户相关目录,否则需要手动删除
groupadd:创建用户组
groupdel:删除用户组
gpasswd:将用户添加到某个组,从某个组删除
gpasswd -a test hello 将test用户添加到hello组
gpasswd -d test hello 将test用户从hello组中删除
chgrp:改变文件所属组,chgrp hello 1.txt
chown:改变文件拥有者[及组],chown root[:root] 1.txt
chsh:修改用户的shell解释器,chsh test -s /sbin/nologin
su - : 切换到指定用户,若不加’-’,只会切换目录及用户身份,不会切换执行环境
若不指定用户。默认切换到root用户
涉及文件:
/etc/passwd:存放用户信息
/etc/group:存放用户组信息
/etc/shadow:存放用户密码
用户身份:
#:root用户
$:普通用户
绝对路径
例如在我的/home/grc/exchange/二级目录/三级目录下有一个文件test.txt,那这个文件的绝对路径就是/home/grc/exchange/二级目录/三级目录,可在任意目录下通过绝对路径找到这个文件:
相对路径
如果当前我在/home/grc/exchange这个目录下,那么上述文件的相对路径就是 ./二级目录/三级目录,当然这个./也可以不要:
给指令定义别名
可以为上述进入test.txt所在目录的指令另起一个别名,下次使用时可以不用输入这么长的指令
上述设置别名的方式在关闭终端的时候就失效了,如果想永久保存:
输入vim ~/.bashrc,在里面添加想要设置的别名,这样在下次启动终端的时候该别名也不会失效:
输入alias可以查看当前所有已经设置的别名
用系统中存储的.bashrc备份文件恢复到~/目录下(如果你和我一样不小心把它给删掉了)
cp /etc/skel/.bashrc ~/
vim文本编辑器常用指令
下载vim文本编辑器
sudo apt-get install vim
:i 插入
:w 保存文件但不退出vi
:wq 保存文件并退出vi
:q 不保存文件,退出vi
:e! 放弃所有修改,从上次保存文件开始再编辑
上述所有指令都可以在后面加!表示强制执行
创建和删除文件以及文件夹
创建文件
touch a.txt
删除文件
rm a.txt
创建文件夹
mkdir NewFolder
删除空文件夹
rmdir NewFolder
删除非空文件夹及目录下所有文件
rm -rf Folder
软链接和硬链接
软链接:相当于windows里面的快捷方式,删除源文件之后软链接失效。
ln -s 源文件 目标文件
硬链接:相当于重新建立了一个文件与源文件内容相同,删除源文件后硬链接是不会失效的。
ln 源文件 目标文件
常用通配符
还有[!a]或者[^a]表示除了a之外的任意一个字符
复制文件到制定目录
cp [选项] 源文件或目录 目标文件或目录
-a 该选项通常在拷贝目录时使用。它保留链接、文件属性,并递归地拷贝目录,其作用等于dpR选项的组合。
-d 拷贝时保留链接。
-f 删除已经存在的目标文件而不提示。
-i 和f选项相反,在覆盖目标文件之前将给出提示要求用户确认。回答y时目标文件将被覆盖,是交互式拷贝。
-p 此时cp除复制源文件的内容外,还将把其修改时间和访问权限也复制到新文件中。
-r 若给出的源文件是一目录文件,此时cp将递归复制该目录下所有的子目录和文件。此时目标文件必须为一个目录名。
-l 不作拷贝,只是链接文件
管理员权限
输入命令:sudo su;
屏幕上会回显要求输入当前用户密码的提示,输入密码即可获得管理员权限;
若想退出管理员权限可输入命令:su 用户名.
创建和删除用户
创建用户user1
useradd user1
创建用户user1,并为其建立主目录(在/home目录下)
useradd -m user1
为用户user1设置密码
passwd user1
将用户 user1的登录名改为 u1
usermod –l u1 user1
删除用户user1和他的工作目录
userdel –r user1
查看用户信息uid和gid
id user1
切换到用户user1
su user1
创建和删除用户组
创建一个组users,其GID为888
groupadd –g 888 users
把 user1加入users组
gpasswd –a user1 users
把 user1退出users组
gpasswd –d user1 users
修改组名user为users
groupmod –n user users
删除组users
groupdel users
用chmod设置文件权限
chmod的用法大致分为两种
1.指定某类用户的权限
chmod [ u / g / o / a ] [ + / - / = ] [ r / w / x ] file
[ u / g / o / a ] 为权限范围,其中
u:User,即文件或目录的拥有者
g:Group,即文件或目录的所属群组
o:Other,除了文件或目录拥有者和所属群组外,其他用户都属于这个范围
a:All,即全部用户
权限操作
+表示增加权限
-表示取消权限
=表示取消之前的权限,并给予唯一的权限
权限代号
r:读取权限,数字代号为 “4”
w:写入权限,数字代号为 “2”
x:执行权限,数字代号为 “1”
-:不具备任何权限,数字代号为 “0”
file,文件名(路径)
例如
sudo chmod u+rw /code/readme.txt
给 User 用户增加了对”/code/readme.txt”文件 “w” 和 “x” 的权限
2.同时指定三类用户的权限
chmod [xyz] file
其中x,y,z分别指定User、Group、Other的权限;用三位二进制数表示 ” r , w , x”(注意顺序)三种权限,其中 0 代表没有该权限,1 代表有该权限,如 100 则表示,有 ‘r”权限,无 “w x”权限;再将这个三位的二进制数转为十进制,则是 x (或y,z)的值
例如
sudo chmod 774 /code/readme.txt
User : 7 = 111 表示具有 ” r , w , x” 权限
Group : 7 = 111 表示具有 ” r , w , x” 权限
Other : 4 = 100 表示只具有 ” r ” 权限,而没有 “w,x” 权限
sudo chmod 774 *
” * ” 为通配符,表示对当前所在目录下的所有文件做权限修改操作
sudo chmod -R 774 /code/
修改这个目录,以及子目录下文件的权限
初学Linux基本的命令操作应当记牢
weixin_30292843 2017-11-01 21:15:00 11492 收藏 273
文章标签: shell 数据库 运维
版权
Linux管理文件和目录的命令
命令
功能
命令
功能
pwd
显示当前目录
ls
查看目录下的内容
cd
改变所在目录
cat
显示文件的内容
grep
在文件中查找某字符
cp
复制文件
touch
创建文件
mv
移动文件
rm
删除文件
rmdir
删除目录
1.1 pwd命令
该命令的英文解释为print working directory(打印工作目录)。输入pwd命令,Linux会输出当前目录。
1.2 cd命令
cd命令用来改变所在目录。
cd / 转到根目录中
cd ~ 转到/home/user用户目录下
cd /usr 转到根目录下的usr目录中-------------绝对路径
cd test 转到当前目录下的test子目录中-------相对路径
1.3 ls命令
ls命令用来查看目录的内容。
选项
含义
-a
列举目录中的全部文件,包括隐藏文件
-l
列举目录中的细节,包括权限、所有者、组群、大小、创建日期、文件是否是链接等
-f
列举的文件显示文件类型
-r
逆向,从后向前地列举目录中内容
-R
递归,该选项递归地列举当前目录下所有子目录内的内容
-s
大小,按文件大小排序
-h
以人类可读的方式显示文件的大小,如用K、M、G作单位
ls -l examples.doc
列举文件examples.doc的所有信息
1.4 cat命令
cat命令可以用来合并文件,也可以用来在屏幕上显示整个文件的内容。
cat snow.txt 该命令显示文件snow.txt的内容,ctrl+D退出cat。
1.5 grep命令
grep命令的最大功能是在一堆文件中查找一个特定的字符串。
grep money test.txt
以上命令在test.txt中查找money这个字符串,grep查找是区分大小写的。
1.6 touch命令
touch命令用来创建新文件,他可以创建一个空白的文件,可以在其中添加文本和数据。
touch newfile 该命令创建一个名为newfile的空白文件。
1.7 cp命令
cp命令用来拷贝文件,要复制文件,输入命令:
cp
cp t.txt Document/t 该命令将把文件t.txt复制到Document目录下,并命名为t。
选项
含义
-i
互动:如果文件将覆盖目标中的文件,他会提示确认
-r
递归:这个选项会复制整个目录树、子目录以及其他
-v
详细:显示文件的复制进度
1.8 mv命令
mv命令用来移动文件。
选项
说明
-i
互动:如果选择的文件会覆盖目标中的文件,他会提示确认
-f
强制:它会超越互动模式,不提示地移动文件,属于很危险的选项
-v
详细:显示文件的移动进度
mv t.txt Document 把文件t.txt 移动到目录Document中。
1.9 rm命令
rm命令用来删除文件。
选项
说明
-i
互动:提示确认删除
-f
强制:代替互动模式,不提示确认删除
-v
详细:显示文件的删除进度
-r
递归:将删除某个目录以及其中所有的文件和子目录
rm t.txt 该命令删除文件t.txt
1.10 rmdir命令
rmdir命令用来删除目录。
有关磁盘空间的命令
命令
功能
mount
挂载文件系统
umount
卸载已挂载上的文件系统
df
检查各个硬盘分区和已挂上来的文件系统的磁盘空间
du
显示文件目录和大小
fsck
主要是检查和修复Linux文件系统
2.1 mount命令
mount命令的功能是挂载文件系统,可以挂载硬盘、光盘、软盘,也可以挂载NFS网络文件系统。这个命令的标准用法如下:
mount –t 设备类型 存放目录
mount IP地址:/所提供的目录 存放目录
选项
说明
(无)
不加任何参数,直接输入命令可以显示已挂载的文件系统和目录
-a
挂上/etc/fstab下的全部文件系统
-t
制定所挂上来的文件系统的名称,所有系统支持的文件系统,这个信息可以在/proc/filesystems这个文件里看到
-n
挂上文件系统,但是不把文件系统的数据写入/etc/mtlab这个文件
-w
将文件系统设为可读写
-r
挂上来的文件系统设为只读
在目录/mnt下,挂上iso9660文件系统。输入命令:
mount –t iso9660 /dev/hdb /cdrom
2.2 umount命令
umount命令的功能是卸载已挂上的文件系统,在关闭系统前应该把所有挂载上的文件系统卸载。这个命令和mount命令是相对的。用法:
umount 已挂上的目录或设备
卸载已挂上的/cdrom目录,输入命令:
umount /cdrom
卸载已挂上的某个分区,输入命令:
umount /dev/hdb1
2.3 df命令
df命令用来检查硬盘分区和已挂在的文件系统的磁盘空间,也就是说,检查硬盘的使用量。标准用法如下:
df [-选项]
选项
功能
-a
把全部的文件系统和各分区的硬盘使用情形列出来,包括0区块的,例如/proc这个文件系统
-i
列出I-nodes的使用量
-k
把各分区的大小和挂上来的文件分区的大小用k表示
-t
列出某一文件系统的所有分区磁盘空间使用量
-x
列出不是某一文件系统的所有分区磁盘空间使用量,和-t选项相反
-T
列出每个分区所属文件系统的名称
例如,要列出全部文件系统和各分区的磁盘使用情况,输入命令:
df –a
2.4 du命令
du命令的功能是用于显示文件目录或大小。标准用法:
du [-选项]
选项
含义
-a
显示全部目录及其次目录下的每个文件所占的磁盘空间
-b
显示目录和文件的大小,以B为单位
-c
最后再加上一个总计
-h
以KB、MB、GB为单位,提高信息可读性
-s
只列出各文件大小的总和
-x
只计算属于同一文件系统的文件
2.5 fsck命令
fsck命令的功能是检查和修复Linux文件系统,这个命令最好在没有人或是没有分区挂上来时使用,其实每次开机系统都会做一次检查,看是否有坏轨或数据流失的现象。用法:
fsck (-选项) 分区名称
选项
功能
-a
自动修复文件系统,不询问任何问题,比较危险
-A
依照/etc/fstab配置文件的内容,检查该文件内所列全部文件系统。若没有附加参数"-P”,则会先检查/目录的文件系统,而不会同时检查所有文件系统
-R
采取互动方式,在修复时询问问题,让用户确认并决定处理方式
-S
依次检查作业而不是同时执行。当依次指定多个文件系统且采用互动的方式进行检查时,请使用此参数以便顺序执行,否则fsck可能会同时询问数个问题,让人不知所措
-V
显示命令执行的过程
-T
指定要检查的文件系统的类型
-N
不是真正执行指令,仅列出实际执行时会进行的动作
文件备份和压缩命令
在Linux中,常用的文件压缩工具有gzip、bzip2、zip。bzip2是最理想的压缩工具,它提供了最大限度的压缩。zip兼容性好,Windows也支持。
命令
功能
bzip2/bunzip2
扩展名为bz2的压缩/解压缩工具
gzip/gunzip
扩展名为gz的压缩/解压缩工具
zip/unzip
扩展名为zip的压缩/解压缩工具
tar
创建备份和归档
3.1 bzip2命令
要使用bzip2来压缩文件,在shell提示下输入命令:
bzip2 filename
文件即会被压缩,并被保存为filename.bz2。
要解压缩文件,输入命令:
bunzip2 filename.bz2
filename.bz2会被删除,而以filename代替。
bzip2 filename.bz2 file1 file2 file3 /usr/work/school
上面的命令把file1、file2、file3以及/usr/work/school目录中的内容压缩起来放入filename.bz2。
3.2 gzip命令
要使用gzip来压缩文件,输入命令:
gzip filename
文件即会被压缩,并被保存为filename.gz。
要解压缩文件,输入命令:
gunzip filename.gz
filename.gz会被删除,而以filename代替。
gzip -r filename.gz file1 file2 file3 /usr/work/school
上面的命令把file1、file2、file3以及/usr/work/school目录中的内容压缩起来放入filename.gz。
3.3 zip命令
zip命令的使用方法同gzip。
3.4 tar命令
tar命令最早是用来做磁带备份的,但是由于硬盘容量越来越大,因此现在主要用这个命令来备份所有的文件。tar这个命令把大量的文件和目录打包成一个文件。
选项
功能
-c
创建一个新归档
-f
当与-c选项一起使用时,创建的tar文件使用该选项指定的文件名;当与-x选项一起使用时,则解除该选项指定的归档
-t
显示包括在tar文件中的文件列表
-v
显示文件的归档进度
-x
从归档中抽取文件
-z
使用gzip压缩tar文件
-j
使用bzip2压缩tar文件
要创建一个tar文件,输入命令:
tar –cvf filename.tar directory/file /home/mine
上面的命令将directory/file、/home/mine放入归档文件中。
要列出tar文件的内容,输入命令:
tar –tvf filename.tar
要抽取tar文件的命令,输入命令:
tar –xvf filename.tar
这个命令不会删除tar文件,但会把解除归档的内容复制到当前工作目录下,并保留归档文件所使用的任何目录结构。
请记住,tar默认不压缩文件。要创建一个使用tar和bzip2来归档压缩的文件,使用-j选项:
tar –cjvf filename.tbz file
如果使用bunzip2命令解压filename.tbz文件,则filename.tbz会被删除,以filename.tar代替。
要扩展并解除归档bzip tar文件,输入命令:
tar –xjvf filename.tbz
要创建一个用tar和gzip归档并压缩的文件,使用-z选项:
tar –czvf filename.tgz file
如果使用gunzip命令解压filename.tgz文件,则filename.tgz会被删除,以filename.tar代替。
有关关机和查看系统信息的命令
命令
说明
shutdown
正常关机
reboot
重启计算机
ps
查看目前程序执行的情况
top
查看目前程序执行的情景和内存使用的情况
kill
终止一个进程
date
更改或查看目前日期
cal
显示月历及年历
4.1 shutdown命令
要使用这个命令必须保证是根用户,否则使用su命令改变为根用户。命令格式如下:
shutdown –(选项)
选项
功能
-k
不是真正的关机,只是发出警告命令
-r
关机后重启
-t
在规定的时间内关机
加入要在2min内关机,输入命令:
shutdown –t 2
如果是关机后重启,输入命令:
shutdown –r
4.2 reboot命令
这个命令也是一个关机命令,只有输入,不加任何参数,系统会以最快的速度关机,且不将内存或缓冲区里的东西写回硬盘。
选项
功能
-d
不把记录写到/var/log/wtmp档案里(-n这个参数包含了-d)
-f
强迫重开机,不呼叫shutdown这个指令
-n
在重开机前不做将记忆体资料写回硬盘
-w
并不会真的重开机,只是把记录写到/var/log/wtmp档案里
4.3 ps命令
ps命令用来查看在计算机系统中有哪些程序正在执行,及其执行的情况。这是一个相当强大的命令,可以用它来找出所有的process id和名称。另外,ps命令也可以用来列出所有程序占用内存的情况。用法如下:
ps –(选项)
选项
功能
-l
用长格式列出
-u
列出使用者的名称和使用时间
-m
列出内存分布的情况
-r
只列出正在执行的前台程序,不列出其他信息
-x
列出所有程序,包括那些没有终端机的程序
4.4 top命令
top命令可以查看目前程序的执行情景和内存使用。它和ps类似,不过,它会几秒钟更新一次系统状态,方便追踪。要离开这个程序,按Ctrl+C键就可以了。
4.5 kill命令
kill命令用来终止一个正在执行中的进程。如果一个程序执行过程中失败了,可以把这个程序终止,避免留在内存中占用系统资源。不过,它的实际意义是送一个信号给这个正在执行的程序,叫它自杀。可以送很多信号给这些程序,也可以让他们受到信号后做很多事情。标准用法:
kill –(选项) pid
在执行kill命令前。可以先用ps命令查一下某宕掉程序的pid,然后使用kill除去某个程序。例如,终止pid为90的程序:
kill 90
选项
功能
-l
列出所有可用的信号名称
-p
印出pid并不发送信号
-signal
其中可用的讯号有 HUP (1), KILL (9), TERM (15), 分别代表著重跑, 砍掉, 结束
将 pid 为 323 的行程砍掉 (kill) :
kill -9 323
将 pid 为 456 的行程重跑 (restart) :
kill -HUP 456
4.6 date命令
date命令用来显示、设定和修改现在的时间和日期。标准用法:
date –(选项) 显示时间格式(以+号开头,后加格式)
date 设定时间格式
选项
功能
-u
使用格林尼治时间
-r
最后一次修改文件的时间
-s
设置时间
常用的几种时间格式如下表所示:
格式
说明
%a
星期几的简称,例如一、二、三
%A
星期几的全名,例如星期一、星期二
%D
日期(mm/dd/yy格式)
%T
显示时间格式,24小时制(hh:mm:ss)
%x
显示日期的格式(mm/dd/yy)
%y
年的最后两个数字
%Y
年(如2007、2008)
%r
时间(hh:mm:ss 上午或下午)
%p
显示上午或下午
如果输入命令:
date “+%x,%r”
系统返回如下信息:
2010年3月26日,下午 18时06分49秒
4.7 cal命令
cal命令有两种功能:显示月历以及年历。
直接输入cal命令则系统会显示目前月份的月历。
若要显示一整年的年历,可以在cal命令后加4位数的公元年份。例如要显示2008年的年历,必须输入:
cal 2008
若输入 cal 08 ,则最显示公元8年的年历。
若只需要查看某一年份中某一月份的月历,可以输入:cal 月份 公元年份。例如输入:"cal 12 2004”。
管理使用者和设立权限的命令
命令
说明
命令
说明
chmod
用来改变权限
useradd
用来增加用户
su
用来修改用户
5.1 chmod命令
chmod命令用来改变许可权限。读取、写入和执行是许可权限中的三个主要设置。因为用户在他们的账号被创建时就被编入一个组群,所以还可以指定那些组群可以读取、写入或执行某一文件。其中:
r—文件可以被读取
w—文件可以被写入
x—文件可以被执行,如果文件是程序的话
可以使用带有-l的ls命令来仔细查看一个文件的许多细节。
chmod命令用来设定文件的权限。标准用法:
chmod 文件的使用者(u,g,o,a)增减(+,-,=)权限名称(r,w,x) 文件
文件的使用者
说明
权限
说明
增减
说明
u
拥有文件的用户
r
读取权
添加权限
g
所有者所在的组群
w
写入权
删除权限
o
其他人
x
执行权
=
是它称为唯一权限
a
全部(u,g和o)
删除某一文件的所有权限,输入命令:
chmod a-rwx test.txt
为文件所有者添加权限,输入命令:
chmod u+rwx test
还可以用数字表示权限:4——读取,2——写入,1——执行。下面的两个命令等价:
chmod 751 filename
chmod u+rwx,g=rx,0=x filename
5.2 su命令
su命令用来修改用户。这个命令非常重要,它可以让一个普通的使用者拥有超级用户或其他使用者的权限。不过,这个命令必须具有超级用户或其他使用者的口令才能成为超级用户或其他使用者。如果要离开,可以输入exit。标准用法:
su 用户名 (如果没有输入用户名则预设为root)
举例说明,假设当前用户user01,想要转变为user02,则输入命令:
su user02
系统返回:
password:
此时,输入user02的指令,就会变为user02。
5.3 useradd命令
useradd命令用来增加用户,只有根用户才能增加用户。如果没有登录为根用户,输入su,再输入根口令即可。
要增加用户,输入命令:
useradd 用户名
然后,根据提示为新用户输入一个口令即可。
线上查询的命令
命令
功能
man
查询和解释一个命令的使用方法,以及这个命令的说明事项
locate
定位文件和目录
whatis
寻找某个命令的含义
6.1 man命令
man命令用来查询和解释一个命令的使用方法和这个命令的注意事项。这个查询查询在每个Linux上都有。通常,使用者只要输入命令man和这个命令的名称shell就会列出一份完整的说明。标准用法:
man 命令的名称
要查询ls命令的说明书页,输入命令:
man ls
要翻阅说明书页,可以使用Page Up和Page Down键,或使用空格键向后翻一页,使用b向前翻。要退出说明书页,输入命令q。要在说明书页中搜索关键字,输入命令/和要搜索的关键字或短语,然后按 Enter键即可。所有出现在说明书页中的关键字都会被突出显示,允许快速地阅读上下文中的关键字。
6.2 locate命令
locate命令的主要功能是定位文件和目录。有时候,只知道某一文件或目录存在,却不知道在哪儿,就可以用locate来定位文件和目录。使用locate命令,将会看到每一个包括搜索田间的文件和目录。例如,如果想要搜索带有test的这个词的文件,输入命令:
locate test
locate命令使用数据库来定位带有test这个词的文件或目录。
6.3 whatis命令
whatis命令用来查询某个命令的含义。用法简单,也不需要什么参数,直接在whatis命令后加上所要查询的命令就可以了,但是却很实用。
要查询mv命令的含义,输入命令:
whatis mv
文件阅读的命令
命令
功能
head
查看文件的开头部分
tail
查看文件结尾的10行
less
less是一个分页工具,它允许一页一页地(或一个屏幕一个屏幕地)查看信息
more
more是一个分页工具,它允许一页一页地(或一个屏幕一个屏幕地)查看信息
7.1 head命令
head命令可以用来查看文件的开头部分。此命令的格式是:
head 文件名
默认设置,它只查看文件的前10行。但可以通过指定一个数字选项来改变要显示的行数,命令如下:
head –20 文件名
这个命令将会查看文件的前20行。
7.2 tail命令
tail命令和head命令恰恰相反。使用tail命令,可以查看文件结尾的10行。这有助于查看日 志文件的最后10行来阅读重要的系统信息。还可以使用tail观察日志文件更新的过程。使用-f选项,tail会自动实时地把打开文件中的新信息显示到屏 幕上。例如,要活跃地观察/var/log/messages,以根用户身份在shell下输入以下命令:
tail –f /var/log/messages
7.3 less命令
less命令与more命令相似。
7.4 more命令
more和less的主要区别是,less允许使用箭头来前后移动,而more使用空格键和b键来前后移动。使用ls和more来列举/etc目录下的内容:
ls –al /etc | more
要使用more在文本文件中搜索关键字,按/键并输入命令搜索条目:
/foo
使用空格键来先前翻阅页码。按q键退出。
more命令标准格式为:
more [选项] [fileNames]
选项
含义
-num
一次显示的行数
-d
提示使用者,在画面下方显示[Press space to continue, q to quit.],如果使用者按错键,则会显示[Press h for instructions.]而不是哔声
-l
取消遇见特殊字元^L(送纸字元)时会暂停的功能
-f
计算行数时,以实际上的行数,而非自动换行过后的行数(有些单行字数太长的会被扩展为两行或两行以上)
-p
不以卷动的方式显示每一页,而是先清除萤幕后再显示内容
-c
跟-p相似,不同的是先显示内容再清除其他旧资料
-s
当遇到有连续两行以上的空白行,就代换为一行的空白行
-u
不显示下引号(根据环境变数TERM指定的terminal而有所不同)
+/
在每个档案显示前搜寻该字串(pattern),然后从该字串之后开始显示
+num
从第num行开始显示
fileNames
欲显示内容的档案,可为复数个数
例如:
more -s testfile 逐页显示testfile之档案内容,如有连续两行以上空白行则以一行空白行显示。
more +20 testfile 从第20行开始显示testfile之档案内容。
网络操作命令
命令
功能
命令
功能
ftp
传送文件
telnet
远端登陆
bye
结束连线并结束程序
rlogin
远端登入
ping
检测主机
netstat
显示网络状态
8.1 ftp命令
ftp命令用来传输文件,非常重要。如果在网络上看到一个很重要的文件,就可以用这个命令把那个文件传到自己的机器上来。
标准用法:
ftp (-选项) 主机名称或IP地址
选项
含义
-D
详细显示命令的执行过程,便于排错和分析程序的执行情况
-I
关闭互动模式,不询问任何问题
-G
关闭本地主机文件名称支持特殊字符的扩充特征
-N
不适用自动登录。FTP在启动时,会尝试自动登录远端系统,它会从用户的转述目录中读取rc文件的内容,以便自行登录。若该文件不存在,FTP会放弃自动登录,并询问用户的账号名称
-V
显示命令的执行过程
举例说明,用ftp登录ftp.dark主机,输入命令:
ftp ftp.dark
注意:用户必须有相应的存取权限,否则不能从远程系统中获得文件或向远程系统中传输文件。为了使用ftp来传输文件,用户必须知道远程计算机上的合法用户名和口令。
8.2 bye命令
在ftp模式下,输入bye即可中断目前的连线作业,并结束ftp的执行,没有选项。
8.3 ping命令
执行ping命令,它会使用ICMP传输协议,发出要求回应的信息,若远程主机的网络没有什么问题,就会回应信息,因而得知该主机运作正常。
标准用法:
ping (-选项) 主机名称或IP地址
选项
含义
c 次数
设置完成要求回应的次数。ping命令会反复发出信息,直到达到设定的次数为止
D
使用Socket的SO_DEBUG功能
F
大量而且快速地送网络封包给一台机器,看它的回应。一般不到几秒钟,送出去的封包就会超过两千个
I 秒数
指定收发信息的间隔时间,单位为s,预置位1s。与参数f不兼容
S bytes
设置数据包的大小。预设置为56B,加上8B ICMP头文件,共64B
R
忽略网关,直接将数据保送到远程主机上。如果该主机并非局域网的一份子,就会传回错误信息
Q
不显示命令的执行过程,只显示结果
V
详细显示命令的执行过程,包括非回应信息和其它信息
T 存活数值
设置存活数值TTL的大小。TTL是IP协议包中的一个值,它告诉网络,数据包在网络中的时间是否太长而应被丢弃
举例说明,检测des.bllod主机网络功能是否正常,送出去要去信息需完成5次回应,每次间隔10s,数据包的大小为512B,输入命令:
ping –c 5 –i 10 –s 504 –t 64 des.blood
8.4 telnet命令
telnet命令的主要功能是进行远程登录。该命令允许用户在使用telnet协议的远程计算机之间 进行通信,用户可以通过网络在远程计算机上登录,就像登录到本地机上执行命令一样。为了通过telnet登录计算机,必须知道远程计算机上的合法用户名和 口令。telnet只为普通终端提供终端仿真,而不支持X Window等图形环境。
标准用法:
telnet 主机名或IP
例如登录IP地址为140.114.63.12的计算机,输入命令:
telnet 140.114.63.12
一旦telnet成功连接到远程系统上,就显示登录信息,并提示用户输入用户名和口令。如果用户名和 口令正确,就能成功登录并在远程系统上工作。用户结束了远程会话后,一定要确保使用logout命令退出远程系统。然后telnet报告远程会话被关闭, 并返回到用户本地机的shell提示符下。
8.5 rlogin命令
rlogin也是用来远程登录的。它的英文含义是remote login。该命令与telnet命令很相似,允许用户启动远程系统上的交互命令会话。用法:
rlogin (-选项) host
选项
含义
8
允许输入8位字符数据
e
为rlogin会话设置转义字符,默认的转义字符是“~”,用户可以指定一个文字字符或一个/nnn形式的八进制数
E
停止任何转义字符。当与-8选项一起使用时,它提供一个完全透明的链接
l 用户名称
指定要登入远端主机的用户名称
L
使用litout模式进行远端登入操作
例如,要登入别人的计算机。输入命令:
rlogin –l inin 140.114.125.24
8.6 netstat命令
netstat命令的主要功能是了解Linux系统的网络情况。假设没有指定任何参数给netstat命令,则效果和指定-F参数相同。
用法:
netstat (-选项)
选项
说明
a
显示所有连线中的Socket
F
显示FIB
a
全部列出,包括正在等待的程序
c
持续列出网络状态
i
显示网络界面信息
n
使用网络ip地址代替名称
o
显示计时器
r
显示网络路径表
t
显示TCP协议的连接情形
u
显示UDP协议的连接情形
v
显示版本信息
w
显示RAW传输协议的连接情形
which
语法
which command
说明
依序从path环境变量所列的目录中找出command的位置,并显示完整路径的名称。在找到第一个符合条件的程序文件时,就立刻停止搜索,省略其余未搜索目录。
范例,找出ls命令的程序文件的位置:
which ls
系统输出:
/usr/bin/ls
whereis
语法
whereis [option] name
说明
找出特定程序的可执行文件、源代码文件以及manpage的路径。你所提供的name会被先除去前置的路径以及任何.ext形式的扩展名。
whereis 只会在标准的Linux目录中进行搜索。
常用选项
-b
只搜索可执行文件。
-m
只搜索manpage。
-s
只搜索源代码文件。
-B directory
更改或限定搜索可执行的文件的目录。
-M directory
更改或限定搜索manpage的目录。
-S directory
更改或限定搜索源代码文件的目录。
find
语法
find paths expression [action]
说明
以paths为搜索起点逐层往下找出每一个符合expression条件的文件,并对该文件执行action所代表的动作。expression是搜索条件,它由一个代表匹配项目的选项以及一个代表匹配模式的参数构成。
action是处理动作,它有一个代表“处理方式”的选项以及一个操作参数构成。若不指定action,则默认动作是显示出文件名。
常用的搜索条件
-name pattern
-path pattern
-lname pattern
找出名称、路径名称或符号链接的目标匹配pattern模式的文件。pattern可以包含shell的文件名通配符,路径是相对于搜索起点的。
常见处理动作
显示出文件的相对路径(相对于搜索起点)。
-exec cmd /;
执行指定的shell命令。若cmd含有任何shell特殊字符,则他们之前都必须加上/符号,以免shell立刻执行他们。在cmd里,可以用”{}”符号(包括双引号)表示find所找出的文件。
locate
语法
locate patterns
说明
第一次执行locate时,它会建立一个索引数据库,当往后再次执行时,它便从索引数据库中迅速找出文件的位置。locate很适合用来反复搜索很少变动的目录树,但是对于刚改名的旧文件以及新建的文件,locate就找不到了,除非重建数据库。
updatedb
语法
updatedb [option]
说明
更新slocate的索引数据库。
选项
-e directories
略过directories所列的目录。
命令
功能
命令
功能
echo
显示一字串
passwd
修改密码
clear
清除显示器
lpr
打印
lpq
查看在打印队列中等待的作业
lprm
取消打印队列中的作业
9.1 echo命令
echo命令用来在显示器上输出一段文字,这个命令常用来输出一些提示信息,因此这个命令的意义在于输出一些文字。它的用法也很简单:
echo –(参数) 字串 (可以用"”,也可以不用,显示略有区别)
参数n代表输出文字后不换行,如果不加参数会自动换行。
输入命令:
echo “welcome to use Linux”
输出结果为:
welcome to use Linux
如果不加"”,则输出结果为:
welcome to use Linux
它们的区别在于后一个输出,每两个输出之间只隔一个空格,这是因为echo把这些输出看做字串的缘故。
9.2 clear命令
clear命令的主要功能是清除显示器,这个命令很简单,只要输入clear即可。
9.3 passwd命令
passwd命令用来修改用户的密码。
在shell下输入
passwd
然后,根据提示输入旧密码和新密码即可。
9.4 lpr命令
lpr命令的功能是把指定的文件发送到打印队列中。例如,lpr foo.txt 会打印 foo.txt 文件。
标准用法:
lpr filename
要查看在打印队列中等待的作业,在命令行中输入命令lpq。系统返回如下信息:
active root 389 foo.txt
在这个例子中,389是作业号码。还可以取消打印队列中的作业,格式是:
lprm 作业号码
输入命令:
lprm 389
这样就去修了 foo.txt 打印作业
版权声明:本文标题:Linux系统常用命令 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://m.elefans.com/dianzi/1728276533a1151504.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论