Provides resources for installing Tomcat and managing the Tomcat service for use in wrapper cookbooks. Installs Tomcat from tarballs on the Apache.org website and installs the appropriate configuration for your platform's init system.
- Debian / Ubuntu derivatives
- RHEL and derivatives
- Fedora
- openSUSE / SUSE Linux Enterprises
- Chef 12.7+
- none
Due to the complexity of Tomcat cookbooks it's not possible to create an attribute driven cookbook that solves everyone's problems. Instead this cookbook provides resources for installing Tomcat and managing the Tomcat service, which are best used in your own wrapper cookbook. The best way to understand how this could be used is to look at the helloworld test recipe located at https://github.com/chef-cookbooks/tomcat/blob/master/test/cookbooks/test/recipes/helloworld_example.rb
tomcat_install installs an instance of the tomcat binary direct from Apache's mirror site. As distro packages are not used we can easily deploy per-instance installations and any version available on the Apache archive site can be installed.
version
: The version to install. Default: 8.0.47install_path
: Full path to the install directory. Default: /opt/tomcat_INSTANCENAME_VERSIONtarball_base_uri
: The base uri to the apache mirror containing the tarballs. Default: 'http://archive.apache.org/dist/tomcat/'checksum_base_uri
: The base uri to the apache mirror containing the checksum file. Default: 'http://archive.apache.org/dist/tomcat/'checksum_type
: The type of checksum to apply (e.g. sha256, sha1, md5). Default: '' (try all)verify_checksum
: Whether the checksum should be verified againstchecksum_base_uri
. Default:true
.dir_mode
: Directory permissions of theinstall_path
. Default:'0750'
.tarball_uri
: The complete uri to the tarball. If specified would override (tarball_base_uri
andchecksum_base_uri
). checksum will be loaded from "#{tarball_uri}.#{checksum_type}". This attribute is useful, if you are hosting tomcat tarballs from artifact repositories such as nexus.tarball_path
: Local path on disk to the tarball. If the file does not exist, or the checksum does not match, it will be downloaded fromtarball_uri
.tarball_validate_ssl
: Validate the SSL certificate, iftarball_uri
is using HTTPS. Defaulttrue
.exclude_docs
: Exclude ./webapps/docs from installation. Defaulttrue
.exclude_examples
: Exclude ./webapps/examples from installation. Defaulttrue
.exclude_manager
: Exclude ./webapps/manager from installation. Default:false
.exclude_hostmanager
: Exclude ./webapps/host-manager from installation. Default:false
.tomcat_user
: User to run tomcat as. Default:tomcat_INSTANCENAME
tomcat_group
: Group of the tomcat user. Default:tomcat_INSTANCENAME
tomcat_user_shell
: Shell of the tomcat user. Default:/bin/false
Install an Tomcat 8.0.36 instance named 'helloworld' to /opt/tomcat_helloworld_8_0_36/ with a symlink at /opt/tomcat_helloworld/
tomcat_install 'helloworld' do
version '8.0.36'
end
Install an Tomcat instance named 'helloworld' from a local tarball to /opt/tomcat_helloworld_8_0_36/ with a symlink at /opt/tomcat_helloworld/
tomcat_install 'helloworld' do
version '8.0.36'
verify_checksum false
tarball_path '/tmp/apache-tomcat-8.0.36.tar.gz'
end
tomcat_service sets up the installed tomcat instance to run using the appropriate init system (sys-v, upstart, or systemd)
install_path
: Full path to the install directory. Default: /opt/tomcat_INSTANCENAMEenv_vars
: An array of hashes containing the environmental variables for Tomcat's setenv.sh script. Note: If CATALINA_BASE is not passed it will automatically be added as the first item in the array. Default: [ {'CATALINA_BASE' => '/opt/INSTANCE_NAME/'}, {'CATALINA_PID' => '$CATALINA_BASE/bin/tomcat.pid'} ]sensitive
: Excludes diffs that may expose ENV values from the chef-client logs. Default:false
start
stop
enable
disable
restart
tomcat_service 'helloworld' do
action :start
env_vars [{ 'CATALINA_PID' => '/my/special/path/tomcat.pid' }]
end
- Author: Tim Smith ([email protected])
Copyright:: 2010-2016, Chef Software, Inc
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.