死锁是指多个进程(线程)因为长久等待已被其他进程占有的的资源而陷入阻塞的一种状态。当等待的资源一直得不到释放,死锁会一直持续下去。...死锁一旦发生,程序本身是解决不了的,只能依靠外部力量使得程序恢复运行,例如重启,开门狗复位等。 所以内核中设计了内核死锁检测机制,一旦发现死锁进程,就重启OS,快刀斩乱麻解决问题。...之所以使用重启招数,还是在于分布式系统中可以容忍单点崩溃,不能容忍单点进程计算异常,否则进行死锁检测重启OS就得不偿失了。
常见的死锁有如下两种: 递归死锁:中断等延迟操作中使用了锁,和外面的锁构成了递归死锁。 AB-BA死锁:多个锁因处理不当而引发死锁,多个内核路径上的所处理顺序不一致也会导致死锁。...Linux内核提供死锁调试模块Lockdep,跟踪每个锁的自身状态和各个锁之间的依赖关系,经过一系列的验证规则来确保锁之间依赖关系是正确的。 2....首先从死锁描述大概可以知道死锁类型。 然后详细介绍了产生死锁的点,这时就可以大概知道是哪个锁,有哪些地方调用导致了死锁。 接着是详细的发生死锁的backtrace,有助于分析死锁产生时的栈回溯。...>__lock_acquire-----------------------------------------下面的validate_chain在打开CONFIG_PROVE_LOCKING才会进行检查...参考文档 《Linux 死锁检测模块 Lockdep 简介》 内核帮助文档:Documentation/locking/
常见的死锁有如下两种: 递归死锁:中断等延迟操作中使用了锁,和外面的锁构成了递归死锁。 AB-BA死锁:多个锁因处理不当而引发死锁,多个内核路径上的所处理顺序不一致也会导致死锁。...Linux内核提供死锁调试模块Lockdep,跟踪每个锁的自身状态和各个锁之间的依赖关系,经过一系列的验证规则来确保锁之间依赖关系是正确的。 2....首先从死锁描述大概可以知道死锁类型。 然后详细介绍了产生死锁的点,这时就可以大概知道是哪个锁,有哪些地方调用导致了死锁。 接着是详细的发生死锁的backtrace,有助于分析死锁产生时的栈回溯。...首先是死锁类型介绍。 然后是产生死锁的两个点的调用者,再详细给出了两个点的栈回溯。 最后是死锁点的详细栈回溯。...>__lock_acquire-----------------------------------------下面的validate_chain在打开CONFIG_PROVE_LOCKING才会进行检查
一、背景 对登录一个系统,快速查看其系统信息,检查系统各项指标及参数,编写系统快速检查脚本,输出系统信息到脚本运行的logs目录下。 二、脚本 git地址 #!...size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=] 检查的信息如下...330 512K 1% /boot ------------------------------------------------- 系统信息: 系统: GNU/Linux...发行版本: CentOS Linux release 7.3.1611 (Core) 系统内核: 3.10.0-514.el7
The OS version of a Linux distribution can be determined by using the command-line interface as well...Command Example uname -a $uname -a Linux ip-10-0-0-224 5.4.0-1045-aws#47-Ubuntu SMP Tue Apr 13 07:02...:25 UTC2021 x86_64 x86_64 x86_64 GNU/Linux more /proc/version $ more /proc/version Linux version 5.4.0...ID: UbuntuDescription: Ubuntu 20.04.2 LTSRelease: 20.04Codename: focal how to check os version in Linux
# Windows 检查端口 telnet ip port # Linux telnet 检查端口 telnet ip port ## 若报命令不存在时安装 sudo yum install telnet...# Linux crul 检查端口 curl localhost:port ## 成功是网页代码 ## 端口通但服务没启动 curl: (7) Failed connect to localhost...:port; Connection refused ## 失败卡住 # Linux ssh 检查端口 ssh -v -p port root@localhost ## 成功返回的是网页代码(一堆debug
如果你的Linux服务器突然负载暴增,告警短信快发爆你的手机,如何在最短时间内找出Linux性能问题所在?...dig 域名 查看域名解析地址 dmesg 查看系统内核日志 磁盘瓶颈 iostat -x -k -d 1 详细列出磁盘的读写情况 当看到I/O等待时间所占CPU时间的比重很高的时候,首先要检查的就是机器是否正在大量使用交换空间...wc -l 查看特定进程的数量 cat ***.log | grep ***Exception | wc -l 统计日志文件中包含特定异常数量 jstack -l pid 用于查看线程是否存在死锁
死锁 概念 指一组进程中的各个进程均占有不会释放的资源, 但因互相申请被其他进程所占用不会释放的资源而处于的一种永久等待的状态 ---- 有两个小朋友,张三和李四,共同去了一家商店,想要向老板 购买一块价值...老板 为操作系统 想要访问临界资源,必须同时拥有两把锁 ---- 两个线程各自持有自己的锁,并向对方申请锁,从而导致互相申请锁不成功,进而导致双执行流互相被挂起 访问临界资源的临界区代码,无法得以推进 死锁的必要条件...不剥夺: 一个执行流已获得的资源,在未使用完之前,不能强行剥夺 假设张三的块头比李四大,若李四不给属于他自己的5毛钱,张三就要揍李四,把李四的5毛钱枪过来 就不会有死锁问题了,所以要求不能打人抢钱 如何避免死锁...核心思想:破坏死锁的4个必要条件的任意一个 ---- 1. 不加锁 ---- 2....控制线程统一释放锁 将所有线程 申请的锁 使用一个线程 全部释放掉,就不会出现死锁了 证明 一个线程申请一把锁,可以由另一个线程释放 设置一个全局锁mutex,再自定义函数中由于两次申请锁,所以在第二次申请锁时
我个人原来一直没有看过Linux的死锁跟踪机制,为了看懂这个问题,我先速成一下,整理一下笔记。内核代码基于5.2-rc3。...查了一下git历史,这个死锁跟踪功能最初是Ingo Molnar 2006年引入的。网上有人说第一个版本就解决掉了大部分Linux内核的死锁问题。...Linux内核的lockdep-design.txt对这个东西有介绍,但我觉得文档写得很烂,前后矛盾,语焉不详,还不如直接看代码。不过这个代码也很不规整,基本上都是细节,我也耗不起这个时间。...为了增加检测的机会,在部分和锁有关的代码中,还会主动插入might_lock增加检查,这个本质是主动把lock_acquire和lock_release调一次,就是为了检查而做的。...,导致死锁)。
检查该设备是否已经打开SMART技术。 2、smartctl -H :查看硬盘的健康状况。一般看不出来问题,没啥用。...7、smartctl -i :显示设备的身份信息,检查硬盘是否打开了SMART支持。 看到有:SMART support is: Enabled,说明硬盘支持SMART。...处理过程 首先通过smartctl -H /dev/sda检查磁盘健康状态,然后smartctl -a /dev/sda查看磁盘详细情况,再对磁盘进行短期测试smartctl -t short /dev.../sda,最后查看磁盘测试结果smartctl -l selftest /dev/sda,基本磁盘健康状态就可以定位出来,最后检查磁盘错误日志smartctl -l error /dev/sdb 查看测试结果...(ps:流言说某个linux系统——不点名,在使用电池时候,会不断强制磁头归为,而磁头归位次数最大值约为600k次,所以认为linux会损坏硬盘,实际上不是这样的); reallocetion event
PASS_MIN_DAYS 参数设置为7-14之间,建议为7: PASS_MIN_DAYS 7 需同时执行命令为root用户设置: chage --mindays 7 root 操作时建议做好记录或备份 密码复杂度检查...| 身份鉴别 描述 检查密码长度和密码是否使用多种字符类型 加固建议 编辑/etc/security/pwquality.conf,把minlen(密码最小长度)设置为9-32位,把minclass...如: minlen=10 minclass=3 操作时建议做好记录或备份 检查密码重用是否受限制 | 身份鉴别 描述 强制用户不重用最近使用的密码,降低密码猜测攻击风险 加固建议 在/etc/pam.d...操作时建议做好记录或备份 检查系统空密码账户 | 身份鉴别 描述 检查系统空密码账户 加固建议 为用户设置一个非空密码,或者执行passwd -l 锁定用户 操作时建议做好记录或备份
通过检查是否支持旋转判断 cat /sys/block/dm-0/queue/rotational 如果返回0表示是SSD硬盘,如果是1表示HDD硬盘 b....通过lsblk 命令查找,该命令位于util-linux包 [root@k8s-uat-test-node01 ~]# lsblk -o NAME,MOUNTPOINT,MODEL,ROTA NAME
只能通过网络或则cdrom中的rpm数据库来比较 如:rpm -Vvp ftp://mirror.site/dir/RedHat/RPMS/fileutils-3.16-10.i386.rpm 以下常用命令需要检查...ifconfig /usr/sbin/syslogd /usr/sbin/inetd /usr/sbin/tcpd /usr/bin/killall /sbin/pidof /usr/bin/find 8 如果检查的是已经确认被黑客攻击的机器...上面有静态编译好的程序ls ps netstat等常用工具 3.用nc把执行步骤输出到远程机器上 9 用md5sum保存一个全局的文件 find /sbin -type f|xargs md5sum >1st 检查是否改变....2 => /lib/ld-linux.so.2 (0x40000000) strace工具是一个调试工具,它可以显示出一个程序在执行过程中的所有系统调用, [root@rh9bk root]# strace.../dev/sda of=/dev/sdb bs=1024 分区复制 测试过 dd if=/dev/sda1 of=/abc bs=1024 这里是保存在了根分区,用mount查看是sda2 启动另一个linux
在Linux上,有多种方法可以检查MAC地址。...下面列出了三种常用的方法:使用ifconfig命令:打开终端,输入以下命令来检查网络接口的MAC地址:ifconfig 将替换为你想要检查...使用ip命令:打开终端,输入以下命令来检查网络接口的MAC地址:ip link show 将替换为你想要检查MAC地址的网络接口名称,如eth0...这些方法提供了在Linux上检查MAC地址的不同方式。你可以根据个人偏好和具体需求选择使用哪种方法。参考信息:3 Ways to Find MAC Address In Linux
这篇文章主要是记录自己做的一些小的测试.主要包括内存溢出,栈溢出,以及死锁问题. PS:文章中使用了Arthas工具,用来动态监控JVM的一些资源,非常好用,强烈安利一下....StackOverFlowTest().fun(10); } public int fun(int n) { return fun(n); } } 所以当发生StackOverFlow的时候,记得检查一下递归调用的结束条件...死锁 死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。...此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。 造成死锁的条件有四个: 互斥条件:指进程对所分配到的资源进行排它性使用,即在一段时间内某资源只由一个进程占用。...环路等待条件:指在发生死锁时,必然存在一个进程——资源的环形链,即进程集合{P0,P1,P2,···,Pn}中的P0正在等待一个P1占用的资源;P1正在等待P2占用的资源,……,Pn正在等待已被P0占用的资源
死锁是一种非常棘手的问题,因为它会导致系统无法正常运行。 举个例子。比如买东西,如果商家要先拿钱才给东西,顾客要先拿到东西才给钱,那么会发生死锁。 另外,哲学家就餐问题是一个死锁的经典例子。...2.死锁的条件 死锁需要满足四个必要条件: 互斥(mutual exclusion):资源只能同时分配给一个进程,不能共享。...死锁只有在四个条件同时满足时发生,预防死锁必须至少破坏其中一项。 3.如何避免死锁? 只要破坏死锁的四个必要条件的任意一个,便可避免死锁。 破坏互斥条件:允许多个进程共享某些资源,从而避免互斥条件。...判断资源分配是否安全流程如下: 小结 银行家算法是一种有效的避免死锁的资源分配策略,通过模拟资源分配的情况,前置检查系统是否处于安全状态来避免死锁。...如果你想排查你的 Java 程序是否死锁,则可以使用 jstack 工具,它是 JDK 自带的线程堆栈分析工具。 在 Linux 下,我们可以使用 pstack + gdb 工具来定位死锁问题。
什么是死锁 简单的说:线程1持有A锁,线程2持有B锁;线程1尝试获取B锁,线程2尝试获取A锁。两个线程各持有了一把锁,同时想获取对方的锁,自身的又不释放。...死锁 如何定位 先写一个死锁的程序 public class DeadLock extends Thread { private String first; private String...ScheduledThreadPoolExecutor scheduled = new ScheduledThreadPoolExecutor(1); //等待10s,每10s检查一次...所以当写程序的时候如何避免死锁显得重要的多。...从代码程序上 不要出现多个锁 设置锁的过期时间 工具上 使用静态代码扫描,例如“FindBugs” 其他方式 写之前把使用锁的逻辑画出流程图 类加载过程中发生的死锁 最后 自旋锁发生死锁如何排查,程序中经常遇到的
这种状况就是死锁(deadlock)。
什么是死锁: 是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。...此时称系统处于死锁状态或系统产生了死锁 死锁产生的四个条件 (1) 互斥条件:一个资源每次只能被一个进程使用。
死锁 在进程同步的时候,我们已经发现了死锁存在。有两个信号量S和Q。...在资源分配图中如果没有环,那么系统就一定不是死锁状态;如果有环,那么系统可能处于死锁状态,也可能不是死锁。 死锁处理的方法 从原理上来讲,死锁有三种方法可以来处理它。...分别是死锁避免,死锁检测和恢复,死锁忽略。 死锁忽略 OS不能保证死锁不会发生,并且也不提供死锁避免和死锁检测。那么就是说,当死锁发生的时候,操作系统是不知道的。...当系统既不采用死锁预防,也不采用死锁避免。因此就有了死锁检测。用来检查系统是否出现了死锁。一个用来从死锁状态恢复。...这个方法的开销比较大,每次终止一个进程之后,都需要调用一次死锁检查算法。终止进程的时候,需要去选择终止哪一个,这并不是一个简单地问题。许多因素影响着应该选择哪个进程去终止它。
领取专属 10元无门槛券
手把手带您无忧上云