-
Notifications
You must be signed in to change notification settings - Fork 80
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Community] [WFCORE-6830] New attributes on the HTTP Management Interface to configure resource constraints. #595
Merged
Merged
Changes from 1 commit
Commits
Show all changes
4 commits
Select commit
Hold shift + click to select a range
8cb6c78
[WFCORE-6830] New attributes on the HTTP Management Interface to conf…
darranl 9a18514
[WFCORE-6830] Add information about the admin clients to the proposal.
darranl 8511a65
[WFCORE-6830] Small update to specify that a deprecation message will…
darranl 6672457
[WFCORE-6830] Add some additional information about the community doc…
darranl File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
221 changes: 221 additions & 0 deletions
221
management/WFCORE-6830_Management_Resource_Constraints.adoc
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,221 @@ | ||
--- | ||
categories: | ||
- management | ||
--- | ||
= [Community] [WFCORE-6830] Additional management attributes to contrain HTTP management interface resource utilisation. | ||
:author: Darran Lofthouse | ||
:email: [email protected] | ||
:toc: left | ||
:icons: font | ||
:idprefix: | ||
:idseparator: - | ||
|
||
== Overview | ||
|
||
Previously under https://issues.redhat.com/browse/WFCORE-6825[WFCORE-6825] an update was made to the HTTP management interface | ||
to allow the following system properties to be set to configure the constraints applied to the HTTP management interface: | ||
|
||
* `org.wildfly.management.backlog` | ||
* `org.wildfly.management.connection-high-water` | ||
* `org.wildfly.management.connection-low-water` | ||
* `org.wildfly.management.no-request-timeout` | ||
|
||
If the system properties were not set these would defalt to: | ||
|
||
* backlog = 50 | ||
* connection-high-water = 100 | ||
* connection-low-water = 75 | ||
* no-request-timeout = 60000 | ||
|
||
This proposal is to add attributes to the management model for the HTTP management interface at the "Community" stability level | ||
to enable these to be configured directly in the management model. | ||
|
||
== Issue Metadata | ||
|
||
=== Issue | ||
|
||
* https://issues.redhat.com/browse/WFCORE-6830[WFCORE-6830] | ||
|
||
=== Related Issues | ||
|
||
* https://issues.redhat.com/browse/WFCORE-6825[WFCORE-6825] - The original issue to add the system properties. | ||
* https://issues.redhat.com/browse/WFCORE-6829[WFCORE-6829] - A new community level schema for the core management model. | ||
* https://issues.redhat.com/browse/WFLY-19715[WFLY-19715] - Task to document the new attributes. | ||
|
||
=== Stability Level | ||
// Choose the planned stability level for the proposed functionality | ||
* [ ] Experimental | ||
|
||
* [ ] Preview | ||
|
||
* [*] Community | ||
|
||
* [ ] default | ||
|
||
=== Dev Contacts | ||
|
||
* mailto:{email}[{author}] | ||
|
||
=== QE Contacts | ||
|
||
=== Testing By | ||
// Put an x in the relevant field to indicate if testing will be done by Engineering or QE. | ||
// Discuss with QE during the Kickoff state to decide this | ||
* [*] Engineering | ||
|
||
* [ ] QE | ||
|
||
=== Affected Projects or Components | ||
|
||
* WildFly Core | ||
* WildFly | ||
|
||
=== Other Interested Projects | ||
|
||
The https://github.com/wildfly-extras/creaper[Creaper] project is also impacted by the changes as adding a community | ||
level schema impacts version detection in this project as reported under | ||
https://github.com/wildfly-extras/creaper/issues/236[Issue#236]. | ||
|
||
=== Relevant Installation Types | ||
// Remove the x next to the relevant field if the feature in question is not relevant | ||
// to that kind of WildFly installation | ||
* [x] Traditional standalone server (unzipped or provisioned by Galleon) | ||
|
||
* [x] Managed domain | ||
|
||
* [x] OpenShift s2i | ||
|
||
* [x] Bootable jar | ||
|
||
== Requirements | ||
|
||
=== Hard Requirements | ||
|
||
Four new attributes will be added to the HTTP management interface to configure the supported resource constraints that | ||
can be applied: | ||
|
||
* `backlog` | ||
* `connection-high-water` | ||
* `connection-low-water` | ||
* `no-request-timeout` | ||
|
||
The resulting resource will look like: | ||
|
||
[source] | ||
---- | ||
/core-service=management/management-interface=http-interface:read-resource(include-defaults=true) | ||
{ | ||
"outcome" => "success", | ||
"result" => { | ||
"allowed-origins" => undefined, | ||
"backlog" => 50, | ||
"connection-high-water" => 100, | ||
"connection-low-water" => 75, | ||
"console-enabled" => true, | ||
"constant-headers" => undefined, | ||
"http-authentication-factory" => "management-http-authentication", | ||
"http-upgrade" => { | ||
"enabled" => true, | ||
"sasl-authentication-factory" => "management-sasl-authentication" | ||
}, | ||
"http-upgrade-enabled" => true, | ||
"no-request-timeout" => 60000, | ||
"sasl-protocol" => "remote", | ||
"secure-socket-binding" => undefined, | ||
"server-name" => undefined, | ||
"socket-binding" => "management-http", | ||
"ssl-context" => undefined | ||
} | ||
} | ||
---- | ||
|
||
When persisted to the configuration file the resulting XML will look like: | ||
|
||
[source,xml] | ||
---- | ||
<management-interfaces> | ||
<http-interface http-authentication-factory="management-http-authentication" | ||
backlog="51" no-request-timeout="60001" | ||
connection-high-water="101" connection-low-water="76"> | ||
|
||
<http-upgrade enabled="true" sasl-authentication-factory="management-sasl-authentication"/> | ||
<socket-binding http="management-http"/> | ||
</http-interface> | ||
</management-interfaces> | ||
---- | ||
|
||
=== Nice-to-Have Requirements | ||
|
||
None | ||
|
||
=== Non-Requirements | ||
|
||
The purpose of this feature request is to expose management model attributes to configure existing behaviour within the | ||
application server, this feature request is not intended to revisit the existing behaviour which is already available at | ||
all stability levels. | ||
|
||
=== Future Work | ||
|
||
The only possible future work could be to promote one or all of these new attributes to a higher stability level. | ||
|
||
A change such as this should likely be constrained to: | ||
|
||
* Removing the stability level qualifier from the attribute definitions allowing them to be used at the default stability level. | ||
* Moving the XML schema definitions and parsing to an appropriate schema at the default stability level. | ||
|
||
== Backwards Compatibility | ||
|
||
In considering backwards compatibility if an attribute is defined on the HTTP management interface AND the | ||
corresponding system property is set then the system property should take precedence. | ||
|
||
=== Default Configuration | ||
|
||
The new attributes will not be present in the default configuration, instead the default values will remain in use. | ||
|
||
=== Importing Existing Configuration | ||
|
||
As the attributes are optional and defined with default values the changes here will not impact the ability to import | ||
and existing configuration. | ||
|
||
=== Deployments | ||
|
||
N/A | ||
|
||
=== Interoperability | ||
|
||
N/A | ||
|
||
== Security Considerations | ||
|
||
Security constraints are already defined on the management interfaces, these new attributes do not require further constraints. | ||
|
||
== Test Plan | ||
|
||
The original issue https://issues.redhat.com/browse/WFCORE-6825[WFCORE-6825] already added a test case to the `manualmode` | ||
testsuite `org.wildfly.core.test.standalone.mgmt.ManagementInterfaceResourcesTestCase`, this test uses the system properties | ||
to define the resource constraints and then checks that the constraints are applied. This test will be enhanced so that in | ||
addition to the testing it performs using system properties the same tests are repeated setting the constraints as attributes | ||
in the management model. | ||
|
||
WildFly Core also contains two test cases which test the parsing and marshalling of the management model from XML and back | ||
for the management interfaces: | ||
|
||
* `org.jboss.as.core.model.test.mgmt_interfaces.StandaloneMgmtInterfacesTestCase` | ||
* `org.jboss.as.core.model.test.mgmt_interfaces.HostMgmtInterfacesTestCase` | ||
|
||
These test cases will both have a test added to parse and marshall a configuration with all of the new attributes defined. | ||
|
||
== Community Documentation | ||
|
||
Under https://issues.redhat.com/browse/WFLY-19715[WFLY-19715] documented will be added describing the new attributes | ||
and how they can be used. | ||
|
||
== Release Note Content | ||
|
||
Previously under https://issues.redhat.com/browse/WFCORE-6825[WFCORE-6825] four system properties with default values were | ||
added to enable the constraints affecting the HTTP management interface to be configured. Under | ||
https://issues.redhat.com/browse/WFCORE-6830[WFCORE-6830] four new attributes have been added to the HTTP management interface | ||
(`backlog`, `connection-high-water`, `connection-low-water`, `no-request-timeout`) to allow these constraints to be configured | ||
directly in the management model. | ||
|
||
These new attributes are available for servers running at the `Community` stability level or lower. |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If this happens we should log a WARN that the system property will be removed. People should move promptly off of system property based configuration once proper attributes are available.
And then remove it in, say, WF 36, assuming this lands in WF 34.
Probably using the same logger category that we use when warning about use of deprecated management API would be good. It's an analogous situation.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you, I can add that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I have updated to add the logging:
https://github.com/wildfly/wildfly-proposals/pull/595/files#diff-c4fba9f719d2a6d63183999eb1869081774e7d44fb5d70004133b12de65c8dd6R176
The other deprecation messages all appear to use INFO so I have done the same here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks. LGTM.