今天压测活动相关页面,遇到一个问题:
400个VU,设置按线程运行出现多个报错,设置为按进程运行所有运行成功,没有报错。因此好奇他二者的区别,如今大体了解了~~~多线程
进程和线程的区别是什么?
简而言之,一个程序至少有一个进程,一个进程至少有一个线程. 线程的划分尺度小于进程,使得多线程程序的并发性高。另外,进程在执行过程当中拥有独立的内存单元,而多个线程共享内存,从而极大地提升了程序的运行效率。并发
线程在执行过程当中与进程仍是有区别的。每一个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。可是线程不可以独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。ide
从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分能够同时执行。但操做系统并无将多个线程看作多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。测试
进程方式和线程方式的优缺点:操作系统
选择按照进程方式运行, 每一个用户都将启动一个mmdrv进程,多个mmdrv进程会占用大量内存及其余系统资源,这就限制了能够在任一负载生成器上运行的并发用户数的数量,由于负载机的资源(内存及其余系统资源)是有限的。线程
选择按照线程方式运行,在默认状况下,controller为每50个用户仅启动一个mmdrv进程,而每一个用户都按线程方式来运行,这些线程用户将共享父进程的内存段,这就节省了大量内存空间,从而能够在一个负载生成器上运行更多的用户。blog
选择线程方式虽然能够减小启动的mmdrv进程数,减小了内存的占用,可是也容易出现一个问题,例如,同一个测试场景,用线程并发就会出现超时失败或报错,而用进程并发就没错。为何呢?由于线程的资源是从进程资源中分配出来的,所以同一个进程中的多个线程会有共享的内存空间,假设a线程要用资源就必须等待b线程释放,而b线程也在等待其余资源释放才能继续,这样就会出现这个问题。进程
因此若是在并发时出现报错,可尝试下修改并发用户运行方式。内存
固然,报错也多是其余因素影响,可是你们也能够尝试着根据报错缘由,逐步排查问题呦。资源