2009-12-30 15 views
35

Estoy usando Wampserver versión 2.0. Cuando intento importar un archivo sql, ya sea a través de MySQL Query Browser o PHPMyAdmin, aparece el siguiente error.# 2006 El servidor MySQL se ha ido error en Wamp

Error 2006: MySQL Server has gone away. 

El tamaño del archivo es 54,528 KB.

En C: \ wamp \ bin \ mysql \ mysql5.1.30 \ mi.ini, configuro max_allowed_packet a 100M en [mysqldump] y [wampmysqld]. No pude encontrar la variable wait_timeout en my.ini. ¿Alguna forma de solucionar este problema? Para su referencia, he dado a continuación los contenidos del archivo my.ini.

# Example MySQL config file for medium systems. 
# 
# This is for a system with little memory (32M - 64M) where MySQL plays 
# an important part, or systems up to 128M where MySQL is used together with 
# other programs (such as a web server) 
# 
# You can copy this file to 
# /etc/my.cnf to set global options, 
# mysql-data-dir/my.cnf to set server-specific options (in this 
# installation this directory is C:\mysql\data) or 
# ~/.my.cnf to set user-specific options. 
# 
# In this file, you can use all long options that a program supports. 
# If you want to know which options a program supports, run the program 
# with the "--help" option. 

# The following options will be passed to all MySQL clients 
[client] 
#password = your_password 
port  = 3306 
socket  = /tmp/mysql.sock 

# Here follows entries for some specific programs 

# The MySQL server 
[wampmysqld] 
port  = 3306 
socket  = /tmp/mysql.sock 
skip-locking 
key_buffer = 16M 
max_allowed_packet = 100M 
table_cache = 64 
sort_buffer_size = 512K 
net_buffer_length = 8K 
read_buffer_size = 256K 
read_rnd_buffer_size = 512K 
myisam_sort_buffer_size = 8M 
basedir=c:/wamp/bin/mysql/mysql5.1.30 
log-error=c:/wamp/logs/mysql.log 
datadir=c:/wamp/bin/mysql/mysql5.1.30/data 

# Don't listen on a TCP/IP port at all. This can be a security enhancement, 
# if all processes that need to connect to mysqld run on the same host. 
# All interaction with mysqld must be made via Unix sockets or named pipes. 
# Note that using this option without enabling named pipes on Windows 
# (via the "enable-named-pipe" option) will render mysqld useless! 
# 
#skip-networking 

# Disable Federated by default 
skip-federated 

# Replication Master Server (default) 
# binary logging is required for replication 
log-bin=mysql-bin 

# binary logging format - mixed recommended 
binlog_format=mixed 

# required unique id between 1 and 2^32 - 1 
# defaults to 1 if master-host is not set 
# but will not function as a master if omitted 
server-id = 1 

# Replication Slave (comment out master section to use this) 
# 
# To configure this host as a replication slave, you can choose between 
# two methods : 
# 
# 1) Use the CHANGE MASTER TO command (fully described in our manual) - 
# the syntax is: 
# 
# CHANGE MASTER TO MASTER_HOST=<host>, MASTER_PORT=<port>, 
# MASTER_USER=<user>, MASTER_PASSWORD=<password> ; 
# 
# where you replace <host>, <user>, <password> by quoted strings and 
# <port> by the master's port number (3306 by default). 
# 
# Example: 
# 
# CHANGE MASTER TO MASTER_HOST='125.564.12.1', MASTER_PORT=3306, 
# MASTER_USER='joe', MASTER_PASSWORD='secret'; 
# 
# OR 
# 
# 2) Set the variables below. However, in case you choose this method, then 
# start replication for the first time (even unsuccessfully, for example 
# if you mistyped the password in master-password and the slave fails to 
# connect), the slave will create a master.info file, and any later 
# change in this file to the variables' values below will be ignored and 
# overridden by the content of the master.info file, unless you shutdown 
# the slave server, delete master.info and restart the slaver server. 
# For that reason, you may want to leave the lines below untouched 
# (commented) and instead use CHANGE MASTER TO (see above) 
# 
# required unique id between 2 and 2^32 - 1 
# (and different from the master) 
# defaults to 2 if master-host is set 
# but will not function as a slave if omitted 
#server-id  = 2 
# 
# The replication master for this slave - required 
#master-host  = <hostname> 
# 
# The username the slave will use for authentication when connecting 
# to the master - required 
#master-user  = <username> 
# 
# The password the slave will authenticate with when connecting to 
# the master - required 
#master-password = <password> 
# 
# The port the master is listening on. 
# optional - defaults to 3306 
#master-port  = <port> 
# 
# binary logging - not required for slaves, but recommended 
#log-bin=mysql-bin 

# Point the following paths to different dedicated disks 
#tmpdir  = /tmp/  
#log-update  = /path-to-dedicated-directory/hostname 

# Uncomment the following if you are using InnoDB tables 
#innodb_data_home_dir = C:\mysql\data/ 
#innodb_data_file_path = ibdata1:10M:autoextend 
#innodb_log_group_home_dir = C:\mysql\data/ 
#innodb_log_arch_dir = C:\mysql\data/ 
# You can set .._buffer_pool_size up to 50 - 80 % 
# of RAM but beware of setting memory usage too high 
#innodb_buffer_pool_size = 16M 
#innodb_additional_mem_pool_size = 2M 
# Set .._log_file_size to 25 % of buffer pool size 
#innodb_log_file_size = 5M 
#innodb_log_buffer_size = 8M 
#innodb_flush_log_at_trx_commit = 1 
#innodb_lock_wait_timeout = 50 

[mysqldump] 
quick 
max_allowed_packet = 100M 

[mysql] 
no-auto-rehash 
# Remove the next comment character if you are not familiar with SQL 
#safe-updates 

[isamchk] 
key_buffer = 20M 
sort_buffer_size = 20M 
read_buffer = 2M 
write_buffer = 2M 

[myisamchk] 
key_buffer = 20M 
sort_buffer_size = 20M 
read_buffer = 2M 
write_buffer = 2M 

[mysqlhotcopy] 
interactive-timeout 

[mysqld] 
port=3306 
+3

intente reiniciar el servidor mysql – Krunal

+1

Gracias Krunal, eso lo solucionó! :) – john

+0

posible duplicado de [MySQL error 2006: el servidor mysql se ha ido] (http://stackoverflow.com/questions/7942154/mysql-error-2006-mysql-server-has-gone-away) –

Respuesta

62

Estoy usando XAMPP en Windows y tuve el mismo problema. Pensé que era la variable de tiempo de espera pero era max_allowed_packet.

Esto ha arreglado:

# note the change was made at this section 
[mysqld] 
port= 3306 
socket= "/xampp/mysql/mysql.sock" 
basedir="/xampp/mysql" 
tmpdir="/xampp/tmp" 
datadir="/xampp/mysql/data" 
skip-locking 
key_buffer = 16M 
# it was 1M by default 
max_allowed_packet = 2M 
table_cache = 64 
sort_buffer_size = 512K 
net_buffer_length = 8K 
read_buffer_size = 256K 
read_rnd_buffer_size = 512K 
myisam_sort_buffer_size = 8M 

Este archivo de configuración se encuentra en «XAMPP directorio de instalación, esto esC:\XAMPPpor defecto»\mysql\bin\my.ini.

+3

Esta respuesta ayudó yo también, pero para esa gente muy nueva para desarrollar un proceso como yo, agregaré que este archivo se llama "my.ini" y se debe buscar en esta posición "C: \ xampp \ mysql \ bin \ my.ini" - Además , Le sugiero que configure el max_allowed_packet = 10M porque si usa drupal 7 como yo, alguna tabla puede tener un caché de gran tamaño. – wocmultimedia

+0

Sí, eso es todo, esto sucede cuando creo que las filas individuales son demasiado grandes. +1 –

+3

Sí, hacer key_buffer y max_allowed_packet 16M generalmente resuelve este problema. –

5

Estoy usando Xampp 1.7.7 en Windows 7 y tuve el mismo problema también. El abajo es lo arreglaron:

  • Aumentar valor mysql.connect_timeout:
    ; Tiempo máximo (en segundos) para el tiempo de espera de conexión. -1 significa sin límite
    ; http://php.net/mysql.connect-timeout
    mysql.connect_timeout = 10; era 3 de forma predeterminada

  • Probé lo que hice antes y tengo otro problema sobre 'max_allowed_packet'.

  • Vaya a mysql \ bin \ my.ini y busque la configuración max_allowed_packet = 1M, luego cámbiela a 10M: max_allowed_packet = 10M; Era 1M por defecto

Espero que esto ayude.

Duc

2

PhpMyAdmin Documentación:

1.16 No puedo subir grandes archivos de volcado de memoria (problemas, HTTP o de tiempo de espera).

A partir de la versión 2.7.0, el motor de importación ha sido reescrito y estos problemas no deberían ocurrir. Si es posible, actualice su phpMyAdmin a la última versión para aprovechar las nuevas funciones de importación.

Las primeras cosas a comprobar (o pregunte a su proveedor de alojamiento para comprobar) son los valores de upload_max_filesize, memory_limit y post_max_size en el archivo de configuración php.ini. Todas estas tres configuraciones limitan el tamaño máximo de los datos que PHP puede enviar y gestionar. Un usuario también dijo que post_max_size y memory_limit deben ser mayores que upload_max_filesize.

Existen varias soluciones si su carga es demasiado grande o su proveedor de alojamiento no está dispuesto a cambiar la configuración:

Mira el $ cfg [ 'uploaddir'] función. Esto le permite cargar un archivo al servidor a través de scp, ftp o su método de transferencia de archivos favorito. PhpMyAdmin puede importar los archivos desde el directorio temporal. Más información está disponible en la sección Configuración de este documento.

Uso de una utilidad (como BigDump) para dividir los archivos antes de cargarlos. No podemos admitir esta o ninguna aplicación de terceros, pero somos conscientes de que los usuarios tienen éxito con ella.

Si tiene acceso de shell (línea de comandos), use MySQL para importar los archivos directamente. Puede hacer esto al emitir el comando "fuente" desde MySQL: source filename.sql.

1

PARA AQUELLOS DESARROLLADORES QUE UTILIZAN Mac OSX, tendrá que cambiar el max_allowed_packet de 1M a 10M dentro del archivo "my.cnf".

max_allowed_packet = 10M 

Es probable que encuentre el archivo "my.cnf" en una de estas ubicaciones:

  1. /etc/my.cnf (ubicación más probable PARA USUARIOS Mavericks)
  2. /etc/mysql/my.cnf
  3. SYSCONFDIR/my.cnf
  4. $ MYSQL_HOME/my.cnf
  5. defecto-extra-file (el archivo especificado con --defaults-extra-file = ruta, si existe)
  6. ~/.my.cnf
1

Pasos para MySQL error de solución de 2006:

  1. Editar el archivo “my.ini” que se encuentra en “: \ xampp \ mysql \ bin \”.
  2. En el archivo my.ini, edite el "max_allowed_packet" aumentando el valor.
    • El valor predeterminado de XAMPP es 1M. Lo actualicé a 10M.
  3. Guarde el archivo my.ini.
  4. Reinicia tu servidor MySQL y Apache en XAMPP.
4

Esto puede ser debido a max_allowed_packet

Cambio en el archivo my.ini/my.cnf. Incluir la línea single bajo [mysqld] en su archivo

max_allowed_packet=500M 

Ahora reinicie el MySQL service vez que haya terminado. Se puede ver su valor curent en MySQL como esto:

SHOW VARIABLES LIKE 'max_allowed_packet' 

se puede leer sobre ello aquí http://dev.mysql.com/doc/refman/5.1/en/packet-too-large.html

0

me di cuenta de este error al actualizar desde la versión de Magento xay. Al mirar los registros vi que había un problema en una mesa.

[ERROR] Índice UNQ_DH_CORE_URL_REWRITE_REQUEST_PATH_STORE_ID de databaseabc/core_url_rewrite tiene 2 columnas únicas dentro de InnoDB, pero MySQL está pidiendo estadísticas para 3 columnas. ¿Has mezclado archivos .frm de diferentes instalaciones? Ver http://dev.mysql.com/doc/refman/5.1/en/innodb-troubleshooting.html

Al arreglar esta tabla se solucionó el problema. En mi caso, podría truncar la tabla, ya que era un índice que podría generarse nuevamente.

0

Si el aumenta el tamaño de la memoria las respuestas no funcionan para usted, verifique su código en un bucle infinito.

Eso es lo que tenía en mi código que agotó mi memoria sin importar a qué la aumentara. El rastro de la pila da buenas pistas, ¡asegúrate debugging is turned on, al menos localmente!

Cuestiones relacionadas