linux基础命令

一、网络命令

1.ping 指定 ip

查看指定ip的延迟丢包率

18 packets transmitted, 18 received, 0% packet loss, time 34038ms:

18 packets transmitted:发送了18个数据包。
18 received:收到了18个回复数据包。
0% packet loss:丢包率为0%,表示所有发送的数据包都成功到达目的地。
time 34038ms:ping命令的运行时间为34038毫秒(34.038秒)。
rtt min/avg/max/mdev = 20.110/37.124/101.995/18.191 ms:

rtt:表示往返时间(Round-Trip Time),即从发送数据包到接收回复数据包所花费的时间。
min/avg/max/mdev:分别表示最小、平均、最大和平均偏差的往返时间。
min:最小往返时间,即最短延迟时间。
avg:平均往返时间,即所有往返时间的平均值。
max:最大往返时间,即最长延迟时间。
mdev:平均偏差,表示往返时间的变化或波动情况

丢包的原因,以及如何处理?

原因:

  1. 网络拥塞:过度的流量导致路由器或网络设备无法处理数据包,从而导致丢包
  2. 网络故障:设备出现的问题
  3. 防火墙或者网络策略:过滤某些特定的数据,导致丢包
  4. 无线信号干扰

处理:

  1. 检查网络连接:设备和线缆连接良好,有没有松
  2. 减少网络负载:
  3. 优化网络配置:例如防火墙设置、更新路由器固件或调整网络参数
  4. 更换网络设备、避免无线干扰、联系网络服务提供商

2.telnet 指定端口是否能访问

主要作用

  1. 远程登录和管理设备
  2. 测试网络服务是否可达:判断该端口是否开放并且服务是否可用
  3. 检查端口连接是否正常:确定端口是否收到防火墙或其他网络设备的阻止
  4. 测试网络协议是否可用

这里在云上的时候要经常用


3.traceroute 检查指定ip经过的路由

4.curl 访问页面获取返回值

这里获取网页内容,只能获取静态的,无法 获取动态内容和访问量统计数据

成功访问:网络连接正常、DNS解析正常、目标服务器正常运行、HTTP通信正常

5.tcpdump 抓网络包到本地

待实验

6.ss 查看本地网络连接情况

ss -ntlp (t:显示tcp连接 u:显示udp连接 -l:显示监听中的连接 -p:显示京城与套接字关联信息 -s:显示统计信息)

二、系统信息查看

1.查看系统版本

2.查看内核版本

3.10.0-1160.el7.x86_64:
3.10.0:内核版本号,表示Linux内核的主版本号。
-1160.el7:内核版本的补丁号,以及操作系统的版本号。
1160 是内核的补丁版本号,表示这是第 1160 个补丁。
el7 表示这是基于 Red Hat Enterprise Linux (RHEL) 7 的内核版本。
x86_64:表示系统架构,这里是 64 位的 x86 架构

3.查看cpu信息参数、型号、核数

4.查看cpu使用率

top命令

5.查看内存详细情况

free -h

6.查看内存使用率

top

7.查看硬盘分区信息

fdisk -l

这会列出系统中所有磁盘的分区信息,包括磁盘的名称、分区表类型、分区大小、起始和结束扇区等

8.查看硬盘使用率

df -h

9.查看所有进程

ps aux

10.实时查看硬盘和网络使用情况

iotop 是一个用于监视磁盘 I/O 活动的命令。它可以实时显示磁盘 I/O 活动情况,包括读取和写入的速度、哪些进程在进行磁盘 I/O 操作等

iftop 是一个用于监视网络流量的命令。它可以实时显示系统中的网络流量情况,包括各个网络连接的带宽使用情况、来源和目的 IP 地址、端口号等。通过

三、面试题

Java应用无响应、内存飙升、CPU飙升排查-CSDN博客

CPU 100%排查及常见案例_cpu飙升到100%如何排查-CSDN博客

Java线上服务CPU、内存飙升问题排查步骤!_java cpu过高排查-CSDN博客

1.CPU飙升:导致系统响应缓慢

原因:死循环、递归  正则  线程数增多  死锁 (病毒或恶意软件)

解决办法: top定位消耗cpu最高的进程

  1. top -c 找到消耗CPU最高进程的pid,如果java有多个服务,通过ps -aux | grep java命令来找到对应服务的进程号pid
  2. 使用top -H -n 1 -p PID(-H:查看线程 -n 1显示一次退出) 通过该命令查找对应进程下线程的状态,看那个线程cpu高
  3. 在使用jstack(jstack 可以显示每个线程当前的状态、正在执行的方法以及线程之间的关系,从而帮助开发人员找出应用程序中的问题所在),将pid输出成进程的线程文件,然后分析(可能是开发人员代码的问题)

2.内存飙升

  • 内存泄漏(memory leak):是指程序在申请内存后,无法释放已申请的内存空间,堆积导致内存溢出。
  • 内存溢出 (out of memory):是指程序申请内存时,没有足够的内存供申请者使用,导致数据无法正常存储到内存中

原因

  1. 应用占用总内存(redis、kafka):使用top命令排查
  2. 启动参数内存值设定的过小:-Xms -Xmx
  3. 内存中加载的数据量过大(数据缓存、PDF字体缓存、文件传输):代码走查,观察内存波动
  4. 代码中存在四魂环或循环过多产生过多重复的对象实体:代码走查
  5. list、MAP登记和中对对象的引用,使用完未清空,使得JVM不能回收:代码走查,观察内存波动

解决:

  1. top命令查看cpu和内存的情况,找到对应的进程号PID
  2. jmap、jcmd分析内存的使用情况(专业工具分析)

JVM的理解

当我们编写 Java 代码时,我们实际上是在为一种称为 JVM(Java 虚拟机)的特殊程序编写指令。这个 JVM 就像是一个模拟器,可以在你的计算机上运行 Java 程序。

想象一下,你的 Java 代码就像是一本书,而 JVM 就像是一台阅读器,负责将书中的内容翻译成计算机可以理解的语言。这样,无论你用哪种操作系统(比如 Windows、Mac 或 Linux),JVM 都会将你的 Java 代码翻译成相应的机器语言,使得你的程序能够在不同的设备和系统上运行。

JVM 还会处理一些其他任务,比如管理内存、确保程序的安全性,以及协调多个任务(线程)之间的工作。这样,你就可以专注于编写 Java 代码,而不用担心程序在不同环境下的运行问题。

 jvm是为java项目设计和优化的,运维工程师可能接触到软件需要jvm调优的有:

apacha、tomcat、 es 、kafka 、jenkins 、容器化平台中的java应用

  • 19
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值