【Linux】Linux基本命令

news2024/9/27 7:29:05

目录

文件和目录操作:

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

命令解析

  1.  rm:是一个用于删除文件和目录的命令。
  2. -r-r--recursive 选项表示递归删除,即删除目录及其所有子目录和文件。
  3. -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 命令的界面中,你可以使用以下键盘快捷键来浏览文件内容:

  • Spacef:向下滚动一页。
  • b:向上滚动一页。
  • Enter:向下滚动一行。
  • q:退出 less 命令。

用于显示文件的前几行。默认情况下,它显示文件的前 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

vivim

强大的文本编辑器,查看文件中的内容。

示例

假设你有一个名为 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

ifconfigip

显示和配置网络接口。

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&param2=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&param2=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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2163963.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

fopen与fwrite在C语言中写文件及open、write的对比

fopen与fwrite在C语言中写文件及open、write的对比 一、fopen与fwrite写文件1. fopen函数介绍2. fwrite函数介绍3. 示例代码4. 注意事项二、open与write写文件1. open函数介绍2. write函数介绍3. 示例代码4. 注意事项三、fopen/fwrite与open/write的对比1. 跨平台性2. 功能与灵…

android和ios双端应用性能的测试工具

1.工具介绍 基于日常工作的需要,开发了一款新的android和ios端应用性能测试工具,本工具在数据测试方面与所流行的工具没有区别。欢迎下载使用体验。 本工具为筋斗云,工具说明 本工具无侵入,不需要root,低延迟…

统一建模语言(UML)在软件研发过程中常用图接受:类图、用例图、时序图、状态图、活动图、流程图、顺序图

UML具有许多不同类型的图表,包括: 静态图:用例图、类图、对象图、组件图、部署图动态图:活动图、状态图、时序图(又叫顺序图、序列图)、协作图 软件工程(软件工程中的各种图一般用于以下三个阶段…

线上报名小程序怎么做

在这个数字化、智能化的时代,信息技术的发展正以前所未有的速度改变着我们的生活。无论是学习、工作还是娱乐,互联网都成为了我们不可或缺的一部分。而在线上报名这一领域,小程序的出现更是为广大用户带来了前所未有的便捷与高效。今天&#…

# 高可用的并发解决方案nginx+keepalived(四)

高可用的并发解决方案nginxkeepalived(四) 一、Keepalived安装 1、keepalived 介绍 Keepalived 是一种高性能的服务器高可用或热备解决方案,Keepalived 可以用来防止服务器单点故障的发生,通过配合 Nginx 可以实现 web 前端服务…

SOMEIP_ETS_134: SD_Option_Length_ends_past_Options_Array_Var_A

测试目的: 验证DUT能够处理一个其选项长度超出所指示的选项数组长度的SubscribeEventgroup消息,并以SubscribeEventgroupNAck作为响应或完全忽略该请求。 描述 在变体A中,通过将SOME/IP头部中指示的总长度从60字节略微减少到48字节&#x…

Tomcat后台弱口令部署war包

1.环境搭建 cd /vulhub/tomcat/tomcat8 docker-compose up -d 一键启动容器 2.访问靶场 点击Manager App tomcat8的默认用户名和密码都是tomcat进行登录 3.制作war包 先写一个js的一句话木马 然后压缩成zip压缩包 最后修改后缀名为war 4.在网站后台上传war文件 上传war文件…

MySQL基础篇 - SQL

01 SQL通用语法 02 SQL分类 03 DDL语句 04 DML语句 05 DQL语句(单表查询) 05_01 学习总览 05_02 基本查询 05_03 条件查询 【应用实例】: 05_04 聚合函数 05_05 分组查询 05_06 排序查询 05_07 分页查询 【boss题目】: 05_08 执行顺序 06 DCL语句 【概…

Google发布改进型Gemini 1.5 系列AI模型 并将API价格降低50%

Google今天发布了两款可投入生产环境的更新版Gemini 1.5 型号:Gemini-1.5-Pro-002 和 Gemini-1.5-Flash-002。与五月份发布的原版 Gemini 1.5 型号相比,这两款新产品略有改进。 更新后的 Gemini 1.5 系列模型在 MMLU-Pro 基准成绩提高了约 7%&#xff0c…

UNI-SOP认证系统的定位

目前市面上的认证开发框架比较多,比如SA-TOKEN、SHIRO以及SPRING集成的Oauth2等都是比较优秀的认证授权框架,还有像若依这样比较完整的带有后台一些常用功能的开发框架,诸如这些认证授权开发框架都集成了用户的登录授权功能,他们可…

C语言长度受限制的字符串函数:(strncpy,strncat,strncmp)

strncpy 重点&#xff1a;1.拷贝num个字符从源字符串到目标空间 2.如果源字符串的长度小于num&#xff0c;则拷贝完源字符串之后&#xff0c;在目标的后边追加0&#xff0c;直到num个 3.这个函数不会拷贝\0。 列子&#xff1a; #include<stdio.h> #include<string…

vcruntime140_1.dll无法继续执行代码怎么办,总结6种解决方法

在计算机编程和软件开发中&#xff0c;我们经常会遇到各种错误和问题。其中&#xff0c;vcruntime140_1.dll无法继续执行代码是一个常见的问题。这个问题可能会导致程序崩溃&#xff0c;影响我们的工作进度。因此&#xff0c;了解这个问题的原因以及如何解决它是非常重要的。 …

点云与Open3D入门

文章目录 点云数据介绍点云 Open3D点云基础操作RGBD转换为PCDPLY转PCD 点云空间搜索K-DTree原理搜索算法 OCTree 点云滤波体素下采样点云体素化复杂点云体素化统计滤波半径滤波 点云特征提取法线估计 点云分割DBSCAN 聚类分割&#xff08;运行时间较长&#xff09;PANSNC平面分…

Tableau|二 如何利用功能区创建视图

一 认识 Tableau 数据 1.数据角色 维度和度量是Tableau的一种数据角色划分&#xff0c;离散和连续是另一种划分方式。 1.维度和度量 维度往往是一些分类、时间方面的定性字段&#xff0c;将其拖放到功能区时&#xff0c;Tableau不会对其进行计算&#xff0c;而是对视图区进行分…

什么开放式耳机好用?2024五款地表最强机型推荐!

随着耳机使用的普及&#xff0c;选择一款合适的耳机变得尤为重要。入耳式耳机虽然普遍&#xff0c;但长时间佩戴可能会带来不适&#xff0c;甚至可能影响耳道健康。开放式耳机提供了一个折中的选择&#xff0c;它们不堵塞耳道&#xff0c;允许用户在享受音乐的同时&#xff0c;…

Android线程使用总结

Android线程使用总结 1. Threading Performance 在程序开发的实践当中&#xff0c;为了让程序表现得更加流畅&#xff0c;我们肯定会需要使用到多线程来提升程序的并发执行性能。但是编写多线程并发的代码一直以来都是一个相对棘手的问题&#xff0c;所以想要获得更佳的程序性…

基于主从Reactor模型实现高并发服务器

目录 1. 项目简介1.1 环境介绍1.2 项目定位1.3 功能模块整体划分 2. Reactor简介2.1 Reactor模型分析2.2 多Reactor多线程分析&#xff1a;多I/O多路复用线程池&#xff08;业务处理&#xff09; 3. 日志宏的编写4. Server模块4.1 Buffer模块4.1.1 Buffer的功能4.1.2 Buffer的实…

腾讯邮箱上传附件卡、慢、无法上传问题处理

1、检查文件中转站容量是否已满 2、建议用户打开链接https://exmail.qq.com/qy_mng_logic/wasmHelper?typehashv2&#xff0c;看是否可以正常访问。&#xff08;能打开下载就表示可以正常访问&#xff09; 3、让用户切换到4G或者其他网络再重新上传附件是否会重现问题&#xf…

网络安全全方略

网络安全全方略是指通过系统化、全面化的方法&#xff0c;从技术、管理、人员等多个维度&#xff0c;构建一个全方位、多层次的网络安全防护体系。以下是一个详细的网络安全全方略&#xff0c;涵盖了从策略制定到实施和维护的全过程。 1. 网络安全策略制定 1.1 风险评估 资产…

沸点 | 嬴图成功入选“DataTech50 for 2024”,彰显金融科技实力

近日&#xff0c;世界领先的金融科技信息服务巨头 Find Tech Global 推出首届“DataTech50 for 2024”排行榜&#xff0c;嬴图凭借其在图数据库领域的领先技术与创新能力&#xff0c;成功跻身该全球性奖项&#xff0c;荣膺这一殊荣。 “DataTech50”作为年度榜单&#xff0c;由…