ajout vagrantfile +playbook pour rundeck avec mariadb

This commit is contained in:
phil 2022-12-04 00:38:29 +01:00
parent 6ee329a147
commit 4657394542
2 changed files with 189 additions and 0 deletions

82
rundeck/Vagrantfile vendored Normal file
View File

@ -0,0 +1,82 @@
# -*- mode: ruby -*-
# vi: set ft=ruby :
# All Vagrant configuration is done below. The "2" in Vagrant.configure
# configures the configuration version (we support older styles for
# backwards compatibility). Please don't change it unless you know what
# you're doing.
Vagrant.configure("2") do |config|
# The most common configuration options are documented and commented below.
# For a complete reference, please see the online documentation at
# https://docs.vagrantup.com.
# Every Vagrant development environment requires a box. You can search for
# boxes at https://vagrantcloud.com/search.
config.vm.box = "debian/bullseye64"
config.vm.hostname = "rundeck"
# Disable automatic box update checking. If you disable this, then
# boxes will only be checked for updates when the user runs
# `vagrant box outdated`. This is not recommended.
# config.vm.box_check_update = false
# Create a forwarded port mapping which allows access to a specific port
# within the machine from a port on the host machine. In the example below,
# accessing "localhost:8080" will access port 80 on the guest machine.
# NOTE: This will enable public access to the opened port
# config.vm.network "forwarded_port", guest: 80, host: 8080
# Create a forwarded port mapping which allows access to a specific port
# within the machine from a port on the host machine and only allow access
# via 127.0.0.1 to disable public access
# config.vm.network "forwarded_port", guest: 80, host: 8080, host_ip: "127.0.0.1"
# Create a private network, which allows host-only access to the machine
# using a specific IP.
# config.vm.network "private_network", ip: "192.168.33.10"
# Create a public network, which generally matched to bridged network.
# Bridged networks make the machine appear as another physical device on
# your network.
config.vm.network "public_network"
# Share an additional folder to the guest VM. The first argument is
# the path on the host to the actual folder. The second argument is
# the path on the guest to mount the folder. And the optional third
# argument is a set of non-required options.
# config.vm.synced_folder "../data", "/vagrant_data"
# Provider-specific configuration so you can fine-tune various
# backing providers for Vagrant. These expose provider-specific options.
# Example for VirtualBox:
#
config.vm.provider "virtualbox" do |vb|
# # Display the VirtualBox GUI when booting the machine
# vb.gui = true
#
# # Customize the amount of memory on the VM:
vb.memory = "3076"
end
#
# View the documentation for the provider you are using for more
# information on available options.
# Enable provisioning with a shell script. Additional provisioners such as
# Ansible, Chef, Docker, Puppet and Salt are also available. Please see the
# documentation for more information about their specific syntax and use.
config.vm.provision "shell", inline: <<-SHELL
apt-get update
# apt-get install -y oftware-properties-common curl wget vim git openjdk-11-jre-headless
# curl https://raw.githubusercontent.com/rundeck/packaging/main/scripts/deb-setup.sh 2> /dev/null | sudo bash -s rundeck
# apt-get update
# apt-get install -y rundeck
# apt-get install -y mariadb-server
# echo "create database rundeck;" |mysql -u root -p
# echo "create user 'rundeckuser'@'localhost' identified by 'rundeckpassword'"|mysql -u root -p;
# echo "grant ALL on rundeck.* to 'rundeckuser'@'localhost';" |mysql -u root -p
SHELL
config.vm.provision "ansible" do |ansible|
ansible.verbose = "v"
ansible.playbook = "deploy-rundeck.yml"
end
end

107
rundeck/deploy-rundeck.yml Normal file
View File

@ -0,0 +1,107 @@
---
- name: Install rundeck
hosts: all
become: yes
vars:
- rddbname: "rundeck"
- rduser: "rundeckuser"
- rdpw: "rundeckuserpassword"
- rdhost: "rundeck"
- rdtz: "Europe/Paris"
tasks:
- name: Change TimeZone to "{{ rdtz }}"
community.general.timezone:
name: "{{ rdtz }}"
- name: Install paquets software-props curl wget vim openjdk11 python3-pymysql
package:
name:
- software-properties-common
- gpg
- curl
- wget
- vim
- openjdk-11-jre-headless
- python3-pymysql
state: present
- name: installe mariadb-server
package:
name: mariadb-server
state: present
- name: cree db "{{ rddbname }}"
community.mysql.mysql_db:
name: "{{ rddbname }}"
state: present
login_unix_socket: /var/run/mysqld/mysqld.sock
- name: Cree utilisteur {{ rduser }}
community.mysql.mysql_user:
name: "{{ rduser }}"
password: "{{ rdpw }}"
priv: "{{ rddbname }}.*:ALL"
state: present
login_unix_socket: /var/run/mysqld/mysqld.sock
# - name:
#fail:
#msg: 'fini'
- name: get key for rundeck apt repo
ansible.builtin.apt_key:
url: https://packages.rundeck.com/pagerduty/rundeck/gpgkey
state: present
- name: ajout depot
ansible.builtin.apt_repository:
repo: deb https://packages.rundeck.com/pagerduty/rundeck/any/ any main
state: present
- name: Update cache
ansible.builtin.apt:
update_cache: yes
cache_valid_time: 86400
- name: installe rundeck
package:
name: rundeck
state: present
- name: supprimie jdbc.h2
replace:
path: /etc/rundeck/rundeck-config.properties
regexp: '^\s*dataSource.url = jdbc:h2:.*'
replace: ''
backup: yes
- name: remplace localhost par {{ rdhost }} dans /etc/rundeck/framework.properties
replace:
path: /etc/rundeck/framework.properties
regexp: "localhost"
replace: "{{ rdhost }}"
backup: yes
- name: remplace localhost par {{ rdhost }} dans /etc/rundeck/rundeck-system.properties
replace:
path: /etc/rundeck/rundeck-config.properties
regexp: "^grails.serverURL=.*"
replace: "grails.serverURL=http://{{ rdhost }}:4440"
backup: yes
- name: configure DB connexion
blockinfile:
path: /etc/rundeck/rundeck-config.properties
backup: yes
block: |
dataSource.driverClassName = org.mariadb.jdbc.Driver
dataSource.url = jdbc:mysql://localhost/rundeck?autoReconnect=true&useSSL=false
dataSource.username = {{ rduser }}
dataSource.password = {{ rdpw }}
- name: Active rundeckd et le lance
ansible.builtin.sysvinit:
name: rundeckd
state: started
enabled: yes