web-dev-qa-db-fra.com

MariaDB - impossible de définir max_connections via my.cnf

Je ne parviens pas à définir le paramètre max_connections dans /etc/my.cnf mais MariaDB ne semble pas lire le paramètre dans le fichier.

Mon fichier /etc/my.cnf:

[mysqld]
#skip-grant-tables
datadir=/data/mysql
socket=/data/mysql/mysql.sock
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

# network
connect_timeout = 60
wait_timeout = 28800
max_connections = 100000
max_allowed_packet = 64M
max_connect_errors = 1000

# limits
tmp_table_size = 512M
max_heap_table_size = 256M
table_cache = 512

[mysqld_safe]
log-error=/var/log/mariadb/mariadb.log
pid-file=/var/run/mariadb/mariadb.pid

[client]
port = 3306
socket= /data/mysql/mysql.sock

Mais lorsque je vérifie la variable dans MariaDB, elle affiche la valeur par défaut:

MariaDB [(none)]> show variables like 'max_connections';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 214   |
+-----------------+-------+
1 row in set (0.00 sec)

Cependant, les autres paramètres de my.cnf sont corrects:

MariaDB [(none)]> show variables like 'wait_timeout';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| wait_timeout  | 28800 |
+---------------+-------+
1 row in set (0.00 sec)

MariaDB [(none)]> show variables like 'max_allowed_packet';
+--------------------+----------+
| Variable_name      | Value    |
+--------------------+----------+
| max_allowed_packet | 67108864 |
+--------------------+----------+
1 row in set (0.00 sec)


MariaDB [(none)]> show variables like 'max_connect_errors';
+--------------------+-------+
| Variable_name      | Value |
+--------------------+-------+
| max_connect_errors | 1000  |
+--------------------+-------+
1 row in set (0.00 sec)

MariaDB [(none)]> show variables like 'connect_timeout';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| connect_timeout | 60    |
+-----------------+-------+
1 row in set (0.00 sec)

Je peux définir cette variable à partir de la ligne de commande mysql mais elle se réinitialise lorsque je redémarre le service:

MariaDB [(none)]> set global max_connections := 10000;
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> show variables like 'max_connections';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| max_connections | 10000 |
+-----------------+-------+
1 row in set (0.00 sec)

OS: RHEL 7

Version de MariaDB: mariadb-server-5.5.47-1.el7_2.x86_64

Voir ici: https://dba.stackexchange.com/questions/137487/mariadb-cannot-set-max-connections-and-wait-timeout-through-my-cnf

6
Iokanaan Iokan

Je pense que la solution est ici. Augmentez votre limite de fichiers ouverts. 

https://dba.stackexchange.com/questions/12061/mysql-auto-adjusting-max-connections-values ​​

3
mootmoot

J'ai le même problème sur le serveur Ubuntu. nd j'ai changer ce fichier /etc/mysql/my.cnf

max_connections = 1000

puis exécutez la requête. vous modifiez un fichier incorrect.

1
Ket.