处理调度与死锁

作者: 天涯的尽头s风沙 | 来源:发表于2019-06-17 20:11 被阅读10次
    • 请谈一谈,系统如何提高并发性?

    考察:操作系统综合性
    参考回答:

    1、提高CPU并发计算能力

    (1)多进程&多线程

    (2)减少进程切换,使用线程,考虑进程绑定CPU

    (3)减少使用不必要的锁,考虑无锁编程

    (4)考虑进程优先级

    (5)关注系统负载

    2、改进I/O模型

    (1)DMA技术

    (2)异步I/O

    (3)改进多路I/O就绪通知策略,epoll

    (4)Sendfile

    (5)内存映射

    (6)直接I/O

    • 请你解释一下,通常系统CPU比较高是什么原因?

    考察点:处理机
    参考回答:

    1、首先查看是哪些进程的CPU占用率最高(如下可以看到详细的路径)

    ps -aux --sort -pcpu | more

    定位有问题的线程可以用如下命令

    ps -mp pid -o THREAD,tid,time | more

    2、查看JAVA进程的每个线程的CPU占用率

    ps -Lp 5798 cu | more # 5798是查出来进程PID

    3、追踪线程,查看负载过高的原因,使用JDK下的一个工具

    jstack 5798 # 5798是PID

    jstack -J-d64 -m 5798 # -j-d64指定64为系统

    jstack 查出来的线程ID是16进制,可以把输出追加到文件,导出用记事本打开,再根据系统中的线程ID去搜索查看该ID的线程运行内容,可以和开发一起排查。

    • 请谈一谈,什么情况下会发生死锁?解决死锁的策略有哪些?

    考察点:死锁
    参考回答:

    (一)互斥条件:一个资源一次只能被一个进程访问。即某个资源在一段时间内只能由一个进程占有,不能同时被两个或两个以上的进程占 有。这种独占资源如CD-ROM驱动器,打印机等等,必须在占有该资源的进程主动释放它之后,其它进程才能占有该资源。这是由资源本身的属性所决定的。

    (二)请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。进程至少已经占有一个资源,但又申请新的资源;由于该资源已被另外进程占有,此时该进程阻塞;但是,它在等待新资源之时,仍继续占用已占有的资源。

    (三)不剥夺条件:进程已经获得的资源,在未使用完之前不能强行剥夺,而只能由该资源的占有者进程自行释放。

    (四)循环等待条件:若干资源形成一种头尾相接的循环等待资源关系。

    解决方法:银行家算法

    相关文章

      网友评论

        本文标题:处理调度与死锁

        本文链接:https://www.haomeiwen.com/subject/ygwzfctx.html