Linux 简单命令总结

Linux 简单命令总结

1. 简单命令

1.1. ls

列出该目录下的所有子目录与文件,后面还可以跟上一些选项

常用选项:
・-a 列出目录下的所有文件,包括以。开头的隐含文件。
・-d 将目录象文件一样显示,而不是显示其下的文件。如:ls -d 指定目录
・-k 以 k 字节的形式表示文件的大小。ls -alk 指定文件
・-l 列出文件的详细信息。
・-r 对目录反向排序。
・-t 以时间排序。
・-R 列出所有子目录下的文件。

1.2. cd

cd :切换目录

2的n次方_-ZEEKLOG博客

1.3. pwd

pwd:显示当前目录

2. 创建文件和文件夹

2.1. 创建文件

touch + 文件名

2.2. 创建文件夹

2.2.1. 创建单个文件夹

mkdir + 文件名称

2.2.2. 创建多级文件夹

mkdir -p 表示创建多级目录,./ 表示在当前目录下创建文件夹,

mkdir -p ./parent/child/grandchild

3. 删除

3.1. 删除文件

rm + 要删除的文件名

3.2. 删除文件夹

rm -r + 要删除的文件夹名称

也可以加上 / 表示删除此文件夹下的文件夹

4. 复制和移动

4.1. cp

cp 命令可以复制文件或者目录:cp 源文件或目录 目标文件或目录

4.2. mv

mv 的功能和剪切一样,就是把一个文件或目录移动到另一个位置

mv cat.jpg test/

也可以实现文件重命名的效果

这样就相当于把 test1.txt 重命名为了 test2.txt

5. 上传和下载

上传和下载是通过 rz 和 sz 命令来完成的,如果输入之后显示没下载的话可以通过命令先下载一下

apt-get install lrzsz

5.1. rz

输入 rz 后就会弹出一个框,用来选择要将哪个 windows 中的文件上传到 Linux 中

5.2. sz

sz 要下载的文件名

输入之后也会弹出就直接下载到 windows 中了

除了上面通过命令的方式进行上传之外,还可以直接将 Windows 中的文件拖到 finalshell 的文件区中

也可以直接右键来选择上传和下载

6. 查看文件内容

6.1. cat

输入 cat + 要查看的文件名,就会显示文件内容在命令行中

6.2. more

使用 cat 命令是把该文件所有的内容都展示出来,这样就会把命令行铺满,影响操作

通过 more 命令来读取文件就会显示文件的一部分: more + 要查看的文件名

按下回车可以继续阅读剩下的部分,b 键可以查看上一页,如果直接想退出的话 ctrl + c 就能退出了,可以输入 / 后面跟要查找的内容,然后按下回车就会跳转到目标位置

6.3. less

less + 文件名也可以查看文件

此时是通过 PgUp 和 PgDn 键来进行翻页的

使用 less 的话文件的内容是不会留在命令行中的,就像打开了一个记事本进行查看一样,还支持搜索功能,也可以输入 / 查找的内容,按下回车就会把所有搜索到的都标记出来

:q 可以退出查看

6.4. head

head 默认查看的是文件的前 10 行,也可以指定查看的行数

6.5. tail

tail 就是从末尾开始查看

7. clear 清屏

在查看了文件内容之后,命令行被很多其他东西占满了,就可以使用 clear 命令来清理一下屏幕,之前输入的内容还是在上面,通过滚轮或者上键可以查看之前的内容

8. 编辑文件

8.1. vi / vim

使用 vi + 要编辑的文件,进来之后是处于阅读模式,并不能进行编辑,需要按下 i 键才能进入编辑模式

下面显示 INSERT 就可以编辑了

编辑完成之后需要按 Esc 键退出编辑模式,输入:w 是保存,:q 是退出,:q! 是强制退出,:wq 就是退出并保存

也可以使用 vim 来编辑,vim 是 vi 的增强版,如果系统中没有的话还需要手动下载一下

8.2. nano

nano 后面加要编辑的文件,进来之后可以直接编辑,下面也展示了一些写入,查找,退出等快捷键

9. grep 查找

grep 用于查找文件中是否包含指定字符串,并显示出来

还可以加上其他内容来配合使用

  • -n <行数> 显示的行数
  • w 全字匹配。要求整个单词都完全相同的结果才能匹配出来,而不仅仅是一个单词的一部分。
  • r 递归查找。可以搜索多级目录下的所有文件。
  • --color 高亮查找到的结果
  • --include 指定查找某些文件
  • --exclude 指定排除某些文件

10. ps 查询进程

ps 查询进程时一般结合下面这些选项来使用

  • a 显示一个终端的所有进程
  • u 以用户为主的格式来显示程序状况
  • x 显示所有程序,不止是会话中的进程
  • e 显示所有进程,包括系统守护进程
  • f 显示完整格式输出

一般情况下使用 ps aux 或者 ps -ef

也可以结合 grep 来使用,来查询目标进程

也可以来查看端口号

上面的 | 表示管道,意思是将前一个指令标准输出的内容,作为第二个指令的标准输入内容。

11. netstat

可以跟下面这些选项

  • -a 显示所有正在或不在侦听的套接字
  • -n 显示数字形式地址而不是去解析主机、端口或用户名
  • -p 显示套接字所属进程的 PID 和名称

还可以结合 grep 来使用

Read more

Java 中间件:RabbitMQ 延迟队列(死信交换机实现)

Java 中间件:RabbitMQ 延迟队列(死信交换机实现)

👋 大家好,欢迎来到我的技术博客! 📚 在这里,我会分享学习笔记、实战经验与技术思考,力求用简单的方式讲清楚复杂的问题。 🎯 本文将围绕Java中间件这个话题展开,希望能为你带来一些启发或实用的参考。 🌱 无论你是刚入门的新手,还是正在进阶的开发者,希望你都能有所收获! 文章目录 * Java 中间件:RabbitMQ 延迟队列(死信交换机实现) ⏳ * 什么是延迟队列?🤔 * 典型应用场景 🌟 * RabbitMQ 原生不支持延迟队列?那怎么办?🚫➡️✅ * 核心思想 💡 * 关键概念详解 🔑 * 1. TTL(Time-To-Live)⏱️ * 2. 死信(Dead Letter)⚰️ * 3. 死信交换机(DLX) & 死信路由键(DLK)🔄 * 4. 延迟队列的构建逻辑 🧩 * 环境准备 🛠️ * 启动 RabbitMQ(Docker 方式) * Spring Boot 项目搭建 🏗️ * 定义交换机、队列与绑定关系 📦 *

By Ne0inhk
【MySQL数据库基础】(四)MySQL 表的操作通关指南:创建 / 修改 / 删除一网打尽

【MySQL数据库基础】(四)MySQL 表的操作通关指南:创建 / 修改 / 删除一网打尽

前言         上一篇我们讲了 MySQL 库的核心操作,作为 MySQL 数据存储的核心载体,数据表的操作更是开发和运维中的高频操作。从表的创建、结构设计,到日常的字段增删改、表名修改,再到最后的表删除,每一步都有对应的语法和实操细节,稍不注意就可能踩坑(比如误删字段导致数据丢失)。         这篇文章就基于 MySQL 实战场景,把表的全套操作讲透,从创建表的核心语法、存储引擎的差异,到修改表的各种场景,再到删除表的高危操作注意事项,让你一文掌握 MySQL 表操作的所有精髓,新手也能快速上手!下面就让我们正式开始吧! 一、创建表:打好基础,定好结构         创建数据表是表操作的第一步,也是最关键的一步 —— 表的结构设计直接决定了后续数据存储的效率和扩展性。MySQL 中创建表的语法支持自定义字段、字段类型、字符集、校验规则和存储引擎,灵活度拉满。 1. 核心创建语法         MySQL 创建表的官方标准语法如下,关键字和可选项的设计和库操作一脉相承,理解起来非常容易: CREATE TABLE

By Ne0inhk
API网关设计模式实战 Spring Cloud Gateway路由过滤限流深度解析

API网关设计模式实战 Spring Cloud Gateway路由过滤限流深度解析

目录 ✨ 摘要 1. API网关:微服务架构的"交通枢纽" 1.1 为什么需要API网关? 1.2 Spring Cloud Gateway vs 传统方案 2. Spring Cloud Gateway架构深度解析 2.1 核心架构设计 2.2 响应式编程模型 3. 路由机制:流量指挥的艺术 3.1 静态路由配置 3.2 动态路由实现 3.3 服务发现集成 4. 过滤器链:请求处理的灵魂 4.1 过滤器类型与执行顺序 4.2 常用内置过滤器详解 4.

By Ne0inhk
SkyWalking - Kafka _ RabbitMQ 消息链路追踪支持

SkyWalking - Kafka _ RabbitMQ 消息链路追踪支持

👋 大家好,欢迎来到我的技术博客! 📚 在这里,我会分享学习笔记、实战经验与技术思考,力求用简单的方式讲清楚复杂的问题。 🎯 本文将围绕SkyWalking这个话题展开,希望能为你带来一些启发或实用的参考。 🌱 无论你是刚入门的新手,还是正在进阶的开发者,希望你都能有所收获! 文章目录 * SkyWalking - Kafka / RabbitMQ 消息链路追踪支持 🚀 * 为什么需要消息链路追踪?🤔 * SkyWalking 核心概念回顾 🔍 * Kafka 链路追踪支持 🐘 * 1. 自动探针(推荐)✅ * 前提条件 * 工作原理 * Java 代码示例(无需修改业务代码!) * 验证追踪效果 * 2. 手动埋点(高级场景)🛠️ * 添加依赖 * 手动注入上下文(Producer) * 手动提取上下文(Consumer) * RabbitMQ 链路追踪支持 🐇 * 工作原理 * Java 代码

By Ne0inhk