Jmeter有个配置元素叫做用户自定义变量(英文名称是UserDefinedVariables)而我们提到的vars即是Variables的简写。
之前我们也说到过Jmeter的脚本中(jsr223sampler或者beanshell编写的脚本)利用varsput和varsget的操作(varsget和put的操作仅在threadgroup测试组线程中实行,以是结果的改变也仅影响该threadGroup,以是不是跨线程组的。须要跨线程组的的变量共享则可以利用prop,vars和props的利用可见vars和props利用比拟1和vars和props利用比拟2)。那“用户自定义变量”和脚本中的vars操作这2个关系是如何的呢?
1)Userdefinedvariables(用户自定义变量)jmeter的处理是非常大略粗暴的,不管该元素位于哪个位置,例如位于threadgroup,还是在threadgroup表面的testplan中,位于threadgroup的实行顺序的最下面还是最上面。jmeter在启动并开始实行脚本之前,实际上对所有的用户配置类元素,全部初始化操作。

例如
TestPlan
  - User defined vars1(定义了var1=test)
  - threadgroup1
    - User defined vars2(定义var2=test2)
  - threadgroup2
则实行时,Userdefinedvars1和Userdefinedvars1都实行了初始化操作。同时threadgroup1和threadgroup2中均可以看到var1和var2.Userdefinedvars(用户自定义变量)初始化后,会将所有的定义变量copy到每一个线程组中,以是每一个线程组都可以看到userdefindvars(用户自定义变量)定义的参数。
2)jmeter脚本中(jsr223sampler或者beanshell编写的脚本)的vars.put操作,例如vars.put(“var1″,”changedvar1″),仅会修正该脚本实行的线程组的变量。
例如
TestPlan
  - User defined vars1(定义了var1=test)
  - threadgroup1
    - User defined vars2(定义var2=test2)
    - vars.put(\"大众var1\"大众,\"大众changedvar1\公众)
    - Debug sampler1
  - threadgroup2
    - Debug sampler2
      - sleep 5秒(等待 threadgroup1 实行完成后,用于确认threadgroup1 中的vars.put 是否对threadgroup2的vars 变量有影响)
则实行后。
threadgroup1 中可见 var1=changedvar1 , var2=test2
threadgroup2 中可见 var1=test,var2=test2
3) 那么我们再来看下user defined vars(用户自定义变量)元素定义的变量var和jmeter 脚本中定义var的差异。
jmeter脚本重定义var 仅在自己所属的线程组有效,不是全局的。而 user defind vars(用户自定义变量)定义的是全局(全局的验证,在2部分已经可以看到)
如
TestPlan
  - User defined vars1(定义了var1=test)
  - threadgroup1
    - vars.put(\公众var1\公众,\公众changedvar1\"大众)
    - vars.put(\"大众var3\"大众,\"大众test3\公众)
    - Debug sampler1
  - threadgroup2
    - Debug sampler2
      - sleep 5秒(等待 threadgroup1 实行完成后,用于确认threadgroup1 中的vars.put 是否对threadgroup2的vars 变量有影响)
则实行后,
threadgroup1 中可见 var1=changedvar1 , var3=test3
threadgroup2 中可见 var1=test
因此我们在利用user defined vars可以统一写在一个地方,便于脚本的梳理。 而脚本中vars.get,vars.put 的处理仅对线程组内有效(包括listener监听器中的vars.get, vars.put)。 这样我们在脚本开拓中就会更清晰和方便定位问题了。