zoukankan      html  css  js  c++  java
  • 关于进程和线程

    什么是进程。最直观的就是一个个 pid, 官方的说法就:进程是程序在计算机上的一次执行活动。线程是可执行代码的可分派单元。这个名称来源于 “ 执行的线索 ” 的概念。在基于线程的多任务的环境中,所有进程有至少一个线程,但是它们可以具有多个任务。这意味着单个程序可以并发执行两个或者多个任务。
     
    1.概念
    进程:正在运行中的程序。
    线程:进程中的一条执行路径。
     
    2.区别
    (1)通常在一个进程中可以包含若干个线程,它们可以利用进程所拥有的资源。在引入线程的操作系统中,通常都是把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度的基本单位。
    (2)线程和进程的区别在于,子进程和父进程有不同的代码和数据空间,而多个线程则共享数据空间,每个线程有自己的执行堆栈和程序计数器为其执行上下文。多线程主要是为了节约CPU时间,发挥利用,根据具体情况而定。线程的运行中需要使用计算机的内存资源和CPU。
    (3)进程间相互独立,同一进程的各线程间共享。某进程内的线程在其它进程不可见。
    (4)线程的上下文切换远大于进程间上下文切换的速度。
    (5)进程是不可执行的实体,程序是一个没有生命的实体,只有当处理器赋予程序生命时,它才能成为一个活动的实体,我们称其为进程。
     
    3.线程和进程的关系以及区别?
    进程和线程的关系:
    (1)一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
    (2)资源分配给进程,同一进程的所有线程共享该进程的所有资源。
    (3)处理机分给线程,即真正在处理机上运行的是线程。
    (4)线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。线程是指进程内的一个执行单元,也是进程内的可调度实体.
    进程与线程的区别:
    (1)调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位
    (2)并发性:不仅进程之间可以并发执行,同一个进程的多个线程之间也可并发执行
    (3)拥有资源:进程是拥有资源的一个独立单位,线程不拥有系统资源,但可以访问隶属于进程的资源.
    (4)系统开销:在创建或撤消进程时,由于系统都要为之分配和回收资源,导致系统的开销明显大于创建或撤消线程时的开销。 
     

    【QPS】
    QPS(Query Per Second),QPS 其实是衡量吞吐量(Throughput)的一个常用指标,就是说服务器在一秒的时间内处理了多少个请求 —— 我们通常是指 HTTP请求,显然数字越大代表服务器的负荷越高、处理能力越强。并发用户数 是指系统可以同时承载的正常使用系统功能的用户的数量。

    【服务器负载过高的解决方案】
    top命令查询服务器负载达到2.0-5之间,nginx的cpu使用率达到104%
    问题分析过程:
    (1)df -h 命令,查看磁盘是否是否超出正常范围
    (2)free 命令,查看内存使用率是否超出正常范围
    问题引出:如何确定nginx的100%的cpu使用率到底问题在哪?
    ps -ef | grep nginx 查询出nginx的进程PID(eg:8209)
    ps -aux | grep nginx 查询出该进程是哪个用户启动的(即使ROOT用户可能也导出线程快照失败)
    su root 切换到进程启动用户

  • 相关阅读:
    Git Bash主题配置
    vuex里mapState,mapGetters使用详解
    Vue基础汇总实践
    Chrome for Mac键盘快捷键!来自Google Chrome官网!
    Vue中ESlint配置文件.eslintrc文件
    axios的get,post方法
    正则表达式识别标记——包括它之间的标记
    关于如何在微信里面让video不全屏播放
    javascript执行机制
    防止表单多次提交方法之二
  • 原文地址:https://www.cnblogs.com/rxbook/p/10697359.html
Copyright © 2011-2022 走看看