一、概述

    1.TPS(Transacitions Per Sencond):代表每秒内服务器平均能响应的请求总量。TPS值与并发能力有非常密切的关系

    2.QPS(Query Per Sencond) :服务器每秒处理的平均请求总量。

二、Java内存模型

   1.主内存和工作内存

       Java内存模型规定所有的变量都存储在主内存中。每个线程还有自己的工作内存,线程的工作内存中保存了该线程使用到的

变量的主内存副本拷贝,线程对变量的所有操作都必须在工作内存中进行,不能直接读写主内存的变量。不同线程之间也无法直接访问对方工作内存的变量,线程间变量值的传递需要通过主内存来完成。如图:

java tps很低_内存模型

    Java内存模型也规定了8种操作来完成主内存和工作内存之间具体的交互协议,即一个变量如何从主内存拷贝到工作内存中,又如何从工作内存中同步到主内存中:

    lock(锁定):作用于主内存的变量,可以将一个变量标记为一个线程独占的状态,其他线程无法对这个变量进行写操作。

    unlock(解锁):作用于主内存的变量,将处于锁定状态的变量释放出来,释放后的变量才可以被其他线程lock。

    read(读取):作用去主内存的变量,把一个变量从主内存传输到工作内存中,以便于load动作使用。

    load(载入):作用于主内存的变量,将read的变量放入工作内存的变量副本中。

    use(使用):作用于工作内存的变量,把工作内存中一个变量传递给执行引擎,每当虚拟机遇到一个需要使用到变量的值的字节码指令时将会执行这个操作。

   assign(赋值):作用于工作内存的变量,将执行引擎的值赋值给工作内存中。

   store(存储) : 作用于工作内存的变量,把工作内存中的一个变量的值传送到主内存中。

   write(写入): 作用于主内存中的变量,把store操作从工作内存中得到的变量的值放入主内存的变量中。

  主内存复制到工作内存时,read和load操作要顺序执行。 工作内存同步到主内存中要顺序执行store和write操作。JMM要求这个两个操作必须按照顺序执行,而没有保证必须是连续执行的。JMM还规定了在执行上述八种基本操作时,必须满足如下规则:

  1.不允许read和load、store和write操作之一单独出现。

  2.不允许一个线程丢弃它的最近assign操作,即变量在工作内存中改变了之后必须把该变化同步到主内存中。

  3.不允许一个线程无原因的把数据从工作内存中同步到主内存中(没有发生过任何assign操作的时候)。

  4.一个新的变量只能在主内存中诞生,不允许在工作内存中直接使用一个未被初始化的变量。(对一个变量实施use和store操作之前,必须先执行assign和load操作)。

 5.一个变量在同一时刻只能允许一个线程对其进行lock操作,lock和unlock必须成对出现。如果变量没有被lock,那么不允许对它执行unlock操作。

6.如果对一个变量进行lock操作,将会清空工作内存中此变量的值,在执行引擎使用这个变量前需要,重新执行load和assign操作初始化变量的值。

7.对一个变量执行unlock操作之前,必须把此变量同步到主内存中。(store和write操作)