命令
sudo passwd [root] 设置root密码
基础命令
- 获取登录信息 - w / who / last/ lastb。
- 查看自己使用的Shell - ps。
- 查看命令的说明和位置 - whatis / which / whereis
- 查看帮助文档 - man / info / help / apropos。
- 查看系统和主机名 - uname / hostname。
- 时间和日期 - date / cal
- 重启和关机 - reboot / shutdown。
- 退出登录 - exit / logout。
- 查看历史命令 - history。
实用程序
文件和文件夹操作
- 创建/删除空目录 - mkdir / rmdir。
- 创建/删除文件 - touch / rm
touch命令用于创建空白文件或修改文件时间。在Linux系统中一个文件有三种时间:
更改内容的时间 - mtime。
更改权限的时间 - ctime。
最后访问时间 - atime。
rm的几个重要参数:
-i:交互式删除,每个删除项都会进行询问。
-r:删除目录并递归的删除目录中的文件和目录。
-f:强制删除,忽略不存在的文件,没有任何提示。
查看目录内容 - ls。
-l:以长格式查看文件和目录。
-a:显示以点开头的文件和目录(隐藏文件)。
-R:遇到目录要进行递归展开(继续列出目录下面的文件和目录)。
-d:只列出目录,不列出其他内容。
-S / -t:按大小/时间排序。
3. 查看文件内容 - cat / tac / head / tail / more / less / rev / od。
cat是显示文件夹的命令,这个大家都知道,tac是cat的倒写,意思也和它是相反的。cat是从第一行显示到最后一行,而tac是从最后一行显示到第一行,而rev 则是从最后一个字符显示到第一个字符。例如:
cat 显示为:
asdf
sdfa
则tac显示为:
sdfa
asdf
rev显示为:
fdsa
afds
4. 压缩/解压缩和归档/解归档 - gzip / gunzip / xz。
5. 归档和解归档 - tar。
6. 将标准输入转成命令行参数 - xargs。
下面的命令会将查找当前路径下的html文件,然后通过xargs将这些文件作为参数传给rm命令,实现查找并删除文件的操作。
[root@iZwz97tbgo9lkabnat2lo8Z ~]# find . -type f -name "*.html" | xargs rm -f
下面的命令将a.txt文件中的多行内容变成一行输出到b.txt文件中,其中<表示从a.txt中读取输入,>表示将命令的执行结果输出到b.txt中。
[root@iZwz97tbgo9lkabnat2lo8Z ~]# xargs < a.txt > b.txt
7. 显示文件或目录 - basename / dirname。
- 其他相关工具。
sort - 对内容排序
uniq - 去掉相邻重复内容
tr - 替换指定内容为新内容
cut / paste - 剪切/黏贴内容
split - 拆分文件
file - 判断文件类型
wc - 统计文件行数、单词数、字节数
iconv - 编码转换
管道和重定向
- 输出重定向和错误重定向 - > / >> / 2>。
- 输入重定向 - <。
- 多重定向 - tee。
下面的命令除了在终端显示命令ls的结果之外,还会追加输出到ls.txt文件中。
[root ~]# ls | tee -a ls.txt
文本处理
模式匹配和处理语言 - awk。
awk是一种编程语言,也是Linux系统中处理文本最为强大的工具,它的作者之一和现在的维护者就是之前提到过的Brian Kernighan(ken和dmr最亲密的伙伴)。通过该命令可以从文本中提取出指定的列、用正则表达式从文本中取出我们想要的内容、显示指定的行以及进行统计和运算,总之它非常强大。
假设有一个名为fruit2.txt的文件,内容如下所示。
[root ~]# cat fruit2.txt
1 banana 120
2 grape 500
3 apple 1230
4 watermelon 80
5 orange 400
显示文件的第3行。
[root ~]# awk 'NR==3' fruit2.txt
3 apple 1230
显示文件的第2列。
[root ~]# awk '{print $2}' fruit2.txt
banana
grape
apple
watermelon
orange
显示文件的最后一列。
[root ~]# awk '{print $NF}' fruit2.txt
120
500
1230
80
400
输出末尾数字大于等于300的行。
[root ~]# awk '{if($3 >= 300) {print $0}}' fruit2.txt
2 grape 500
3 apple 1230
5 orange 400
用户管理
- 创建和删除用户 - useradd / userdel。
[root home]# useradd hellokitty
[root home]# userdel hellokitty
-d - 创建用户时为用户指定用户主目录
-g - 创建用户时指定用户所属的用户组
2. 创建和删除用户组 - groupadd / groupdel。
说明:用户组主要是为了方便对一个组里面所有用户的管理。
- 修改密码 - passwd。
[root ~]# passwd hellokitty
New password:
Retype new password:
passwd: all authentication tokens updated successfully.
说明:输入密码和确认密码没有回显且必须一气呵成的输入完成(不能使用退格键),密码和确认密码需要一致。如果使用passwd命令时没有指定命令作用的对象,则表示要修改当前用户的密码。如果想批量修改用户密码,可以使用chpasswd命令。
- -l / -u - 锁定/解锁用户。
- -d - 清除用户密码。
- -e - 设置密码立即过期,用户登录时会强制要求修改密码。
- -i - 设置密码过期多少天以后禁用该用户。
- 查看和修改密码有效期 - chage。
设置hellokitty用户100天后必须修改密码,过期前15天通知该用户,过期后15天禁用该用户。
chage -M 100 -W 15 -I 15 hellokitty
- 切换用户 - su。
[root ~]# su hellokitty
[hellokitty root]$
- 以管理员身份执行命令 - sudo。
[hellokitty ~]$ ls /root
ls: cannot open directory /root: Permission denied
[hellokitty ~]$ sudo ls /root
[sudo] password for hellokitty:
说明:如果希望用户能够以管理员身份执行命令,用户必须要出现在sudoers名单中,sudoers文件在 /etc目录下,如果希望直接编辑该文件也可以使用下面的命令。
- 编辑sudoers文件 - visudo。
这里使用的编辑器是vi,关于vi的知识在后面有讲解。该文件的部分内容如下所示:
## Allow root to run any commands anywhere
root ALL=(ALL) ALL
## Allows members of the 'sys' group to run networking, software,
## service management apps and more.
# %sys ALL = NETWORKING, SOFTWARE, SERVICES, STORAGE, DELEGATING, PROCESSES, LOCATE, DRIVERS
## Allows people in group wheel to run all commands
%wheel ALL=(ALL) ALL
## Same thing without a password
# %wheel ALL=(ALL) NOPASSWD: ALL
## Allows members of the users group to mount and unmount the
## cdrom as root
# %users ALL=/sbin/mount /mnt/cdrom, /sbin/umount /mnt/cdrom
## Allows members of the users group to shutdown this system
# %users localhost=/sbin/shutdown -h now
-
显示用户与用户组的信息 - id。
-
给其他用户发消息 -write / wall。
发送方:
[root ~]# write hellokitty
Dinner is on me.
Call me at 6pm.
接收方:
[hellokitty ~]$
Message from root on pts/0 at 17:41 ...
Dinner is on me.
Call me at 6pm.
EOF
查看/设置是否接收其他用户发送的消息 - mesg。
[hellokitty ~]$ mesg
is y
[hellokitty ~]$ mesg n
[hellokitty ~]$ mesg
is n
文件系统
文件和路径
- 命名规则:文件名的最大长度与文件系统类型有关,一般情况下,文件名不应该超过255个字符,虽然绝大多数的字符都可以用于文件名,但是最好使用英文大小写字母、数字、下划线、点这样的符号。文件名中虽然可以使用空格,但应该尽可能避免使用空格,否则在输入文件名时需要用将文件名放在双引号中或者通过
\
对空格进行转义。 - 扩展名:在Linux系统下文件的扩展名是可选的,但是使用扩展名有助于对文件内容的理解。有些应用程序要通过扩展名来识别文件,但是更多的应用程序并不依赖文件的扩展名,就像
file
命令在识别文件时并不是依据扩展名来判定文件的类型。 - 隐藏文件:以点开头的文件在Linux系统中是隐藏文件(不可见文件)。
目录结构
- /bin - 基本命令的二进制文件。
- /boot - 引导加载程序的静态文件。
- /dev - 设备文件。
- /etc - 配置文件。
- /home - 普通用户主目录的父目录。
- /lib - 共享库文件。
- /lib64 - 共享64位库文件。
- /lost+found - 存放未链接文件。
- /media - 自动识别设备的挂载目录。
- /mnt - 临时挂载文件系统的挂载点。
- /opt - 可选插件软件包安装位置。
- /proc - 内核和进程信息。
- /root - 超级管理员用户主目录。
- /run - 存放系统运行时需要的东西。
- /sbin - 超级用户的二进制文件。
- /sys - 设备的伪文件系统。
- /tmp - 临时文件夹。
- /usr - 用户应用目录。
- /var - 变量数据目录。
磁盘管理
- 列出文件系统的磁盘使用状况 - df。
[root ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/vda1 40G 5.0G 33G 14% /
devtmpfs 486M 0 486M 0% /dev
tmpfs 497M 0 497M 0% /dev/shm
tmpfs 497M 356K 496M 1% /run
tmpfs 497M 0 497M 0% /sys/fs/cgroup
tmpfs 100M 0 100M 0% /run/user/0
- 磁盘分区表操作 - fdisk。
[root ~]# fdisk -l
Disk /dev/vda: 42.9 GB, 42949672960 bytes, 83886080 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk label type: dos
Disk identifier: 0x000a42f4
Device Boot Start End Blocks Id System
/dev/vda1 * 2048 83884031 41940992 83 Linux
Disk /dev/vdb: 21.5 GB, 21474836480 bytes, 41943040 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
-
磁盘分区工具 - parted。
-
格式化文件系统 - mkfs。
[root ~]# mkfs -t ext4 -v /dev/sdb
- -t - 指定文件系统的类型。
- -c - 创建文件系统时检查磁盘损坏情况。
- -v - 显示详细信息。
- 文件系统检查 - fsck。
-
转换或拷贝文件 - dd。
-
挂载/卸载 - mount / umount。
-
创建/激活/关闭交换分区 - mkswap / swapon / swapoff。
-
创建/激活/关闭交换分区 - mkswap / swapon / swapoff。