[Bug 3408] New: Adverse backend may starve other backends from activation
bugzilla-daemon at icedtea.classpath.org
bugzilla-daemon at icedtea.classpath.org
Tue Jun 27 18:10:46 UTC 2017
http://icedtea.classpath.org/bugzilla/show_bug.cgi?id=3408
Bug ID: 3408
Summary: Adverse backend may starve other backends from
activation
Product: Thermostat.next
Version: unspecified
Hardware: x86_64
OS: Linux
Status: NEW
Severity: enhancement
Priority: P5
Component: Agent
Assignee: unassigned at icedtea.classpath.org
Reporter: sgehwolf at redhat.com
CC: thermostat at icedtea.classpath.org
Created attachment 1633
--> http://icedtea.classpath.org/bugzilla/attachment.cgi?id=1633&action=edit
Adverse backend.
Thermostat agent allows extensions to be written via Backends. If an adverse
developer registers a bad backend, which never returns from Backend.activate()
every Backend which did not register and activate before the "bad" one will
never get a chance to get properly activated by the Thermostat framework.
See the attached reproducer.
Example run of agent with bad backend:
$ ./distribution/target/image/bin/thermostat agent
INFO - Activator: activating thermostat-process bundles
INFO - Agent$1: Adding backend: Backend [name=Host Memory Backend,
version=1.99.12, vendor=Red Hat, Inc., description=Gathers memory statistics
about a host]
INFO - Agent$1: Adding backend: Backend [name=VM Memory Backend,
version=1.99.12, vendor=Red Hat, Inc., description=Gathers memory statistics
about a JVM]
INFO - Agent$1: Adding backend: Backend [name=Commands (cmd-channel) Backend,
version=Thermostat version 1.99.12, vendor=Red Hat Inc.,
description=Establishes web-socket connections to the microservice endpoint so
as to be able to receive command requests]
INFO - Agent$1: Adding backend: Backend [name=Host Overview Backend,
version=1.99.12, vendor=Red Hat, Inc., description=Gathers general information
about a host]
INFO - Agent$1: Adding backend: Backend [name=VM Basic Monitor Backend,
version=0.1, vendor=Red Hat, Inc., description=Monitor the system for JVM
processes]
INFO - Agent$1: Adding backend: Backend [name=VM GC Backend, version=1.99.12,
vendor=Red Hat, Inc., description=Gathers garbage collection statistics about a
JVM]
INFO - Agent$1: Adding backend: Backend [name=Bad backend, version=0.1,
vendor=Adversary, description=Starves other backends]
INFO - AdverseBackend: I'm going to never return. Bye!
WARNING - VmMemoryVmListener: Unable to determine name of generation 2 for VM
d08c6e3f-cfb8-492a-a67f-f0e8e1dafb16
WARNING - VmMemoryVmListener: Further warnings will be ignored
WARNING - VmMemoryVmListener: Unable to determine name of generation 2 for VM
44781903-3d64-4ab4-bdf5-3f28b67ebd32
WARNING - VmMemoryVmListener: Further warnings will be ignored
WARNING - VmMemoryVmListener: Unable to determine name of generation 2 for VM
9f38e015-4fe9-4424-a2f9-f3b7ebb3b42a
WARNING - VmMemoryVmListener: Further warnings will be ignored
In the above case, host-cpu's backend is never activated. Contrast this with a
run without the attached reproducer:
INFO - Activator: activating thermostat-process bundles
INFO - Agent$1: Adding backend: Backend [name=VM GC Backend, version=1.99.12,
vendor=Red Hat, Inc., description=Gathers garbage collection statistics about a
JVM]
INFO - Agent$1: Adding backend: Backend [name=VM Memory Backend,
version=1.99.12, vendor=Red Hat, Inc., description=Gathers memory statistics
about a JVM]
INFO - Agent$1: Adding backend: Backend [name=Commands (cmd-channel) Backend,
version=Thermostat version 1.99.12, vendor=Red Hat Inc.,
description=Establishes web-socket connections to the microservice endpoint so
as to be able to receive command requests]
INFO - Agent$1: Adding backend: Backend [name=Host Overview Backend,
version=1.99.12, vendor=Red Hat, Inc., description=Gathers general information
about a host]
INFO - Agent$1: Adding backend: Backend [name=Host Memory Backend,
version=1.99.12, vendor=Red Hat, Inc., description=Gathers memory statistics
about a host]
INFO - Agent$1: Adding backend: Backend [name=VM Basic Monitor Backend,
version=0.1, vendor=Red Hat, Inc., description=Monitor the system for JVM
processes]
INFO - Agent$1: Adding backend: Backend [name=Host CPU Backend,
version=1.99.12, vendor=Red Hat, Inc., description=Gathers CPU statistics about
a host]
INFO - Agent$1: Adding backend: Backend [name=System Backend, version=1.99.12,
vendor=Red Hat, Inc., description=Gathers basic information from the system]
INFO - AgentApplication: Agent id: 123f5078-4afb-4047-be3c-08ce3a9670a2
WARNING - VmMemoryVmListener: Unable to determine name of generation 2 for VM
b157788b-d850-433c-bb3e-711894908bbe
WARNING - VmMemoryVmListener: Further warnings will be ignored
WARNING - VmMemoryVmListener: Unable to determine name of generation 2 for VM
9a143a0a-e071-4608-bf15-6963b1c36499
WARNING - VmMemoryVmListener: Further warnings will be ignored
WARNING - VmMemoryVmListener: Unable to determine name of generation 2 for VM
40e2418f-d636-4336-942e-2ce489730845
WARNING - VmMemoryVmListener: Further warnings will be ignored
Note that "Host CPU Backend" never activates in the former case.
--
You are receiving this mail because:
You are the assignee for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20170627/67209e88/attachment.html>
More information about the distro-pkg-dev
mailing list