Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Cambiar valor variable global en MySQL en caliente
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Cambiar valor variable global en MySQL en caliente

Publicar nuevo tema Responder al tema
Foros de discusión » MySQL Server, MySQL Client, motor de bd gratuito   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Cambiar valor variable global en MySQL en caliente Responder citando

¿Se puede cambiar el valor de una variable de MySQL Server sin detener la base de datos? necesito ampliar el parámetro max_connections. El problema es que el servidor tiene miles de usuarios conectados las 24 horas y no puedo detenerlo, supondría pérdidas económicas para la empresa.

Necesito ampliar este valor porque, últimamente, me aparece el error: Too many connections.
MensajePublicado:
Mie Oct 24, 2012 6:27 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Cambiar valor variable global en MySQL en caliente Responder citando



Anuncios



varios escribió:
¿Se puede cambiar el valor de una variable de MySQL Server sin detener la base de datos? necesito ampliar el parámetro max_connections. El problema es que el servidor tiene miles de usuarios conectados las 24 horas y no puedo detenerlo, supondría pérdidas económicas para la empresa.

Necesito ampliar este valor porque, últimamente, me aparece el error: Too many connections.


Sí puedes cambiarlo online siempre que se trate de una variable dinámica y max_connections lo es. Para cambiarlo abre una ventana de terminal (si estás en Linux) o un consola de MS-DOS (si estás en Windows) y conéctate a MySQL Server mediante "mysql", sería algo así:

Código:

mysql --user="root" --password="contraseña"


si no te funciona el comando "mysql" ejecútalo desde la carpeta de MySQL, en Linux suele ser:

/var/lib/mysql

Una vez conectado a MySQL con MySQL monitor, ejecuta este comando para ver el valor actual del parámetro a modificar:

Código:

show variables like "max_connections";


Ahora puedes modificarlo en caliente (online) por trtarse de una variable dinámica, para ello ejecuta el comando:

Código:

set global max_connections=2000;


Para asegurarte de que el valor se ha modificado puedes volver a ejecutar:

Código:

show variables like "max_connections";


Es importante mencionar que cuando estableces el valor de una variable de MySQL con "set global ..." el cambio se aplicará a todas las conexiones realizadas y cuando reinicies el servicio de MySQL o todo el servidor el cambio NO se aplicará. Para que el cambio sea definitivo debes añadir este parámetro al fichero de configuración de MySQL (my.cnf en Linux).
MensajePublicado:
Mie Oct 24, 2012 6:37 am
Top of PageVer perfil de usuario
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Re: Cambiar valor variable global en MySQL en caliente Responder citando



Anuncios



alonsojpd escribió:

Sí puedes cambiarlo online siempre que se trate de una variable dinámica y max_connections lo es. Para cambiarlo abre una ventana de terminal (si estás en Linux) o un consola de MS-DOS (si estás en Windows) y conéctate a MySQL Server mediante "mysql", sería algo así:

Código:

mysql --user="root" --password="contraseña"


si no te funciona el comando "mysql" ejecútalo desde la carpeta de MySQL, en Linux suele ser:

/var/lib/mysql

Una vez conectado a MySQL con MySQL monitor, ejecuta este comando para ver el valor actual del parámetro a modificar:

Código:

show variables like "max_connections";


Ahora puedes modificarlo en caliente (online) por trtarse de una variable dinámica, para ello ejecuta el comando:

Código:

set global max_connections=2000;


Para asegurarte de que el valor se ha modificado puedes volver a ejecutar:

Código:

show variables like "max_connections";


Es importante mencionar que cuando estableces el valor de una variable de MySQL con "set global ..." el cambio se aplicará a todas las conexiones realizadas y cuando reinicies el servicio de MySQL o todo el servidor el cambio NO se aplicará. Para que el cambio sea definitivo debes añadir este parámetro al fichero de configuración de MySQL (my.cnf en Linux).



Muchas gracias, ya lo he hecho y parece que funciona. Tendré en cuenta tu último comentario, es importante porque reiniciamos este servidor una vez cada 6 meses de forma programada, si no me anoto esto tendría el mismo problema cuando lo reinicie.

¿Se puede añadir este parámetro a ese fichero de configuración en caliente aunque no se aplique? así ya lo tengo para el próximo reinicio y no se me olvida modificarlo.
MensajePublicado:
Mie Oct 24, 2012 6:53 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: [RESUELTO] Cambiar valor variable global en MySQL online Responder citando



Anuncios



varios escribió:
Muchas gracias, ya lo he hecho y parece que funciona. Tendré en cuenta tu último comentario, es importante porque reiniciamos este servidor una vez cada 6 meses de forma programada, si no me anoto esto tendría el mismo problema cuando lo reinicie.

¿Se puede añadir este parámetro a ese fichero de configuración en caliente aunque no se aplique? así ya lo tengo para el próximo reinicio y no se me olvida modificarlo.


Sí puedes añadirlo en caliente, no se aplicará hasta que no reinicies el servidor, pero no hay problema en editar el fichero my.cnf y añadir el parámetro (o modificarlo si ya existe).
MensajePublicado:
Mie Oct 24, 2012 6:55 am
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » MySQL Server, MySQL Client, motor de bd gratuito  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A