Apache httpd CentOS Certificate not verified: 'Server-Cert'
En CentOS, si de repente tenéis el servidor web caido y os sale este error en /var/log/nss_error_log es porque está instalado el módulo mod_nss y aunque el httpd no lo está cargando, detecta que el certificado de prueba que instala nss automáticamente está caducado.
La solución es desinstalar el móduloyum remove mod_nss
Ejemplo de error: [Mon Apr 29 13:37:24 2013] [error] Certificate not verified: 'Server-Cert'
[Mon Apr 29 13:37:24 2013] [error] SSL Library Error: -8181 Certificate has expired
[Mon Apr 29 13:37:24 2013] [error] Unable to verify certificate 'Server-Cert'. Add "NSSEnforceValidCerts off" to nss.conf so the server can start until the problem can be resolved.
Bug en RH:
https://bugzilla.redhat.com/show_bug.cgi?format=multiple&id=711085
Backup de los procedimientos almacenados mysql
El mysqldump no copia los stored procedures por defecto pero si los triggers, es decir, los parámetros por defecto son:
--routines FALSE por defecto
--triggers TRUE por defecto
Para volcar sólo los procedimientos almacenados:
mysqldump --routines --no-create-info --no-data --no-create-db --skip-opt database > procedimientos.sql
mysql database < procedimientos.sql
mysqldump --routines outputfile.sql
Fuente:
http://www.ducea.com/2007/07/25/dumping-mysql-stored-procedures-functions-and-triggers/
Depurar procedimientos almacenados mysql
Depurar procedimientos de bases de datos suele ser una tarea ingrata a no ser que tengamos alguna herramienta de desarrollo. Pero aún estas herramientas suelen modificar internamente el procedimiento para efectuar el depurado además de crear multitud de tablas intermedias para guardar el estado de las variables en cualquier punto de la ejecución.
Si no te interesa este enfoque y sólo necesitas ir haciendo un log de lo que ocurre propongo el siguiente sistema que he ido mejorando a partir de diversas fuentes y experiencias.
La idea se basa en la creación de una tabla temporal donde vamos realizando el log mediante una llamada al procedimiento doLog(msg).
Primero creamos una tabla de configuración:
CREATE TABLE `internal_config` (
`debug` tinyint(4) NOT NULL DEFAULT '1'
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
insert into internal_config(debug) values(0);
Que nos servirá para activar/desactivar el debug con:
update internal_config set debug=true;
El procedimiento que crea la tabla temporal es:
CREATE PROCEDURE `setupTmpLog`()
BEGIN
CREATE TEMPORARY TABLE IF NOT EXISTS tmplog(
lin integer NOT NULL AUTO_INCREMENT primary key,
msg VARCHAR(512)
) ENGINE = MEMORY;
END
y el que escribe el log:
CREATE PROCEDURE `doLog`(IN logMsg VARCHAR(512))
BEGIN
declare do_debug bool default false;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET do_debug=false;
DECLARE CONTINUE HANDLER FOR 1146 -- Table not found
BEGIN
CALL setupTmpLog();
INSERT INTO tmplog(msg) VALUES ('resetup tmp table');
INSERT INTO tmplog(msg) VALUES (logMsg);
END;
select debug from internal_config limit 1 into do_debug;
-- escribimos en el log solo si debug esta activado
if (do_debug) then
INSERT INTO tmplog(msg) VALUES (logMsg);
end if;
END
y finalmente, un procedimiento que nos muestra el log (con el último mensaje primero) y después borra la tabla:
CREATE PROCEDURE `view_log`()
BEGIN
DECLARE CONTINUE HANDLER FOR 1146 -- Table not found
BEGIN
CALL setupTmpLog();
end;
select msg from tmplog order by lin desc;
drop table tmplog;
END
Ya lo tenemos todo, para ir logeando en nuestros procedimientos sólo tenemos que llamar a doLog así:
call doLog(concat("Hola", " que ", " tal " ));
Y cuando queramos ver (y limpiar) el log hacemos:
call view_log();
Espero que os sirva. Good Luck ;-)
Fuentes:
http://www.drdobbs.com/database/debugging-mysql-stored-procedures/218100564?pgno=1
ebooks de ingeniería
Estos sitios tienen libros interesantes de ingeniería. Si alguno de ellos te interesa, puedes adquirirlos legalmente en las librerías especializadas:
http://bookos.org (sitio ruso, tienen de todo)
http://ieee-books.blogspot.com.es (brutal)
http://es.scribd.com (conocido sitio para compartir pdf)
http://freelibros.org
Problemas resueltos:
http://www.loseskakeados.com
Foros teleco:
http://www.foroteleco.com
http://www.lacomunateleco.com/descargas
http://teleco.apuntesulpgc.es
http://www.gradotelecovigo.com/
Vídeos y otros recursos:
Open courseware upv:
http://www.upv.es/contenidos/OCW/menu_urlc.html?http://www.upv.es/pls/oalu/sic_asi.OCW_Ramasi?p_rama=T&p_idioma=c&p_vista=MSE
http://users.alliedmods.net/~faluco/apuntespak/