mysql-formula/README.rst

138 lines
4 KiB
ReStructuredText
Raw Normal View History

=====
2013-06-13 16:30:15 -06:00
mysql
=====
Install the MySQL client and/or server on Linux and MacOS.
.. note::
See the full `Salt Formulas installation and usage instructions
<http://docs.saltstack.com/en/latest/topics/development/conventions/formulas.html>`_.
2013-06-13 16:30:15 -06:00
2013-08-08 16:47:03 -06:00
Available states
================
.. contents::
:local:
2013-06-13 16:30:15 -06:00
``mysql``
2014-07-02 09:56:59 -04:00
---------
Meta-state including all server packages in correct order. This meta-state does **not** include ``mysql.remove_test_database``.
``mysql.macos``
----------------
2018-10-02 13:19:57 +01:00
Install "MySQL Community Server", "MySQL Workbench", and other related mysql products on MacOS (and create Desktop shortcuts).
``mysql.macos.remove``
----------------
Remove "MySQL Community Server", "MySQL Workbench", and any other enabled products from MacOS.
2013-08-15 17:25:15 -05:00
``mysql.client``
----------------
Install the MySQL client package on Linux.
2013-08-08 16:47:03 -06:00
``mysql.server``
----------------
Install the MySQL server package and start the service.
Debian OS family supports setting MySQL root password during install via debconf.
.. note::
If no root password is provided in the pillar, a random one will
2014-07-26 23:54:48 -07:00
be created. Because Hydrogen doesn't have easy access to a random
function (test.rand_str isn't introduced until Helium), instead,
we use the not-at-all random ``grains.server_id``. As this is
cryptographically insecure, future formula versions should use the
newly available ``random.get_str`` method.
``mysql.server_checks``
-----------------------
Enforces a root password to be set.
2015-03-03 10:49:49 -05:00
``mysql.disabled``
------------------
Ensure that the MySQL service is not running.
``mysql.database``
------------------
Create and manage MySQL databases.
``mysql.python``
2015-03-09 18:12:32 -04:00
----------------
Install mysql python bindings.
2014-05-12 12:29:30 -04:00
``mysql.user``
--------------
Create and manage MySQL database users with definable GRANT privileges.
The state accepts MySQL hashed passwords or clear text. Hashed password have
priority.
.. note::
See the `salt.states.mysql_user
<http://docs.saltstack.com/en/latest/ref/states/all/salt.states.mysql_user.html#module-salt.states.mysql_user>`_
docs for additional information on configuring hashed passwords.
2014-05-15 17:08:31 -04:00
Make sure to **quote the passwords** in the pillar so YAML doesn't throw an exception.
``mysql.remove_test_database``
------------------------------
.. warning::
Do not use this state if your MySQL instance has a database in use called ``test``.
If you do, it will be irrevocably removed!
Remove the database called ``test``, normally created as part of a default
MySQL installation. This state is **not** included as part of the meta-state
above as this name may conflict with a real database.
``mysql.dev``
2015-03-09 18:12:32 -04:00
-------------
Install the MySQL development libraries and header files.
.. note::
Note that this state is not installed by the mysql meta-state unless you set
2015-10-05 21:44:20 +02:00
your pillar data accordingly.
``mysql.repo``
--------------
Add the official MySQL 5.7 repository.
.. note::
Note that this state currently only supports MySQL 5.7 for RHEL systems.
Debian and Suse support to be added. Also need to add the option to allow
selection of MySQL version (5.6 and 5.5 repos are added but disabled) and
changed enabled repository accordingly.
``mysql.config``
------------------
Manage the MySQL configuration.
.. note::
There are currently two common ways to configure MySQL, a monolithic configuration file
or a configuration directory with configuration files per component. By default this
state will use a configuration directory for CentOS and Fedora, and a monolithic
configuration file for all other supported OSes.
Whether the configuration directory is used or not depends on whether `mysql.config_directory`
is defined in the pillar. If it is present it will pick the configuration from individual
component keys (`mysql.server`, `mysql.galera`, `mysql.libraries`, etc) with optional global
configuration from `mysql.global`. The monolithic configuration, however, is defined separately
in `mysql.config`.