Add support for Debian/Ubuntu.

This commit is contained in:
Jeff Geerling 2014-04-23 10:09:31 -05:00
parent 9fc1bbd1ea
commit a7998b3b9a
7 changed files with 75 additions and 25 deletions

View file

@ -1,6 +1,6 @@
# Ansible Role: MySQL # Ansible Role: MySQL
Installs MySQL server on RedHat Enterprise Linux or CentOS 6.x servers. Installs MySQL server on RHEL/CentOS or Debian/Ubuntu servers.
## Requirements ## Requirements
@ -10,9 +10,9 @@ None.
Available variables are listed below, along with default values (see `vars/main.yml`): Available variables are listed below, along with default values (see `vars/main.yml`):
mysql_enablerepo: "" mysql_user_home: /root
If you have enabled any additional repositories (might I suggest geerlingguy.repo-epel or geerlingguy.repo-remi), those repositories can be listed under this variable (e.g. `remi,epel`). This can be handy, as an example, if you want to install later versions of MySQL. The home directory inside which Python MySQL settings will be stored, which Ansible will use when connecting to MySQL. This should be the home directory of the user which runs this Ansible role.
mysql_root_password: root mysql_root_password: root
@ -23,7 +23,11 @@ The MySQL root user account password.
- mysql-server - mysql-server
- MySQL-python - MySQL-python
Packages to be installed. In some situations, you may need to add additional packages, like `mysql-devel`. (OS-specific, RedHat/CentOS defaults listed here) Packages to be installed. In some situations, you may need to add additional packages, like `mysql-devel`.
mysql_enablerepo: ""
(RedHat/CentOS only) If you have enabled any additional repositories (might I suggest geerlingguy.repo-epel or geerlingguy.repo-remi), those repositories can be listed under this variable (e.g. `remi,epel`). This can be handy, as an example, if you want to install later versions of MySQL.
## Dependencies ## Dependencies

View file

@ -1,3 +1,5 @@
--- ---
- name: restart mysql - name: restart mysql
command: service mysqld restart service: >
name={{ mysql_daemon }}
state=restarted

View file

@ -11,5 +11,11 @@ galaxy_info:
- name: EL - name: EL
versions: versions:
- 6 - 6
- name: Ubuntu
versions:
- all
- name: Debian
versions:
- all
categories: categories:
- database - database

View file

@ -1,24 +1,45 @@
--- ---
# If this is not done for the version of MySQL in certain extra repositories, - name: Include OS-specific variables.
# MySQL installation fails with an error the first time. include_vars: "{{ ansible_os_family }}.yml"
- name: Update postfix to the latest version.
yum: name=postfix state=latest enablerepo={{ mysql_enablerepo }}
- name: Ensure MySQL packages are installed. - name: Update postfix to the latest version (if extra repositories enabled).
yum: name={{ item }} state=installed enablerepo={{ mysql_enablerepo }} yum: >
name=postfix
state=latest
enablerepo={{ mysql_enablerepo }}
when: mysql_enablerepo != ""
- name: Ensure MySQL packages are installed (RedHat).
yum: >
name={{ item }}
state=installed
enablerepo={{ mysql_enablerepo }}
with_items: mysql_packages with_items: mysql_packages
when: ansible_os_family == 'RedHat'
- name: Ensure MySQL packages are installed (Debian).
apt: >
name={{ item }}
state=installed
with_items: mysql_packages
when: ansible_os_family == 'Debian'
- name: Copy my.cnf global MySQL configuration. - name: Copy my.cnf global MySQL configuration.
copy: src=my.cnf dest=/etc/my.cnf owner=root group=root mode=0644 copy: src=my.cnf dest=/etc/my.cnf owner=root group=root mode=0644
# Set MySQL to run at startup. - name: Ensure MySQL is started and enabled on boot.
- name: Ensure MySQL is started. service: >
service: name=mysqld state=started enabled=yes name={{ mysql_daemon }}
state=started
enabled=yes
# 'localhost' needs to be the last item for idempotency, see # 'localhost' needs to be the last item for idempotency, see
# http://ansible.cc/docs/modules.html#mysql-user # http://ansible.cc/docs/modules.html#mysql-user
- name: update mysql root password for all root accounts - name: Update MySQL root password for all root accounts.
mysql_user: name=root host={{ item }} password={{ mysql_root_password }} mysql_user: >
name=root
host={{ item }}
password={{ mysql_root_password }}
with_items: with_items:
- 127.0.0.1 - 127.0.0.1
- ::1 - ::1
@ -26,10 +47,17 @@
# Has to be after the root password assignment, for idempotency. # Has to be after the root password assignment, for idempotency.
- name: Copy .my.cnf file with root password credentials. - name: Copy .my.cnf file with root password credentials.
template: src=my.cnf.j2 dest=/root/.my.cnf owner=root group=root mode=0600 template: >
src=my.cnf.j2
dest={{ mysql_user_home }}/.my.cnf
owner=root group=root mode=600
- name: Delete anonymous MySQL user for localhost. - name: Delete anonymous MySQL user for localhost.
mysql_user: name="" state="absent" mysql_user: >
name=""
state=absent
- name: Remove the MySQL test database. - name: Remove the MySQL test database.
mysql_db: name="test" state="absent" mysql_db: >
name="test"
state=absent

5
vars/Debian.yml Normal file
View file

@ -0,0 +1,5 @@
---
mysql_daemon: mysql
mysql_packages:
- mysql-server
- python-mysqldb

6
vars/RedHat.yml Normal file
View file

@ -0,0 +1,6 @@
---
mysql_daemon: mysqld
mysql_packages:
- mysql
- mysql-server
- MySQL-python

View file

@ -1,8 +1,7 @@
--- ---
# Pass in a comma-separated list of repos to use (e.g. "remi,epel"). mysql_user_home: /root
mysql_enablerepo: ""
mysql_root_password: root mysql_root_password: root
mysql_packages:
- mysql # Pass in a comma-separated list of repos to use (e.g. "remi,epel"). Used only
- mysql-server # for RedHat systems (and derivatives).
- MySQL-python mysql_enablerepo: ""