mirror of
https://github.com/corda/corda.git
synced 2025-01-01 10:46:46 +00:00
Some clean up. Remote slave via capsule is working.
This commit is contained in:
parent
6b0291d420
commit
ed898778c8
@ -1,10 +1,12 @@
|
|||||||
apply plugin: 'kotlin'
|
apply plugin: 'kotlin'
|
||||||
|
apply plugin: 'us.kirchmeier.capsule'
|
||||||
apply plugin: 'application'
|
apply plugin: 'application'
|
||||||
|
|
||||||
mainClassName = 'net.corda.jmeter.Launcher'
|
mainClassName = 'net.corda.jmeter.Launcher'
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compile project(':client:rpc')
|
compile project(':client:rpc')
|
||||||
|
compile project(":finance")
|
||||||
|
|
||||||
// JMeter
|
// JMeter
|
||||||
ext.jmVersion = "3.3"
|
ext.jmVersion = "3.3"
|
||||||
@ -14,7 +16,7 @@ dependencies {
|
|||||||
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_ftp', version: "$jmVersion"
|
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_ftp', version: "$jmVersion"
|
||||||
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_functions', version: "$jmVersion"
|
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_functions', version: "$jmVersion"
|
||||||
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_http', version: "$jmVersion"
|
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_http', version: "$jmVersion"
|
||||||
compile group: 'org.apache.jmeter', name: 'ApacheJMeter_java', version: "$jmVersion"
|
compile group: 'org.apache.jmeter', name: 'ApacheJMeter_java', version: "$jmVersion" // 'compile' because we extend Java sampler.
|
||||||
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_jdbc', version: "$jmVersion"
|
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_jdbc', version: "$jmVersion"
|
||||||
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_jms', version: "$jmVersion"
|
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_jms', version: "$jmVersion"
|
||||||
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_junit', version: "$jmVersion"
|
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_junit', version: "$jmVersion"
|
||||||
@ -26,37 +28,29 @@ dependencies {
|
|||||||
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_config', version: "$jmVersion"
|
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter_config', version: "$jmVersion"
|
||||||
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter', version: "$jmVersion"
|
runtime group: 'org.apache.jmeter', name: 'ApacheJMeter', version: "$jmVersion"
|
||||||
runtime group: 'org.apache.jmeter', name: 'jorphan', version: "$jmVersion"
|
runtime group: 'org.apache.jmeter', name: 'jorphan', version: "$jmVersion"
|
||||||
|
|
||||||
//compile project(":test-utils")
|
|
||||||
compile project(":finance")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
task(runServer, dependsOn: 'classes', type: JavaExec) {
|
task(runServer, dependsOn: 'classes', type: JavaExec) {
|
||||||
classpath = sourceSets.main.runtimeClasspath
|
classpath = sourceSets.main.runtimeClasspath
|
||||||
main = 'net.corda.jmeter.Launcher'
|
main = 'net.corda.jmeter.Launcher'
|
||||||
systemProperty "search_paths", project(':tools:jmeter').configurations.runtime.files.join(";")
|
systemProperty "search_paths", project(':tools:jmeter').configurations.runtime.files.join(";")
|
||||||
systemProperty "java.rmi.server.hostname", InetAddress.getLocalHost().getHostName()
|
systemProperty "java.rmi.server.hostname", "0.0.0.0"
|
||||||
//jvmArgs += "-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=5005"
|
systemProperty "jmeter.home", sourceSets.main.resources.getSrcDirs().first().getPath()
|
||||||
|
// If you want to debug: jvmArgs += "-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=5005"
|
||||||
args+= [ "-p", sourceSets.main.resources.getSrcDirs().first().getPath()+"/jmeter.properties",
|
args+= [ "-p", sourceSets.main.resources.getSrcDirs().first().getPath()+"/jmeter.properties",
|
||||||
"-d", sourceSets.main.resources.getSrcDirs().first().getPath(),
|
"-d", sourceSets.main.resources.getSrcDirs().first().getPath(),
|
||||||
"-j", buildDir.getPath()+"/jmeter.log",
|
|
||||||
"-s" ]
|
"-s" ]
|
||||||
}
|
}
|
||||||
|
|
||||||
run {
|
run {
|
||||||
systemProperty "search_paths", project(':tools:jmeter').configurations.runtime.files.join(";")
|
systemProperty "search_paths", project(':tools:jmeter').configurations.runtime.files.join(";")
|
||||||
//jvmArgs += "-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=5005"
|
systemProperty "jmeter.home", sourceSets.main.resources.getSrcDirs().first().getPath()
|
||||||
|
// If you want to debug: jvmArgs += "-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=5005"
|
||||||
args+= [ "-p", sourceSets.main.resources.getSrcDirs().first().getPath()+"/jmeter.properties",
|
args+= [ "-p", sourceSets.main.resources.getSrcDirs().first().getPath()+"/jmeter.properties",
|
||||||
"-d", sourceSets.main.resources.getSrcDirs().first().getPath(),
|
"-d", sourceSets.main.resources.getSrcDirs().first().getPath() ]
|
||||||
"-j", buildDir.getPath()+"/jmeter.log" ]
|
|
||||||
}
|
}
|
||||||
|
|
||||||
jar {
|
jar {
|
||||||
from(configurations.runtime.collect { it.isDirectory() ? it : zipTree(it) }) {
|
|
||||||
exclude "META-INF/*.SF"
|
|
||||||
exclude "META-INF/*.DSA"
|
|
||||||
exclude "META-INF/*.RSA"
|
|
||||||
}
|
|
||||||
manifest {
|
manifest {
|
||||||
attributes(
|
attributes(
|
||||||
'Automatic-Module-Name': 'net.corda.tools.jmeter',
|
'Automatic-Module-Name': 'net.corda.tools.jmeter',
|
||||||
@ -65,3 +59,27 @@ jar {
|
|||||||
}
|
}
|
||||||
zip64 = true
|
zip64 = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For building a runnable jar with no other dependencies for remote JMeter slave server, that has Corda code on classpath.
|
||||||
|
// Run with: java -jar corda-jmeter-<version>.jar
|
||||||
|
// No additional args required but will be passed if specified.
|
||||||
|
task buildJMeterJAR(type: FatCapsule, dependsOn: 'jar') {
|
||||||
|
applicationClass 'net.corda.jmeter.Launcher'
|
||||||
|
archiveName "corda-jmeter-${corda_release_version}.jar"
|
||||||
|
applicationSource = files(
|
||||||
|
project(':tools:jmeter').jar
|
||||||
|
)
|
||||||
|
from 'NOTICE' // Copy CDDL notice
|
||||||
|
from { "$rootDir/tools/jmeter/build/resources/main/jmeter.properties" }
|
||||||
|
from { "$rootDir/tools/jmeter/build/resources/main/log4j2.xml" }
|
||||||
|
|
||||||
|
capsuleManifest {
|
||||||
|
applicationVersion = corda_release_version
|
||||||
|
systemProperties['java.rmi.server.hostname'] = '0.0.0.0'
|
||||||
|
minJavaVersion = '1.8.0'
|
||||||
|
minUpdateVersion['1.8'] = java8_minUpdateVersion
|
||||||
|
|
||||||
|
// JVM configuration. Can be overridden on java command line.
|
||||||
|
jvmArgs = ['-Xms512m', '-Xmx512m', '-XX:+UseG1GC']
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1,13 +1,23 @@
|
|||||||
package net.corda.jmeter
|
package net.corda.jmeter
|
||||||
|
|
||||||
import org.apache.jmeter.JMeter
|
import org.apache.jmeter.JMeter
|
||||||
|
import org.slf4j.LoggerFactory
|
||||||
|
|
||||||
class Launcher {
|
class Launcher {
|
||||||
companion object {
|
companion object {
|
||||||
@JvmStatic
|
@JvmStatic
|
||||||
fun main(args: Array<String>) {
|
fun main(args: Array<String>) {
|
||||||
|
val logger = LoggerFactory.getLogger(this::class.java)
|
||||||
val jmeter = JMeter()
|
val jmeter = JMeter()
|
||||||
|
val capsuleDir = System.getProperty("capsule.dir")
|
||||||
|
if (capsuleDir != null) {
|
||||||
|
// We are running under Capsule, so assume we want a JMeter distributed server to be controlled from
|
||||||
|
// elsewhere.
|
||||||
|
logger.info("Starting JMeter in server mode from $capsuleDir")
|
||||||
|
jmeter.start(arrayOf("-s", "-d", capsuleDir, "-p", "$capsuleDir/jmeter.properties") + args)
|
||||||
|
} else {
|
||||||
jmeter.start(args)
|
jmeter.start(args)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
@ -238,7 +238,7 @@ gui.quick_9=ViewResultsFullVisualizer
|
|||||||
#---------------------------------------------------------------------------
|
#---------------------------------------------------------------------------
|
||||||
|
|
||||||
# Remote Hosts - comma delimited
|
# Remote Hosts - comma delimited
|
||||||
remote_hosts=127.0.0.1
|
remote_hosts=Rick-Parker.local
|
||||||
#remote_hosts=localhost:1099,localhost:2010
|
#remote_hosts=localhost:1099,localhost:2010
|
||||||
|
|
||||||
# RMI port to be used by the server (must start rmiregistry with same port)
|
# RMI port to be used by the server (must start rmiregistry with same port)
|
||||||
|
1
tools/jmeter/src/main/resources/lib/ext/readme.txt
Normal file
1
tools/jmeter/src/main/resources/lib/ext/readme.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
This directory is expected by JMeter
|
1
tools/jmeter/src/main/resources/lib/junit/readme.txt
Normal file
1
tools/jmeter/src/main/resources/lib/junit/readme.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
This directory is expected by JMeter
|
21
tools/jmeter/src/main/resources/log4j2.xml
Normal file
21
tools/jmeter/src/main/resources/log4j2.xml
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<Configuration status="info">
|
||||||
|
<Properties>
|
||||||
|
<Property name="defaultLogLevel">info</Property>
|
||||||
|
</Properties>
|
||||||
|
|
||||||
|
<ThresholdFilter level="trace"/>
|
||||||
|
|
||||||
|
<Appenders>
|
||||||
|
<Console name="Console-Appender" target="SYSTEM_OUT">
|
||||||
|
<PatternLayout
|
||||||
|
pattern="%highlight{%level{length=1} %date{HH:mm:ssZ} [%t] %c{2}.%method - %msg%n}{INFO=white,WARN=red,FATAL=bright red}"/>
|
||||||
|
</Console>
|
||||||
|
</Appenders>
|
||||||
|
|
||||||
|
<Loggers>
|
||||||
|
<Root level="${sys:defaultLogLevel}">
|
||||||
|
<AppenderRef ref="Console-Appender" level="${sys:defaultLogLevel}"/>
|
||||||
|
</Root>
|
||||||
|
</Loggers>
|
||||||
|
</Configuration>
|
Loading…
Reference in New Issue
Block a user