当前位置: 首页 > article >正文

【Linux笔记】Linux命令与使用

博文将不断学习补充

学习参考博文:

Linux命令大全:掌握常用命令,轻松使用Linux操作系统-CSDN博客

文件或目录操作命令

zip

# zip是使用最多的文档压缩格式

# 方便跨平台使用,但是压缩率不是很高

zip指令未安装

安装zip

yum install zip

安装unzip

yum install unzip

# 压缩

zip -r archive_name.zip filename

# 将几个文件和目录同时压缩成一个zip格式的压缩包

# 解压

unzip archive_name.zip

cd

切换目录

#        个人主目录

cd ~

#        根目录

cd /

#        上一级目录

cd ..

#        上二级目录

cd ../..

#        切换至上一次目录位置

cd -

ls

#        默认显示当前目录下的文件和目录列表。

ls

#        显示当前目录下所有文件和目录,包括隐藏文件

ls -a

#        递归列出目录下文件,连同子目录文件一起列出

ls -R

#        反转列出文件的顺序

ls -r

#        列出文件或者目录的详细信息

ls -l

#        按行列出每个文件或者目录

ls -1

#        列出当前目录下的文件和目录,同时以特定方式格式化输出

ls -F

在每个条目后面添加特定的字符,以指示该条目的类型

/表示这是一个目录
@表示这是一个符号链接link
|表示这是一个管道
=表示这是一个套接字
*

表示这是一个可执行文件

#        过滤输出的列表

?表示一个字符
*

表示0或多个字符

1、列出当前目录下的文件或目录

ls -l word?或者ls -l word*

2、列出指定目录下的文件或目录

ls word?或者ls word*

pwd

显示当前工作目录

touch

创建空文件

touch filename

mkdir

创建目录

mkdir dirname

cp

cp source destination

复制文件

#        备份整个文件夹(归档模式);递归复制目录与内容,保留源文件所有属性

cp -a source destination

source 目录备份到destination目录下

#        交互式复制;覆盖目标文件前,进行提示

cp [-i] source destination

source文件内容复制到destination文件中;

若destination文件已经存在,会提示是否覆盖原文件内容;

若不存在destination文件,则创建该文件  

#        强制复制;覆盖目标文件前,不提示

cp -f source destination

#        目标文件保留原文件的属性(包括所有者、所属组、权限和时间戳等)

cp -p source destination

#        在当前目录下备份一份文件

使用单点符(.),表示当前工作目录

cp source .

mv

#        移动文件或目录到另一目录下

mv source1 [source2…] destination

默认存在相同名称文件时,mv上诉指令在覆盖前会进行提示

#        强制移动

mv -f source destination

#        移动并重命名文件或目录;仅能操作单个文件或目录

mv oldname newname

rm

#        删除文件;默认进行确认提示

rm [-i] filename1[filename2…]

#        强制删除;不进行提示

rm -f filename1[filename2…]

#        递归删除子目录文件与当前目录

rm -r dirname1 [dirname2…]

#        禁忌指令

rm -rf /*

rmdir

#        删除空目录;若目录存在文件无法删除

rmdir dirname


系统指令

shutdown

参数

-H, --halt
           Halt the machine.

       -P, --poweroff
           Power-off the machine (the default).

       -r, --reboot
           Reboot the machine.

       -h
           Equivalent to --poweroff, unless --halt is specified.

       -k
           Do not halt, power-off, reboot, just write wall message.

       --no-wall
           Do not send wall message before halt, power-off, reboot.

       -c
           Cancel a pending shutdown. This may be used cancel the effect of an invocation of shutdown with a time argument that is not "+0" or "now".

#        关闭系统

        shutdown -h now
        init 0 
        telinit 0 

#        按预定时间关闭系统
        shutdown -h hours:minutes &

#        取消按预定时间关闭系统
        shutdown -c

#        立即重启
        shutdown -r now
        reboot
#        注销

        logout

#        测算一个命令(即程序)的执行时间
        time​​​​​​​

grep

在指定文件中查找匹配的文本

grep keyword

ps

#        ps --help用法

Try 'ps --help <simple|list|output|threads|misc|all>'
  or 'ps --help <s|l|o|t|m|a>'
ps --help simple

Usage:
 ps [options]

Basic options:
 -A, -e               all processes
 -a                   all with tty, except session leaders
  a                   all with tty, including other users
 -d                   all except session leaders
 -N, --deselect       negate selection
  r                   only running processes
  T                   all processes on this terminal
  x                   processes without controlling ttys

TTY 字段代表“Terminal Type”,即终端类型。它表示进程关联的终端或控制台。

#        显示当前终端会话中属于当前用户的进程列表

ps

#        显示系统所有进程的信息

ps -e 或者ps -A

#        显示终端上的所有进程,包括其他用户的进程

ps -a

#        显示没有终端控制的进程

ps -x

ps --help output

Usage:
 ps [options]

Output formats:
 -F                   extra full
 -f                   full-format, including command lines
  f, --forest         ascii art process tree
 -H                   show process hierarchy
 -j                   jobs format
  j                   BSD job control format
 -l                   long format
  l                   BSD long format
 -M, Z                add security data (for SELinux)
 -O <format>          preloaded with default columns
  O <format>          as -O, with BSD personality
 -o, o, --format <format>
                      user-defined format
  s                   signal format
  u                   user-oriented format
  v                   virtual memory format
  X                   register format
 -y                   do not show flags, show rss vs. addr (used with -l)
     --context        display security context (for SELinux)
     --headers        repeat header lines, one per page
     --no-headers     do not print header at all
     --cols, --columns, --width <num>
                      set screen width
     --rows, --lines <num>
                      set screen height

#       显示长格式的进程信息,例如进程命令行、进程状态(S)、进程的会话ID(SID)等

ps -l

#        使用全格式显示进程信息,包括父进程ID(PPID)、进程状态、CPU使用率(%CPU)、内存使用率(%MEM)等

ps -f

ps -F 提供了比ps -f更加详细的进程信息,是其增强版。

添加了SZ(进程使用的虚拟内存大小)、RSS(进程使用的物理内存大小)、PSR(进程当前运行的CPU编号)、ADDR(进程在内核虚拟地址空间中的地址)和WCHAN(进程正在等待的内核函数名称)等字段。

#        自定义输出格式,指定要显示的列

ps -o 自定义列

ps --help list

Usage:
 ps [options]

Selection by list:
 -C <command>         command name
 -G, --Group <GID>    real group id or name
 -g, --group <group>  session or effective group name
 -p, p, --pid <PID>   process id
        --ppid <PID>  parent process id
 -q, q, --quick-pid <PID>
                      process id (quick mode)
 -s, --sid <session>  session id
 -t, t, --tty <tty>   terminal
 -u, U, --user <UID>  effective user id or name
 -U, --User <UID>     real user id or name

  The selection options take as their argument either:
    a comma-separated list e.g. '-u root,nobody' or
    a blank-separated list e.g. '-p 123 4567'

VSZ字段代表“Virtual Memory Size”,表示进程占用的虚拟内存大小(单位通常是KB)。

RSS字段代表“Resident Set Size”,表示进程当前占用的物理内存大小(单位通常是KB)。

STAT表示进程的状态;该字段包含了多个字符,每个字符都代表了一种状态。

字段解释
D不可中断的睡眠状态,通常表示进程正在进行I/O操作
R运行中或就绪状态
S可中断的睡眠状态,表示进程正在等待某个事件或资源,并且可以被信号唤醒
T停止状态
Z僵尸进程,即已经终止但尚未被父进程回收的进程
W没有足够的内存分页可分配
<高优先级的进程
N低优先级的进程
L内存锁定(memory locked)。这表示进程的一部分或全部内存被锁定在内存中,不会被换出(swapped out)
s会话领导者(session leader)。这表示进程是某个会话的领头进程
+前台进程组的成员。这表示进程属于某个前台进程组,与当前终端关联

#        显示指定用户的进程信息

ps -u [用户名]

默认当前用户的信息

#        列出指定程序的进程信息

ps -C 进程名

#        显示指定进程ID的进程信息

ps -p PID

ps --help threads

Usage:
 ps [options]

Show threads:
  H                   as if they were processes
 -L                   possibly with LWP and NLWP columns
 -m, m                after processes
 -T                   possibly with SPID column

#        查看当前系统运行的所有用户的所有进程

ps aux

#        查看所有进程ID、进程名、内存占用百分比

ps -e -o pid,comm,%mem

MobaXterm持续获取CPU和内存

top持续输出

直接读取文件

while true; do  
    echo "CPU Info at $(date)" >> system_info.log  
    cat /proc/cpuinfo >> system_info.log  
    echo "Memory Info at $(date)" >> system_info.log  
    cat /proc/meminfo >> system_info.log  
    echo "------------------------" >> system_info.log  
    sleep 5  
done

df

显示文件系统的磁盘空间使用情况

top

实时显示系统中各个进程CPU、内存等资源的使用情况。

在top界面中,按下“M”键(或“Shift+M”)可以根据内存使用率对进程进行排序。

按下 1 键来显示每个CPU核心的详细使用情况。

使用Ctrl + C键退出top命令

网络配置命令

ifconfig

#        显示当前系统中所有处于激活状态的网络接口信息

ifconfig

#        显示所有网络接口的信息,无论是否激活。

ifconfig -a

#        显示指定网络接口的信息

ifconfig [interface]

#        激活指定网络接口

ifconfig [interface] up

#        关闭指定网络接口

ifconfig [interface] down

#        为指定网络接口设置IP地址和子网掩码,并自动激活;

ifconfig [interface] [ip] netmask [netmask]

#        修改指定网络接口的MAC地址与MTU

ifconfig [interface] hw ether [mac_address] mtu [mtu]

route

#        显示当前路由表

route

或者

ip route show

#       添加一条静态路由

route add -net [ip] netmask [netmask] gw [gw] dev [interface]

#        删除一条静态路由

route del -net [ip] netmask [netmask] gw [gw]

#        添加默认路由

route add default gw [gw] [interface]

添加默认网关时,需要确保所选的网络接口(如ens36或ens33)是活动的,

并且与网关IP地址在同一网络段内。

如果网络接口未正确配置或未连接到网络,则无法添加默认网关(如此处报错Network is  unreachable)。

#        删除默认路由

route del default gw [gw]

#        添加到主机路由

route add -host [ip] gw [gw] 

#        删除到主机路由

route del -host [ip] gw [gw]

路由表参数

Flags解释
U[p]路由已经启动,是一个有效路由
G[ateway]该路由到指定网络需要使用gw转发
H[ost]该路由目标为主机Host
R[einstate]使用动态路由时,恢复路由标识
D[ynamic]该路由是由服务功能设定的动态路由
M[odified]该路由已经被修改
!该路由不被接受
A[ddress]某些上下文中,可能表示该路由是一个广播地址
C[ache]该路由是来自路由缓存

iptables

  是用于配置Linux内核防火墙的工具,具有IP包过滤功能。

基本语法格式
iptables [-t table] [-A|-C|-D chain] [-i interface] [-o interface] [-p protocol] \  
         [-s source_ip/mask] [-d destination_ip/mask] [--sport source_port] \  
         [--dport destination_port] [-j target]

[-t table]:指定要操作的表,省略[-t table]时,默认filter

[-A|-C|-D chain] :

-A        向链添加规则

-C        检查链中是否存在规则(通常用于脚本中的条件检查)

-D        从链中删除规则

[-i interface] :指定数据包进入接口

[-o interface] :指定数据包离开接口

[-p protocol] :  指定协议(TCP、UDP、ICMP等)

 [-s source_ip/mask] :指定源IP和子网掩码

[-d destination_ip/mask] :指定目的IP和子网掩码

[--sport source_port] : 指定源端口
[--dport destination_port] :指定目的端口

[-j target]:匹配规则后的动作(accept,drop,reject,redirect,log等)


图:iptables中数据包处理流程

图:iptables简化处理流程


iptables的基本组件

I、表

内建规则表:nat、mangle和filter。

fiter:

决定数据包处理方式(接受、拒绝或丢弃);

拥有input、forward、output三个规则链。

nat

网络地址转换,进行一对一、一对多、多对多地址转换。

拥有prerouting、postrouting两个规则链。

mangle:

修改数据包头信息

拥有prerouting、forward、postrouting三个规则链。

raw:

用于处理数据包在路由决策之前。

security:

用于SELinux等安全模块的数据包访问控制。

II、链

INPUT:处理进入本机的数据包。

FORWARD:处理经过本机转发的数据包。

OUTPUT:处理从本机发出的数据包。

PREROUTING:用于处理目的地址转换前的数据包。

POSTROUTING:用于处理源地址转换后的数据包。

注意:链的英文必须大写,否则会报错。

III、规则

定义如何处理匹配特定条件的数据包。

可以基于源地址、目的地址、协议类型(TCP、UDP、ICMP)、端口号等条件。


#        允许SSH访问

iptables -A INPUT -p tcp --dport 22 -j ACCEPT

#        打印当前的iptables全部规则和特定的链规则

iptables -L -v -n        全部规则

或者

iptables -L [chain] -v -n        特定的链规则

-L :列出规则

-v:详细模式Verbose,显示更多信息

-n:不进行DNS解析,直接显示IP地址和端口号

如:iptables -L INPUT -v -n

#        拒绝HTTP访问

iptables -A INPUT -p tcp --dport 80 -j DROP

#        转发所有流量到8080端口

iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8080

此处查看时,必须要指定为nat表。

#        删除规则

iptables -t nat -D PREROUTING 1        此处1为规则编号

#        保存和恢复规则

iptables规则在重启后会丢失。

iptables-save > 文件

iptables-restore < 文件

ping

防火墙相关

#        查看防火墙状态

systemctl status firewalld

#        启动防火墙

systemctl start/restart firewalld

#        关闭防火墙,临时停用,重启后失效

systemctl stop firewalld或者systemctl stop firewalld.service

#      永久关闭防火墙

systemctl disable firewalld 或者 systemctl disable firewalld.service

#        开机自启动防火墙

systemctl enable firewalld 或者 systemctl enable firewalld.service  

#        查看防火墙是否开机自启动

systemctl is-enabled firewall

#        firewall-cmd指令


http://www.kler.cn/news/363154.html

相关文章:

  • 内存溢出与内存泄漏详解!
  • 【哈工大_操作系统理论】L282930 生磁盘的使用从生磁盘到文件文件使用磁盘的实现
  • LeetCode练习-删除链表的第n个结节
  • 【C++】动态探索:在C++中实现一个简单的反射系统
  • 网安加·百家讲坛 | 徐一丁:金融机构网络安全合规浅析
  • stable-zero123模型构建指南
  • 前端跨系统请求接口报错
  • Bug:通过反射修改@Autowired注入Bean的字段,明确存在,报错 NoSuchFieldException
  • 可编辑38页PPT | 柔性制造企业数字化转型与智能工厂建设方案
  • 分享一个IDEA里面的Debug调试设置
  • 驾校小程序:一站式学车解决方案的设计与实践
  • 内网穿透
  • 如何使用 pnpm 进行打补丁patch操作?推荐两个方法
  • 【小红书一面】Kafka 是如何选择 Leader的?
  • Unity目录居然这么写就不会被引入到项目内
  • python第五次作业
  • 手机怎么玩GTA5?GameViewer远程助你手机畅玩GTA5侠盗飞车
  • 【RoadRunner】自动驾驶模拟3D场景构建 | 软件简介与视角控制
  • etl-查询错误log日志和oracle删除数据表空间
  • ansible一键部署k8s集群
  • 20241024-帖子发布
  • Ollama
  • git 工作环境恢复到上次提交
  • node.js 的顶级对象
  • spring中的枚举类型转换
  • 人工智能需要学哪些课程?