summaryrefslogtreecommitdiff
path: root/doc/en_US/mysql-configuration.markdown
diff options
context:
space:
mode:
authorFrederic Guillot <fred@kanboard.net>2017-01-29 11:07:42 -0500
committerFrederic Guillot <fred@kanboard.net>2017-01-29 11:07:42 -0500
commit0371acff89b14b9bdcb03e72fd9637e26e6b517c (patch)
treef5878c9c07705379d137843cb8f92e3cdf7c20a8 /doc/en_US/mysql-configuration.markdown
parent3bf4789be255650b64f42231f41383cb13b65572 (diff)
Move English documentation to folder en_US
Diffstat (limited to 'doc/en_US/mysql-configuration.markdown')
-rw-r--r--doc/en_US/mysql-configuration.markdown72
1 files changed, 72 insertions, 0 deletions
diff --git a/doc/en_US/mysql-configuration.markdown b/doc/en_US/mysql-configuration.markdown
new file mode 100644
index 00000000..c199353e
--- /dev/null
+++ b/doc/en_US/mysql-configuration.markdown
@@ -0,0 +1,72 @@
+MySQL/MariaDB Configuration
+===========================
+
+By default Kanboard use Sqlite to stores its data.
+However it's possible to use MySQL or MariaDB instead of Sqlite.
+
+Requirements
+------------
+
+- MySQL server
+- The PHP extension `pdo_mysql` installed
+
+Note: Kanboard is tested with **MySQL >= 5.5 and MariaDB >= 10.0**
+
+MySQL configuration
+-------------------
+
+### Create a database
+
+The first step is to create a database on your MySQL server.
+By example, you can do that with the command line mysql client:
+
+```sql
+CREATE DATABASE kanboard;
+```
+
+### Create a config file
+
+The file `config.php` should contains those values:
+
+```php
+<?php
+
+// We choose to use MySQL instead of Sqlite
+define('DB_DRIVER', 'mysql');
+
+// MySQL parameters
+define('DB_USERNAME', 'REPLACE_ME');
+define('DB_PASSWORD', 'REPLACE_ME');
+define('DB_HOSTNAME', 'REPLACE_ME');
+define('DB_NAME', 'kanboard');
+```
+
+Note: You can also rename the template file `config.default.php` to `config.php`.
+
+### Importing SQL dump (alternative method)
+
+For the first time, Kanboard will run one by one each database migration and this process can take some time according to your configuration.
+
+To avoid any potential timeout you can initialize the database directly by importing the SQL schema:
+
+```bash
+mysql -u root -p my_database < app/Schema/Sql/mysql.sql
+```
+
+The file `app/Schema/Sql/mysql.sql` is a SQL dump that represents the last version of the database.
+
+SSL configuration
+-----------------
+
+These parameters have to be defined to enable the MySQL SSL connection:
+
+```php
+// MySQL SSL key
+define('DB_SSL_KEY', '/path/to/client-key.pem');
+
+// MySQL SSL certificate
+define('DB_SSL_CERT', '/path/to/client-cert.pem');
+
+// MySQL SSL CA
+define('DB_SSL_CA', '/path/to/ca-cert.pem');
+```