Ir al contenido principal

MySQL [ERROR] Cannot find or open table

En este caso en particular voy a hablar de un error que aparece cuando haces un respaldo de manera errada de MySQL, específicamente con las tablas INODB.

Muchos usuarios de MySQL acostumbran a mover tablas de una base de datos a otra simplemente copiando los archivos de un lado a otro, lo cual si bien no es el mejor método funciona sin problemas para las tablas MyISAM, sin embargo si hacemos esto para las tablas INODB la cosa no resulta bien y seguramente tendras un error del tipo [ERROR] Cannot find or open table "XXX/xxxx" aunque la misma exista y tenga los permisos y usuarios correctos.

Que hacer en este caso, bueno en mi experiencia en particular se resolvió el problema de manera sencilla (bueno después de googlear un rato) puesto que también había copiado el archivo ibdata1 que se encuentra en la raíz de mysql (usualmente /var/lib/mysql). Los pasos que realice fueron:
  1. Detener el mysql
  2. Remover el ibdata1 (de la nueva instalación)
  3. Copiar el ibdata1 de la instalación anterior (solo este archivo)
  4. Revisar los permisos (664) y usuarios (mysql:mysql) sean correctos
  5. Reiniciar el mysql
Con esto quedo resuelto el problema, otra cosa importante es  que en mi caso también estaba usando el parámetro innodb_file_per_table en la instalación anterior por lo que es necesario tener esto habilitado en el my.cnf antes de reiniciar el servicio.

En el caso que no tengas el ibdata1 viejo, la cosa se pone más complicada por lo que pude leer y probar hasta cierto punto (cuando me di cuenta que lo podía hacer de la forma anterior pues lo deje así), en todo caso lo que se debe hacer se explica en http://www.chriscalender.com/?p=28

Espero que esta información sea de ayuda.

Comentarios

Entradas más populares de este blog

Recuperar GRUB 2 EFI utilzando rEFInd

Recientemente tuve un problema con un laptop dual-boot (widows/linux) al actualizar el Windosw 8.1 a 10. 
En una de las tantas reiniciadas de windows me quede sin el gestor de arranque grub, por lo que les explico como hice para recuperarlo, finalizar la actualización y dejar intacto mi querido debian.
Se que se puede recuperar el grub con una distro live y seguir algunos pasos, pero como comente la actualización a windows 10 aun no terminaba así que no quería tener que hacer esto a cada rato por lo que me decidí a probar rEFInd.

Lo primero es decidir que imagen utilizar, yo tenia a disposición un viejo USB de 512M así que baje la imagen A USB flash drive image file (les recomiendo revisar la web por si existe una nueva versión)

Una vez descargado el archivo podemos copiarlo al USB, para lo que utilizaremos el comando dd. Esto borrara toda la información que tenían en el mismo. root@lenovoG480 #~ dd if=refind-flashdrive-0.9.0.img of=/dev/sdg1

13696+0 registros leídos
13696+0 reg…

Configurar el DDNS de HE

Si necesitas utilizar un servicio de DNS dinamico gratuito y te aburriste de noip o similares, el servicio ofrecido Hurrican Electrics (HE) es una buena alternativa (https://dns.he.net).

Una vez que te registras y creas tu dominio, debes agregar el registro tipo A o AAAA (si funciona para IPv6) para tu servidor

Acá unas capturas del proceso








 Con esto tenemos listo el registro dinamico para que sea actualizado desde nuestro equipo, existen varias formas para esto como se puede ver en la pagina de HE, pero lo mas sencillo es con un cliente como ddclient

En debian, es tan fácil como:

aptitude install ddclient ó apt-get install ddclient

luego editamos el archivo /etc/ddclient.conf y debe quedar así

Es la configuración a usar si tu ip dinamica es publica de lo contrario utiliza la del ejemplo de windows

# Hurricane Electric
# dyn.dns.he.net
protocol=dyndns2    # default
use=if                          # use the eithernet card (to get the current IP)
if=eth0                         # use certa…

Instalar Icinga2 en debian Wheezy con BD Postgres

A continuación les dejo una guía rápida para la instalación de Icinga2 en debian wheezy,  cuando tenga que hacerlo en jessie actualizo el manual.

Lo primero que debes tener en cuenta es que en la pagina de Icinga tienes bastante documentación sobre como hacer esto mismo, de hecho este manual esta basado en lo que allí aparece. Otro detalle es que parto de la idea que ya tienes configurado Apache2 y Postgres

Comencemos por agregar los repositorios necesarios.

Debian Monitoring Project

~# echo "deb http://debmon.org/debmon debmon-wheezy main" > /etc/apt/sources.list.d/wheezy-debmon.list
~# wget -O - http://debmon.org/debmon/repo.key 2>/dev/null | apt-key add - OK
Según lo referido en esta pagina es posible que existan problemas de dependencias con icinga2 así que es recomendable agregar también el repositorio backports

Debian Backports

~# echo "deb http://http.debian.net/debian wheezy-backports main" > /etc/apt/sources.list.d/wheezy-backports.list
Recuerda que…