Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/silpion/ansible-java
Ansible role to manage Java installation
https://github.com/silpion/ansible-java
Last synced: about 2 months ago
JSON representation
Ansible role to manage Java installation
- Host: GitHub
- URL: https://github.com/silpion/ansible-java
- Owner: silpion
- License: apache-2.0
- Created: 2014-03-04T13:30:33.000Z (almost 11 years ago)
- Default Branch: next
- Last Pushed: 2017-06-12T10:58:37.000Z (over 7 years ago)
- Last Synced: 2024-08-03T17:10:26.434Z (5 months ago)
- Language: Python
- Size: 219 KB
- Stars: 55
- Watchers: 9
- Forks: 37
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ansible - Github
README
# silpion.java
Install Oracle Java.
# Synopsis
```yaml
- name: Install Java 8u102 JDK to /opt/java
hosts: all
roles:
- role: silpion.java
``````yaml
- name: Install Java server-jre to /usr/local/java
hosts: all
roles:
- role: silpion.java
java_oracle_distribution: srv
java_install_dir: /usr/local/java
``````yaml
- name: Install Java JRE 8u60
hosts: all
roles:
- role: silpion.java
java_oracle_version: 8u60
java_oracle_distribution: jre
```# Description
The role downloads redistributable packages from the internet
to the hosts local filesystem before it may install those on
any number of managed nodes in the local network.Downloads are performed with the ``command`` module using ``curl``.
It is required to have curl installed on the local host you
are running ansible-playbook on to manage nodes (your workstation).Downloaded assets are verified based on SHA 256 checksums on
the local workstation before getting copied to the managed node.The local shasum binary is guessed automatically but may get
configured via ``java_shasum_binary: /path/to/shasum/binary``.For detailed configuration options see [Role Variables](#role_variables)
documentation below.# Dependencies
* [silpion.lib][1]
* [silpion.util][2]roles. This is configured for the ``ansible-galaxy install`` command in
**requirements.yml**.```sh
ansible-galaxy install --no-deps --role-file requirements.yml
```* ``java_oracle_distribution``: Configure the Java distribution to be installed (default: ``jdk``, values: [``jdk``, ``jre``, ``srv``])
* ``java_oracle_version``: Configure Java version to be installed (string, default: ``8u66``)
* ``java_install_dir``: Base installation directory for any Java implementation/distribution (string, default: ``/opt/java``)
* ``java_shasum_binary``: Allows to configure shasum binary for local\_action: command (string, default: ``with_first_found: java_shasum_binaries`` (see ``vars/main.yml``))
* ``java_path_to_lib_role``: configure path to lib-role, which can get configured via silpion.lib role (string, default: ``{{ lib_roles_path }}``)Note: ``srv`` is an Ansible compatible shorthand for the Oracle ``server-jre``.
## Versioned variables
Predefined SHA sums and further version specific configuration may get found in
the ``vars/versions`` directory. When configuring a version, that is not predefined
(so far), the following variables must also be defined in the playbook:* ``java_oracle_version_major``: Oracle major version
* ``java_oracle_version_minor``: Oracle minor version
* ``java_oracle_version_patch``: Oracle patch version
* ``java_oracle_version_update``: Oracle major version
* ``java_oracle_version_build``: Oracle build version
* ``java_oracle_redis_jdk_sha256sum``: SHA256 sum for the downloaded Oracle Java JDK redistributable package - mandatory when ``java_oracle_distribution`` is ``jdk``
* ``java_oracle_redis_jre_sha256sum``: SHA256 sum for the downloaded Oracle Java JRE redistributable package - mandatory when ``java_oracle_distribution`` is ``jre``
* ``java_oracle_redis_srv_sha256sum``: SHA256 sum for the downloaded Oracle Java Server-JRE redistributable package - mandatory when ``java_oracle_distribution`` is ``srv``
* ``java_oracle_redis_jce_sha256sum``: SHA256 sum for the downloaded Oracle Java JCE policies package
* ``java_oracle_mirror_jce``: Mirror URL for the download of the Oracle Java JCE policies package
* ``java_oracle_redis_jce_filename``: File name of the Oracle Java JCE policies package
* ``java_oracle_redis_jce_archive_dirname``: Name of the base directory in the Oracle Java JCE policies package## Supported versions
* 7u21
* 7u51
* 7u71
* 7u80
* 8u20
* 8u25
* 8u31
* 8u45
* 8u51
* 8u60
* 8u65
* 8u66
* 8u92
* 8u101
* 8u102Starting with
* ``7u80`` (Java 7)
* ``8u66`` (Java 8)configuration of ``java_oracle_distribution``: ``srv`` is available.
# Role facts
This role sets persistent facts for other roles to use via
* facts.d ``ansible_local.java.general.java_home``
This variable contains the path to the default JVM configured with this role.
# Checkmode
Checkmode is supported provided that all assets have been downloaded.
Otherwise, the copy tasks will fail.You can download the assets without making any changes on the remote nodes by executing this role with the ``java_download`` tag.
# Contributing
If you want to contribute to this repository please be aware that this
project uses a [gitflow](http://nvie.com/posts/a-successful-git-branching-model/)
workflow with the next release branch called ``next``.Please fork this repository and create a local branch split off of the ``next``
branch and create pull requests back to the origin ``next`` branch.# License
Apache Version 2.0
# Author
* Mark Kusch @mark.kusch silpion.de
* Marc Rohlfs @marc.rohlfs silpion.de
* Alvaro Aleman @alvaro.aleman silpion.de## Contributors
* Lars Maehlmann @lars.maehlmann silpion.de
* Sebastian Davids @sebastian.davids silpion.de
* [ludovicc](https://github.com/ludovicc)
* [nixlike](https://github.com/nixlike)
* [trumant](https://github.com/trumant)[1]: https://github.com/silpion/ansible-lib
[2]: https://github.com/silpion/ansible-util