Proyecto movido a GitHub
Miér 7 Abr 2021 - 19:23 por bittor
Proyecto movido a GitHub:
https://github.com/bittor7x0/VDR-M7x0
Con muchos cambios y correcciones, Más información
También incluye el plugin epgfixer para corregir la EPG usando expresiones regulares y el plugin xmltv2vdr para descargar la EPG de internet
https://github.com/bittor7x0/VDR-M7x0
Con muchos cambios y correcciones, Más información
También incluye el plugin epgfixer para corregir la EPG usando expresiones regulares y el plugin xmltv2vdr para descargar la EPG de internet
Comentarios: 0
Buscar
Mejoras arranque Mediatomb
2 participantes
Página 1 de 1.
Mejoras arranque Mediatomb
Hola a todos,
Quería contribuir con un granito de arena con una pequeña "peora" en el arranque del Mediatomb de nuestro querido VDR.
Me explico, si no estoy equivocado actualmente el mediatomb requiere para su arranque, además de activarlo en la variable mediatomb_start del rc.local.conf, el que tengamos activo un disco en uno de los puertos USB (primero comprueba si está activo el sda1 y en caso negativo lo intenta con el sda2). El script que se ejecuta en el arranque es /usr/bin/start_mediatomb
Las comprobaciones de estos dispositivos se reintentan un máximo de 10 veces dejando tres segundos entre comprobación y comprobación. O eso es lo que aparentemente se pretende, pero hay una errata y si no se cumplen las condiciones (no hay ningún disco conectado a los puertos usb, aunque el mediatomb se activó en el rc.local.conf) el script se queda "eternamente" reintentando. Ello es debido a que la sentencia:
debería ser:
Al margen de esta pequeña errata, esta configuración excluye el uso como medio para grabar/reproducir un disco conectado por red y en caso de que tengamos dos discos pinchados por cualquier circunstancia, siempre será el sda1 el que tomará para almacenar la información con la base de datos que requiere el mediatomb.
En realidad fue así como me di cuenta de la errata que antes mencioné, por razones varias, he decidido quitar el disco que utilizaba con el Giga (lo requiero para otra cosa) y utilizar una carpeta de red a la que accedo con CIFS. Me di cuenta que el mediatomb no me funcionaba y tirando, tirando del hilo, fue cuando descubrí este script y además me di cuenta que se quedaba en un bucle infinito porque la condición de finalización no se cumplía por el problema que he mencionado. De paso vi que nunca tendría en cuenta mi directorio de red.
He creado un nuevo script que como no puede sustituir al anterior puesto que está en una partición read only, lo he colocado en /etc/mediatomb/start_mediatomb y he modificado rc.local.net, para que el directorio de arranque del script sea /etc/mediatomb/ en vez del /usr/bin/
Este nuevo script lo he basado en el directorio de grabaciones que tenemos configurado en la variable vdr_videodirs del rc.local.conf. Es decir, si dicha variable no es nula, compruebo si ese directorio está montado en "algún sitio", ya sea un disco conectado a USB (con independencia de que sea el sda1 o el sda2) o en red. Por lo demás, hago una comprobación similar a la anterior, es decir, entro en un bucle para dar tiempo a los retardos que pueda haber en los montajes (pero corrigiendo la errata claro). El resto es prácticamente igual a lo que hacía el anterior script (he añadido un mensaje al log cuando todo ha ido bien indicando que el mediatomb ha quedado activo).
A mi me está funcionando bien y si os agrada la idea y dado que según indicó bittor tiene pensado liberar una nueva versión, quizá pueda ser interesante utilizarlo, o tomarlo como base con los cambios que se os ocurran, para incluirlo en la nueva versión.
Un saludo a todos y ¡larga vida a nuestros Gigas!
Adjunto el script completo:
Quería contribuir con un granito de arena con una pequeña "peora" en el arranque del Mediatomb de nuestro querido VDR.
Me explico, si no estoy equivocado actualmente el mediatomb requiere para su arranque, además de activarlo en la variable mediatomb_start del rc.local.conf, el que tengamos activo un disco en uno de los puertos USB (primero comprueba si está activo el sda1 y en caso negativo lo intenta con el sda2). El script que se ejecuta en el arranque es /usr/bin/start_mediatomb
Las comprobaciones de estos dispositivos se reintentan un máximo de 10 veces dejando tres segundos entre comprobación y comprobación. O eso es lo que aparentemente se pretende, pero hay una errata y si no se cumplen las condiciones (no hay ningún disco conectado a los puertos usb, aunque el mediatomb se activó en el rc.local.conf) el script se queda "eternamente" reintentando. Ello es debido a que la sentencia:
- Código:
if [ ! -z $DISK_VOLUME -o $NUM_CYCLES -eq 10 ]; then
debería ser:
- Código:
if [ ! -z "$DIR_MOUNT" -o ${NUM_CYCLES} -eq 10 ]; then
Al margen de esta pequeña errata, esta configuración excluye el uso como medio para grabar/reproducir un disco conectado por red y en caso de que tengamos dos discos pinchados por cualquier circunstancia, siempre será el sda1 el que tomará para almacenar la información con la base de datos que requiere el mediatomb.
En realidad fue así como me di cuenta de la errata que antes mencioné, por razones varias, he decidido quitar el disco que utilizaba con el Giga (lo requiero para otra cosa) y utilizar una carpeta de red a la que accedo con CIFS. Me di cuenta que el mediatomb no me funcionaba y tirando, tirando del hilo, fue cuando descubrí este script y además me di cuenta que se quedaba en un bucle infinito porque la condición de finalización no se cumplía por el problema que he mencionado. De paso vi que nunca tendría en cuenta mi directorio de red.
He creado un nuevo script que como no puede sustituir al anterior puesto que está en una partición read only, lo he colocado en /etc/mediatomb/start_mediatomb y he modificado rc.local.net, para que el directorio de arranque del script sea /etc/mediatomb/ en vez del /usr/bin/
Este nuevo script lo he basado en el directorio de grabaciones que tenemos configurado en la variable vdr_videodirs del rc.local.conf. Es decir, si dicha variable no es nula, compruebo si ese directorio está montado en "algún sitio", ya sea un disco conectado a USB (con independencia de que sea el sda1 o el sda2) o en red. Por lo demás, hago una comprobación similar a la anterior, es decir, entro en un bucle para dar tiempo a los retardos que pueda haber en los montajes (pero corrigiendo la errata claro). El resto es prácticamente igual a lo que hacía el anterior script (he añadido un mensaje al log cuando todo ha ido bien indicando que el mediatomb ha quedado activo).
A mi me está funcionando bien y si os agrada la idea y dado que según indicó bittor tiene pensado liberar una nueva versión, quizá pueda ser interesante utilizarlo, o tomarlo como base con los cambios que se os ocurran, para incluirlo en la nueva versión.
Un saludo a todos y ¡larga vida a nuestros Gigas!
Adjunto el script completo:
- Código:
#!/bin/ash
set -o nounset
CONTINUE_WAITING="TRUE"
NUM_CYCLES=0
VIDEO_DIR=$(grep vdr_videodirs= /etc/rc.local.conf 2>/dev/null | cut -d'"' -f2)
if [ -z "${VIDEO_DIR}" ]; then
logger -s -p user.err Mediatomb necesita la configuracion del directorio de videos
exit 1
fi
while [ $CONTINUE_WAITING == "TRUE" ]; do
DIR_MOUNT=$(mount | grep $VIDEO_DIR 2>/dev/null | cut -d' ' -f1)
if [ ! -z "$DIR_MOUNT" -o ${NUM_CYCLES} -eq 10 ]; then
CONTINUE_WAITING="FALSE"
else
NUM_CYCLES=$(expr $NUM_CYCLES + 1)
sleep 3
fi
done
if [ -z "$DIR_MOUNT" ]; then
logger -s -p user.err Mediatomb no dispone del directorio de los videos
exit 1
fi
if [ ! -d $VIDEO_DIR/mediatomb ]; then
mkdir $VIDEO_DIR/mediatomb || exit 2
fi
if [ ! -f $VIDEO_DIR/mediatomb/mediatomb.db ]; then
cp /etc/mediatomb/mediatomb.db $VIDEO_DIR/mediatomb/mediatomb.db
fi
cp /etc/mediatomb/config.xml $VIDEO_DIR/mediatomb/
/usr/bin/mediatomb -p 49152 -m $VIDEO_DIR -f mediatomb -P /var/run/mediatomb.pid &
logger -s -p user.info El servicio Mediatomb queda activado
alazan- Cantidad de envíos : 10
Fecha de inscripción : 17/11/2012
Localización : Madrid
Re: Mejoras arranque Mediatomb
Hola,
el script "start-mediatomb" lo modifiqué hace años para poder usar discos de red, pero fue posterior a la versión 0.7 (por eso tienes la versión vieja).
¿Puedes bajarte la versión actualizada de aquí y decirme si te funciona correctamente?
A ver si la semana que viene termino de hacer el traspaso a GitHub con todos los cambios que tengo pendientes.
Uno de los cambios tiene que ver con ese script porque he extraído la parte que establece la variable del directorio de grabación en otro script para poder usarlo desde otros scripts para guardar datos relativos con la EPG.
el script "start-mediatomb" lo modifiqué hace años para poder usar discos de red, pero fue posterior a la versión 0.7 (por eso tienes la versión vieja).
¿Puedes bajarte la versión actualizada de aquí y decirme si te funciona correctamente?
A ver si la semana que viene termino de hacer el traspaso a GitHub con todos los cambios que tengo pendientes.
Uno de los cambios tiene que ver con ese script porque he extraído la parte que establece la variable del directorio de grabación en otro script para poder usarlo desde otros scripts para guardar datos relativos con la EPG.
Re: Mejoras arranque Mediatomb
¡Vaya, estoy desfasado!
He probado el script que me indicas y tiene alguna pequeña errata. He tenido que poner alguna traza para ver el problema.
El dispositivo de red no estaba disponible cuando se intenta el arranque del mediatomb. Eso no debería representar un problema porque se supone que está prevista esa circunstancia y hace hasta diez reintentos.
La pega es que debido a la sentencia "set -o nounset", si una variable no se ha definido previamente no estará disponible ni para preguntar si tiene contenido, ello provoca un error que detiene el script.
Y eso precisamente lo que ocurre cuando en la primera iteración del bucle, al no estar la red disponible, tampoco lo está el directorio y a la variable DISK_VOLUME no se le dará valor, luego al preguntar si dicha variables está vacía en if [ ! -z $DISK_VOLUME ]; then, se produce un error y finaliza la ejecución.
Para evitarlo, he inicializado la variable al inicio del script con DISK_VOLUME=""
De todas formas, al volver a probar, ha seguido sin funcionar porque parece ser que en la shell "ash" da algún problema la sentencia for i in {1..10}; do (aunque en bash si funciona correctamente).
Reconozco que no me he complicado mucho la vida, he sustituido esa sentencia por for i in 1 2 3 4 5 6 7 8 9 10; do ¡y así ya ha funcionado! En la segunda iteración del bucle el directorio ya está disponible y el mediatomb arranca con normalidad.
Lo que si sugiero en cualquier caso es mandar un mensajito al log indicado que el mediatomb se arranca cuando ello se produzca, así si se está analizando alguna situación extraña, en el log veremos que se ha producido esa circunstancia, por si fuera importante.
¡¡Gracias por tu ayuda bittor!!
He probado el script que me indicas y tiene alguna pequeña errata. He tenido que poner alguna traza para ver el problema.
El dispositivo de red no estaba disponible cuando se intenta el arranque del mediatomb. Eso no debería representar un problema porque se supone que está prevista esa circunstancia y hace hasta diez reintentos.
La pega es que debido a la sentencia "set -o nounset", si una variable no se ha definido previamente no estará disponible ni para preguntar si tiene contenido, ello provoca un error que detiene el script.
Y eso precisamente lo que ocurre cuando en la primera iteración del bucle, al no estar la red disponible, tampoco lo está el directorio y a la variable DISK_VOLUME no se le dará valor, luego al preguntar si dicha variables está vacía en if [ ! -z $DISK_VOLUME ]; then, se produce un error y finaliza la ejecución.
Para evitarlo, he inicializado la variable al inicio del script con DISK_VOLUME=""
De todas formas, al volver a probar, ha seguido sin funcionar porque parece ser que en la shell "ash" da algún problema la sentencia for i in {1..10}; do (aunque en bash si funciona correctamente).
Reconozco que no me he complicado mucho la vida, he sustituido esa sentencia por for i in 1 2 3 4 5 6 7 8 9 10; do ¡y así ya ha funcionado! En la segunda iteración del bucle el directorio ya está disponible y el mediatomb arranca con normalidad.
Lo que si sugiero en cualquier caso es mandar un mensajito al log indicado que el mediatomb se arranca cuando ello se produzca, así si se está analizando alguna situación extraña, en el log veremos que se ha producido esa circunstancia, por si fuera importante.
¡¡Gracias por tu ayuda bittor!!
alazan- Cantidad de envíos : 10
Fecha de inscripción : 17/11/2012
Localización : Madrid
Re: Mejoras arranque Mediatomb
Gracias por probarlo tan rápido.
Supongo que los errores que te ha dado ha sido porque el BusyBox es otra versión y ash también.
En la nueva versión he actualizado todos los programas, entre ellos BusyBox, así que a ver si la semana que viene subo una versión para probarla y detectar errores o mejorarla.
Supongo que los errores que te ha dado ha sido porque el BusyBox es otra versión y ash también.
En la nueva versión he actualizado todos los programas, entre ellos BusyBox, así que a ver si la semana que viene subo una versión para probarla y detectar errores o mejorarla.
Re: Mejoras arranque Mediatomb
Buenas tardes Bittor,
es muy probable que como indicas, el problema del "for" se solucione con otra versión del busybox, puesto que como comenté al menos en bash la sintaxis que has utilizado funcionaría correctamente.
Pero mucho me temo que lo de inicializar la variable sí has de hacerlo, puesto que el comportamiento es precisamente el que se espera si utilizas "set -o nounset".
Como ya te indiqué cuando me ayudaste a recuperar mi VDR, si necesitas colaboración con la nueva versión (pruebas, sugerencias, ..., y todo aquello que buenamente pueda) estoy a tu disposición.
¡¡Disfruta del fin de semana!!
es muy probable que como indicas, el problema del "for" se solucione con otra versión del busybox, puesto que como comenté al menos en bash la sintaxis que has utilizado funcionaría correctamente.
Pero mucho me temo que lo de inicializar la variable sí has de hacerlo, puesto que el comportamiento es precisamente el que se espera si utilizas "set -o nounset".
Como ya te indiqué cuando me ayudaste a recuperar mi VDR, si necesitas colaboración con la nueva versión (pruebas, sugerencias, ..., y todo aquello que buenamente pueda) estoy a tu disposición.
¡¡Disfruta del fin de semana!!
alazan- Cantidad de envíos : 10
Fecha de inscripción : 17/11/2012
Localización : Madrid
Temas similares
» Mejoras a la cola de recortes de grabaciones
» ¿Orden de los scripts en el arranque?
» Mejoras en la comprobación de discos
» Mejoras importantes en el JFFS2
» Modo de arranque, estilo clasico de Linux
» ¿Orden de los scripts en el arranque?
» Mejoras en la comprobación de discos
» Mejoras importantes en el JFFS2
» Modo de arranque, estilo clasico de Linux
Página 1 de 1.
Permisos de este foro:
No puedes responder a temas en este foro.