关于进程和线程

什么是进程。最直观的就是一个个 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 切换到进程启动用户

原文地址:https://www.cnblogs.com/rxbook/p/10697359.html