-
Epic
-
Resolution: Fixed
-
Major
-
Plugin Management tooling
-
Jenkins does offer a web UI to manage plugin installation from a live master instance, but in many deployments administrator would like to control installed plugins by version and by tooling, before jenkins master starts.
- docker official image provides an install-plugins.sh script which evolved far beyond its initial "help script" scope.
- configuration-as-code implemented plugin installation hack based on PluginSite.Plugin#deploy. (Removed as of v1.8 of JCasC plugin)
- open-source update center does expose plugins-version.json on casc request so one can manage versions for all hosted plugins, not just latest
- custom war packager does support plugin installation on his own
- jenkins evergreen does manage plugin installation based on updates from metadata server, using his own logic implemented by nodejs evergreen client.
- jenkinsfile-runner does manage plugin installation implemented in Go
- coreOS provides a groovy script to handle required plugins
- cloudbees DEV@Cloud uses a set of Chef Ruby recipes for the same purpose
- etc
Everybody is re-inventing the wheel, partially implementing the "details" of plugin management (signed metadata, artifacts checksums, plugins detached from core, ...). It becomes obvious Jenkins should provide adequate tooling for plugin installation outside a live Jenkins instance.
- relates to
-
JENKINS-53506 Update all installed plugins to latest version
-
- Closed
-
-
JENKINS-51929 Create "mvn incrementals:update" equivalents for YAML and BOM definitions
-
- Resolved
-
- links to
[JENKINS-53767] Offer plugin management tooling
Description |
Original:
Jenkins do offer a web UI to manage plugin installation from a live master instance, but in many deployment administrator would like to control installed plugins by version and by tooling, before jenkins master starts. * docker official image provides an install-plugins.sh script which evolved far beyond it's initial "help script" scope. * configuration-as-code implemented plugin installation hack based on PluginSite.Plugin#deploy. * open-source update center do expose plugins-version.json on casc request so one can manage versions for all hosted plugins, not just latest * custom war packager do support plugin installation on his own * jenkins evergreen do manage plugin installation based on updates from metadata server, using his own logic implemented by nodejs evergreen client. * jenkinsfile-runner do manage plugin installation implemented in Go * coreOS provides a [groovy script|https://github.com/coreos/jenkins-os/blob/master/init.groovy] to handle required plugins * cloudbees DEV@Cloud uses a set of Chef Ruby recipes for the same purpose * etc Everybody is re-inventing the wheel, partially implementing the "details" of plugin management (signed metadata, artifacts checksums, plugins detached from core, ...). It becomes obvious Jenkins should provide adequate tooling for plugin installation _outside_ jenkins live instance. |
New:
Jenkins does offer a web UI to manage plugin installation from a live master instance, but in many deployments administrator would like to control installed plugins by version and by tooling, before jenkins master starts. * docker official image provides an install-plugins.sh script which evolved far beyond its initial "help script" scope. * configuration-as-code implemented plugin installation hack based on PluginSite.Plugin#deploy. * open-source update center does expose plugins-version.json on casc request so one can manage versions for all hosted plugins, not just latest * custom war packager does support plugin installation on his own * jenkins evergreen does manage plugin installation based on updates from metadata server, using his own logic implemented by nodejs evergreen client. * jenkinsfile-runner does manage plugin installation implemented in Go * coreOS provides a [groovy script|https://github.com/coreos/jenkins-os/blob/master/init.groovy] to handle required plugins * cloudbees DEV@Cloud uses a set of Chef Ruby recipes for the same purpose * etc Everybody is re-inventing the wheel, partially implementing the "details" of plugin management (signed metadata, artifacts checksums, plugins detached from core, ...). It becomes obvious Jenkins should provide adequate tooling for plugin installation _outside_ jenkins live instance. |
Assignee | New: James Strachan [ jstrachan ] |
Link |
New:
This issue relates to |
Link |
New:
This issue relates to |
Thanks for submitting it ndeloof! I totally agree we should streamline it at some point and offer a single solution