百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

今天推送8个常用Linux命令,日积月累,每天记录,用时即查

nanshan 2024-10-24 11:42 11 浏览 0 评论

Linux模块的安装和卸载

lsmod #显示当前装入的内核模块

modinfo module_name #显示模块信息

modprobe -c #显示模块的配置信息

modprobe --show-depends module_name #显示模块的依赖信息

modprobe module_name #手动加载模块

rmmod module_name #卸载模块

```

[root@test ~]# lsmod

Module Size Used by

dm_mirror 22135 0

dm_region_hash 20862 1 dm_mirror

dm_log 18411 2 dm_region_hash,dm_mirror

dm_mod 104038 2 dm_log,dm_mirror

intel_rapl 18773 0

crct10dif_pclmul 14289 0

crct10dif_common 12595 1 crct10dif_pclmul

crc32_pclmul 13113 0

crc32c_intel 22079 0

```

systemd 读取 /etc/modules-load.d/ 中的配置加载额外的内核模块。配置文件名称通常为 /etc/modulesload.

d/<program>.conf 。如:

cat /etc/modules-load.d/bonding.conf

bonding

使用 /etc/modprobe.d/中的文件来配置传递参数,如:

/etc/modprobe.d/bonding.conf

options bonding mode=1

别名

```

$ cat /etc/modprobe.d/myalias.conf

# Lets you use 'mymod' in MODULES, instead of 'really_long_module_name'

alias mymod really_long_module_name

```

如果模块直接编译进内核, 也可以通过启动管理器(GRUB, LILO 或 Syslinux) 的内核行加入参数:

modname.parametername=parametercontents

column格式化输出

可以让一些命令的输出看起来更舒服些. 例如 blkid , mount , cat /etc/fstab .

[root@test ~]# blkid

[root@test ~]# blkid | column -t

-s 参数指定可以指定分隔符. 默认是空格

Usage:

column [options] [file ...]

Options:

-c, --columns <width> width of output in number of characters

-t, --table create a table

-s, --separator <string> possible table delimiters

-o, --output-separator <string>

table output column separator, default is two spaces

-x, --fillrows fill rows before columns

-h, --help display this help and exit

-V, --version output version information and exit

通过pid查看进程的环境变量信息

使用strings, 可以格式化打印

$ strings /proc/1158/environ

LANG=en_US.UTF-8

PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin

NOTIFY_SOCKET=/run/systemd/notify

SSH_USE_STRONG_RNG=0

通过pid查看进程对应可执行文件的绝对路径

readlink /proc/[pid]/exe

通过pid查看进程的当前工作目录

pwdx [pid]

lsof 一切皆文件

  • -p [PID] 只显示该进程打开的所有文件. 不带参数显示所有已打开的文件

  • -d 对 FD 有效, 用于筛选文件列表. ^txt 显示除txt 其他所有类型的文件. 1 显示所有fd为1的文件. 可以使用 , 逗号

  • 连接多个选择

  • -a 表示两个参数都必须满足 (AND)。如果没有 -a 标志,缺省的情况是显示匹配任何一个参数 (OR) 的文件

  • -n 阻止网络地址转换

  • -P 阻止端口号到端口名的转换

  • -i protocol:@ip:port protocol 包括 tcp 和 udp. 显示符合该地址的文件列表 -u s s为用户名或者用户ID, 选择该用户下的文件

  • lsof [name]

name是 mount point或者文件系统对应的设备文件, 则显示在该文件系统上打开的所有文件列表

name是 文件夹(非mount point), 则显示所有将该文件夹作为正常文件打开的列表. 例如 cwd, rtd. 如果 +d 打印所有

在该目录下已打开的文件,但不递归查找子目录. +D 则允许递归查找

谁在使用 /var/log/messages

[root@test ~]# lsof /var/log/messages

COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME

abrt-watc 712 root 4r REG 202,2 555975 2093357 /var/log/messages

rsyslogd 714 root 3w REG 202,2 555975 2093357 /var/log/messages

显示文件系统 / 下所有已打开的文件列表. 和 fuser / 效果一样

$ lsof /

所有在/var下已打开的文件

```

[root@test ~]# lsof +D /var/log/

COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME

abrt-watc 712 root 4r REG 202,2 555975 2093357 /var/log/messages

rsyslogd 714 root 3w REG 202,2 555975 2093357 /var/log/messages

rsyslogd 714 root 6w REG 202,2 6985172 2094508 /var/log/secure

rsyslogd 714 root 7w REG 202,2 153861 2093173 /var/log/cron

tuned 732 root 3w REG 202,2 7708 2093361 /var/log/tuned/tuned.log

[root@test ~]#

```

列出root这个用户打开的所有文件

lsof -u root

dd 测试磁盘或者文件读写

高危命令, of 一定要指向正确的文件, 不要指 / , /dev/vda , /dev/vda1 等系统重要设备.

该命令要在测试环境验证充分.

if 表示从哪个设备/文件读

of 表示写到哪个设备/文件

bs 表示一次读写多少字节. 也可以使用 1K, 1M这样带单位的

count 表示最多读写多少次. 总的读写量为 bs * count

/dev/zero 可以无限读取 \0

dd if=/dev/zero of=/tmp/abc.txt bs=1M count=10

rpm 安装/更新/卸载软件包

查询系统已安装的所有软件包

rpm -qa

查询某个文件所属的软件包名. 文件必须是绝对路径

rpm -qf /etc/ssh/sshd_config

rpm -qf `which strace`

查询包所含有的文件

rpm -ql strace

查询包里的配置文件

rpm -qc openssh-server

查询软件包里的脚本信息

rpm -q --scripts openssh-server

查询当前包的changelog. 常用于查看已解决的CVE列表

rpm -q --changelog openssh-server

查询包所能提供的CAPABILITY

rpm -q --provides glibc

查询哪些包依赖某个CAPABILITY

rpm -q --whatrequires [CAPABILITY]

查询包所依赖的CAPABILITY

rpm -q -R glibc

查询包所有提供的CAPABILITY

rpm -q --whatprovides [CAPABILITY]

校验当前包与原始状态的差别.

5 – MD5 校验和

S – 文件长度

L – 符号链接

T – 文件修改日期

D – 设备

U – 用户

G – 用户组

M – 模式 (包含许可和文件类型)

? – 不可读文件

如下标志文件的md5, 文件长度, 修改日志有变化

$ rpm -V openssh-server

S.5....T. c /etc/ssh/sshd_config

安装本地包 -vh 获得一个详细的安装进程 --nodeps 忽略依赖关系

rpm -ivh abc.rpm

卸载包

rpm -e abc.rpm

升级包

rpm -Uvh abc.rpm

相关推荐

实战派 | Java项目中玩转Redis6.0客户端缓存

铺垫首先介绍一下今天要使用到的工具Lettuce,它是一个可伸缩线程安全的redis客户端。多个线程可以共享同一个RedisConnection,利用nio框架Netty来高效地管理多个连接。放眼望向...

轻松掌握redis缓存穿透、击穿、雪崩问题解决方案(20230529版)

1、缓存穿透所谓缓存穿透就是非法传输了一个在数据库中不存在的条件,导致查询redis和数据库中都没有,并且有大量的请求进来,就会导致对数据库产生压力,解决这一问题的方法如下:1、使用空缓存解决对查询到...

Redis与本地缓存联手:多级缓存架构的奥秘

多级缓存(如Redis+本地缓存)是一种在系统架构中广泛应用的提高系统性能和响应速度的技术手段,它综合利用了不同类型缓存的优势,以下为你详细介绍:基本概念本地缓存:指的是在应用程序所在的服务器内...

腾讯云国际站:腾讯云服务器如何配置Redis缓存?

本文由【云老大】TG@yunlaoda360撰写一、安装Redis使用包管理器安装(推荐)在CentOS系统中,可以通过yum包管理器安装Redis:sudoyumupdate-...

Spring Boot3 整合 Redis 实现数据缓存,你做对了吗?

你是否在开发互联网大厂后端项目时,遇到过系统响应速度慢的问题?当高并发请求涌入,数据库压力剧增,响应时间拉长,用户体验直线下降。相信不少后端开发同行都被这个问题困扰过。其实,通过在SpringBo...

【Redis】Redis应用问题-缓存穿透缓存击穿、缓存雪崩及解决方案

在我们使用redis时,也会存在一些问题,导致请求直接打到数据库上,导致数据库挂掉。下面我们来说说这些问题及解决方案。1、缓存穿透1.1场景一个请求进来后,先去redis进行查找,redis存在,则...

Spring boot 整合Redis缓存你了解多少

在前一篇里面讲到了Redis缓存击穿、缓存穿透、缓存雪崩这三者区别,接下来我们讲解Springboot整合Redis中的一些知识点:之前遇到过,有的了四五年,甚至更长时间的后端Java开发,并且...

揭秘!Redis 缓存与数据库一致性问题的终极解决方案

在现代软件开发中,Redis作为一款高性能的缓存数据库,被广泛应用于提升系统的响应速度和吞吐量。然而,缓存与数据库之间的数据一致性问题,一直是开发者们面临的一大挑战。本文将深入探讨Redis缓存...

高并发下Spring Cache缓存穿透?我用Caffeine+Redis破局

一、什么是缓存穿透?缓存穿透是指查询一个根本不存在的数据,导致请求直接穿透缓存层到达数据库,可能压垮数据库的现象。在高并发场景下,这尤其危险。典型场景:恶意攻击:故意查询不存在的ID(如负数或超大数值...

Redis缓存三剑客:穿透、雪崩、击穿—手把手教你解决

缓存穿透菜小弟:我先问问什么是缓存穿透?我听说是缓存查不到,直接去查数据库了。表哥:没错。缓存穿透是指查询一个缓存中不存在且数据库中也不存在的数据,导致每次请求都直接访问数据库的行为。这种行为会让缓存...

Redis中缓存穿透问题与解决方法

缓存穿透问题概述在Redis作为缓存使用时,缓存穿透是常见问题。正常查询流程是先从Redis缓存获取数据,若有则直接使用;若没有则去数据库查询,查到后存入缓存。但当请求的数据在缓存和数据库中都...

Redis客户端缓存的几种实现方式

前言:Redis作为当今最流行的内存数据库和缓存系统,被广泛应用于各类应用场景。然而,即使Redis本身性能卓越,在高并发场景下,应用于Redis服务器之间的网络通信仍可能成为性能瓶颈。所以客户端缓存...

Nginx合集-常用功能指导

1)启动、重启以及停止nginx进入sbin目录之后,输入以下命令#启动nginx./nginx#指定配置文件启动nginx./nginx-c/usr/local/nginx/conf/n...

腾讯云国际站:腾讯云怎么提升服务器速度?

本文由【云老大】TG@yunlaoda360撰写升级服务器规格选择更高性能的CPU、内存和带宽,以提供更好的处理能力和网络性能。优化网络配置调整网络接口卡(NIC)驱动,优化TCP/IP参数...

雷霆一击服务器管理员教程

本文转载莱卡云游戏服务器雷霆一击管理员教程(搜索莱卡云面版可搜到)首先你需要给服务器设置管理员密码,默认是空的管理员密码在启动页面进行设置设置完成后你需要重启服务器才可生效加入游戏后,点击键盘左上角E...

取消回复欢迎 发表评论: