目录
文件和目录操作:
ls
cd
pwd
cp
mv
rm
mkdir
rmdir
touch
clear
history
which/whereis
文件查看和编辑:
cat
less
head
tail
vi 或 vim
sz/rz
echo
系统信息和管理:
su
uname
hostname
df
free
top
ps
kill
chmod
网络操作:
ping
ifconfig 或 ip
netstat
curl
Linux 是一个开源的操作系统内核,广泛应用于服务器、桌面、嵌入式系统和超级计算机等领域。它由 Linus Torvalds 于 1991 年首次发布,并由全球开发者社区共同维护和开发。以下是一些关于 Linux 的常用命令。
文件和目录操作:
ls
列出目录内容。
cd
切换目录。
pwd
(print working directory)查看当前目录所在位置。
cp
复制文件或目录。
命令:cp [-r] 参数1 参数2
命令解释:
-r选项, 可选,用于复制文件夹使用,表示递归
参数1,被复制的文件
参数2,复制去的地方
举例:cp -r a b
将源目录 a 及其所有内容(包括子目录和文件)复制到目标目录 b。
mv
移动或重命名文件或目录。
mv 参数1 参数2
- 被移动的文件或文件夹
- 移动去的地方路径
举例:mv a b
将源文件或目录 a 移动到目标文件或目录 b。
rm
删除文件或目录。
rm -rf 是一个非常强大且危险的命令,用于在 Linux 系统中删除文件和目录。它结合了两个选项:-r 和 -f。
命令解析
- rm:是一个用于删除文件和目录的命令。
- -r:-r 或 --recursive 选项表示递归删除,即删除目录及其所有子目录和文件。
- -f: -f 或 --force 选项表示强制删除,即不提示确认,忽略不存在的文件和目录。
mkdir
创建目录。
rmdir
删除空目录。
touch
创建文件。
clear
清除屏幕。
history
查看历史命令
which/whereis
查看程序安装目录
which命令 eg:which redis-server
which -a ls
-a:显示所有匹配的路径,而不仅仅是第一个匹配的路径。
whereis命令 eg:whereis redis-server
文件查看和编辑:
cat
显示文件的内容。它会将文件的所有内容输出到标准输出(通常是终端)。
cat 文件名
less
用于分页显示文件的内容。它允许你逐页浏览文件内容,而不是一次性显示所有内容。
less 文件名
在 less
命令的界面中,你可以使用以下键盘快捷键来浏览文件内容:
Space
或f
:向下滚动一页。b
:向上滚动一页。Enter
:向下滚动一行。q
:退出less
命令。
head
用于显示文件的前几行。默认情况下,它显示文件的前 10 行。
head 文件名
你也可以指定显示的行数,例如显示前 5 行:
head -n 5 example.txt
tail
用于显示文件的后几行。默认情况下,它显示文件的后 10 行。
tail 文件名
你也可以指定显示的行数,例如显示后 5 行:
tail -n 5 example.txt
实时监控文件
tail 命令还可以用于实时监控文件的变化。使用 -f 选项可以实时显示文件的新内容。
tail -f 文件名
假设你有一个名为 logfile.txt 的日志文件,你可以使用以下命令来实时监控文件的变化:
tail -f logfile.txt
这个命令会显示文件 filename 的最后 100 行,并实时监控文件的变化。
tail -f -n 100 filename
vi
或 vim
强大的文本编辑器,查看文件中的内容。
示例
假设你有一个名为 example.txt
的文件,你想使用 vim
编辑它。你可以使用以下命令:
vim example.txt
编辑文件
进入插入模式:按 i 键。
输入文本:例如,输入 Hello, world!。
退出插入模式:按 Esc 键。
保存并退出:输入 :wq 并按 Enter 键。
搜索文本
进入命令模式:按 Esc 键。
输入 / 并键入要搜索的文本,例如 /world。
按 Enter 键开始搜索。
按 n 键跳转到下一个搜索结果。
按 N 键跳转到上一个搜索结果。
删除行
进入命令模式:按 Esc 键。
将光标移动到要删除的行。
输入 dd 删除当前行。
复制和粘贴
进入命令模式:按 Esc 键。
将光标移动到要复制的行。
输入 yy 复制当前行。
将光标移动到要粘贴的位置。
输入 p 粘贴复制的内容。
sz/rz
sz
命令用于从 Unix/Linux 系统向 Windows 系统发送文件。
rz
命令用于从 Windows 系统向 Unix/Linux 系统接收文件。
上传和下载都是针对Unix/Linux来说的,这样就好记忆。(sz发送就是下载,rz接收就是上传。)
假设你有一个名为 example.txt 的文件,你想将其从 Unix/Linux 系统发送到 Windows 系统,可以使用以下命令:
sz example.txt
假设你想从 Windows 系统接收一个文件,可以在 Unix/Linux 系统上运行以下命令:
rz或rz -y
-y表示如果名称重复直接进行覆盖。
echo
echo
是一个用于在终端输出文本的命令。它可以显示字符串、变量的值、特殊字符等。
语法:echo 文本
输出简单文本
假设你想在终端输出文本 "Hello, world!",可以使用以下命令:
echo Hello, world!
输出为:Hello, world!
系统信息和管理:
su
switch user,切换用户。eg:su root
uname
显示系统信息。
hostname
获取主机名,修改主机名
hostname
获取主机名
hostnamectl set-hostname 主机名
修改主机名(需root)
df
显示文件系统的磁盘空间使用情况。
df -h
-h:以更加人性化的单位显示磁盘使用情况
free
显示内存使用情况。
free -m
用来显示内存使用情况,以MB为单位。
它的输出格式通常是这样的:
total used free shared buffers cached
Mem: 7983 6509 1474 199 104 3707
-/+ buffers/cache: 2697 5286
Swap: 16383 972 15411其中:
● total表示系统当前总内存大小。
● used表示当前已经使用的内存大小。
● free表示当前未使用的内存大小。
● shared表示被共享使用的内存大小,通常是进程间通信时使用的内存。
● buffers表示被缓冲的内存大小,通常是文件系统操作时使用的内存。
● cached表示被缓存的内存大小,通常是为了提高系统性能而缓存的内存。
另外,在 -/+ buffers/cache 行下面的 used 表示实际使用的内存大小,free 表示当前可用的内存大小。free命令支持几个选项,例如-b表示显示字节为单位,-k表示显示KB为单位,-g表示显示GB为单位等。
top
是一个实时监控系统性能的命令行工具,用于显示系统中的进程、CPU 使用率、内存使用率、负载平均值等信息。
python@ubuntu:~$ top
top - 08:31:54 up 2 min, 1 user, load average: 0.25, 0.37, 0.17
Tasks: 271 total, 1 running, 270 sleeping, 0 stopped, 0 zombie
%Cpu(s): 0.2 us, 0.0 sy, 0.0 ni, 99.8 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 4028880 total, 3210104 free, 331668 used, 487108 buff/cache
KiB Swap: 4192252 total, 4192252 free, 0 used. 3414856 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
4827 redis 20 0 47204 6632 2300 S 0.3 0.2 0:00.21 redis-ser+
6371 python 20 0 49000 3896 3176 R 0.3 0.1 0:00.12 top
1 root 20 0 119940 6112 4004 S 0.0 0.2 0:02.77 systemd
2 root 20 0 0 0 0 S 0.0 0.0 0:00.02 kthreadd
3 root 20 0 0 0 0 S 0.0 0.0 0:00.11 ksoftirqd+
1. 系统性能概览:
a. 第一行显示系统的基本信息,包括当前时间、系统运行时间、用户数量、负载平均值等。
b. 第二行显示进程的状态信息,包括总进程数、运行中的进程数、睡眠中的进程数、停止的进程数、僵尸进程数等。
c. 第三行显示 CPU 使用率信息,包括用户空间占用的 CPU 时间、系统空间占用的 CPU 时间、空闲 CPU 时间等。
d. 第四行和第五行显示内存和交换区的使用情况,包括总内存、已用内存、空闲内存、缓冲区、缓存等。
2. 进程列表:
a. 进程列表显示系统中的各个进程,包括进程 ID(PID)、用户名(USER)、优先级(PR)、虚拟内存(VIRT)、物理内存(RES)、共享内存(SHR)、状态(S)、CPU 使用率(%CPU)、内存使用率(%MEM)、运行时间(TIME+)、命令名称(COMMAND)等。
ps
查询当前进程。
查询java的进程:ps -ef | grep java
grep:是一个用于搜索文本的命令。
java:是搜索的关键字。
|:管道符,将左边的输出结果当作右边的输入。
kill
终止进程。
kill -15(优雅)/-9(强制) PID(进程的PID)
kill -9 发送的是 SIGKILL 信号(信号编号为 9)。这个信号会立即终止进程,不允许进程进行任何清理操作。它是强制终止进程的方式,通常用于那些无法通过其他方式终止的进程
kill -15 发送的是 SIGTERM 信号(信号编号为 15)。这个信号是一个终止信号,但它允许进程进行清理操作(如关闭文件、释放资源等)。它是一种优雅的终止方式,通常用于正常终止进程。
chmod
是一个用于修改文件或目录权限的命令。chmod 是 "change mode" 的缩写,用于更改文件或目录的访问权限。
chmod 777 文件
chmod 777 是一个用于修改文件或目录权限的命令。chmod 是 "change mode" 的缩写,用于更改文件或目录的访问权限。777 是权限的数字表示形式。
权限的数字表示形式
在 Unix 和 Linux 系统中,文件和目录的权限分为三类:
1.用户(User):文件的所有者。
2.组(Group):文件所有者所属的组。
3.其他(Others):其他所有用户。
每类权限可以有以下三种权限:r w x
●读(Read):权限值为 4。
●写(Write):权限值为 2。
●执行(Execute):权限值为 1。
权限值是这三种权限的总和。例如:
●读和执行权限:4 + 1 = 5。
●读、写和执行权限:4 + 2 + 1 = 7。
777 的含义
777 表示所有用户(用户、组、其他)都有读、写和执行权限:
●用户:读、写、执行(7)。
●组:读、写、执行(7)。
●其他:读、写、执行(7)。
网络操作:
ping
检查指定的网络是否可以联通。
ping 127.0.0.1
ifconfig
或 ip
显示和配置网络接口。
netstat
显示网络连接和路由表。
常用选项
-a:显示所有连接(包括监听的和未监听的)。
netstat -a
-t:显示 TCP 连接。
netstat -t
-u:显示 UDP 连接。
netstat -u
-n:以数字形式显示地址和端口号,而不是解析为主机名和服务名。
netstat -n
-p:显示进程 ID 和程序名。
netstat -p
-l:显示监听的连接。
netstat -l
-r:显示路由表。
netstat -r
-i:显示网络接口统计信息。
netstat -i
-s:显示网络协议统计信息。
netstat -s
组合使用
netstat命令查看端口是否被占用
netstat -anp | grep 端口号 eg:netstat -anp | grep 8080 (没有打印就说明没有被占用)
netstat -tpln 用于显示系统中的所有 TCP 连接及其详细信息。
netstat -upln 用于显示系统中的所有 UDP 连接及其详细信息。
curl
curl
是一个强大的命令行工具,用于从命令行传输数据。它支持多种协议,包括 HTTP、HTTPS、FTP、SFTP、SCP、TFTP 等。curl
常用于下载文件、上传文件、发送 HTTP 请求等。
curl [选项] [URL]
常用选项
-O:将文件保存到本地,使用远程文件的原始名称。
curl -O http://example.com/file.txt
-o:将文件保存到本地,使用指定的文件名。
curl -o localfile.txt http://example.com/file.txt
-L:跟随重定向。
curl -L http://example.com/redirect
-I:仅显示响应头信息。
curl -I http://example.com
-X:指定请求方法(GET、POST、PUT、DELETE 等)。
curl -X POST http://example.com/api
-d:发送 POST 数据。
curl -X POST -d "param1=value1¶m2=value2" http://example.com/api
-H:添加自定义请求头。
curl -H "Content-Type: application/json" http://example.com/api
-u:指定用户名和密码进行基本认证。
curl -u username:password http://example.com/protected
-k:忽略 SSL 证书验证。
curl -k https://example.com
-v:显示详细的请求和响应信息。
curl -v http://example.com
-s:静默模式,不显示进度条和错误信息。
curl -s http://example.com
-F:以表单数据的方式发送数据。
curl -F "file=@/path/to/file" http://example.com/upload
示例
下载文件
假设你想从 http://example.com/file.txt 下载文件并保存为 localfile.txt,可以使用以下命令:
curl -o localfile.txt http://example.com/file.txt
发送 POST 请求
假设你想向 http://example.com/api 发送一个 POST 请求,并包含一些表单数据,可以使用以下命令:
curl -X POST -d "param1=value1¶m2=value2" http://example.com/api
发送 JSON 数据
假设你想向 http://example.com/api 发送一个 POST 请求,并包含 JSON 数据,可以使用以下命令:
curl -X POST -H "Content-Type: application/json" -d '{"key1":"value1","key2":"value2"}' http://example.com/api
上传文件
假设你想将本地文件 /path/to/file 上传到 http://example.com/upload,可以使用以下命令:
curl -F "file=@/path/to/file" http://example.com/upload