Obtenir Xvfb pour démarrer lors du système de démarrage dans Ubuntu Maverick

J'essaie d'get Xvfb pour fonctionner lorsque le système démarre sur Ubuntu 10.10 (Maverick), mais cela ne fonctionne pas. Dans /etc/rc.local, j'ai les éléments suivants:

/root/start_xvfb.sh >> /var/log/start_xvfb.log 2>&1 exit 0 

Et dans /root/start_xvfb.sh j'ai:

 #!/bin/sh -e startx -- `which Xvfb` :0 -screen 0 1024x768x24 & exit 0 

Après avoir redémarré la machine, le file journal (/var/log/start_xvfb.log) contient:

 [dix] Could not init font path element /usr/share/fonts/X11/cyrillic, removing from list! ^M waiting for X server to shut down ^M 

Compte tenu de ce contenu dans le file journal, il semble que l'appel à "startx -` que Xvfb`: 0 -screen 0 1024x768x24 "soit en cours, mais le process est abattu peu après.

Je veux démarrer Xvfb au démarrage parce que je dois exécuter Firefox sur un server distant qui n'a pas d'affichage de moniteur. Si je lance /etc/rc.local après SSH'ing vers la machine distante, Xvfb démarre sans problème et je peux lancer Firefox via "firefox –display =: 0 &". Si j'essaie d'exécuter Firefox en utilisant cette command sans commencer Xvfb, je reçois le message "Erreur: impossible d'ouvrir l'affichage:: 0".

Notez que je n'essaie pas de voir l'affichage sur mon post de travail local. Je souhaite que l'application s'affiche sur l'affichage de la machine distante (virtuelle, en memory).

Des idées pour lesquelles le server X est éteint sur l'ordinateur distant immédiatement après le démarrage? Existe-t-il un meilleur moyen de démarrer Xvfb lors du démarrage du système?

Merci d'avance pour votre aide.

Je suppose que le shell TERM le fait quand il sortira, ce qui serait immédiatement, en raison de '&'. Peut-être que vous voulez utiliser start-stop-daemon? Par exemple:

 start-stop-daemon --start -b -x /usr/bin/Xvfb :1 

Je suppose que si vous voulez l'aide du wrapper startx, vous voudrez peut-être exécuter votre shellscript à la place.

Vous pouvez utiliser mon script init. Il est basé sur /etc/init.d/skeleton et semble fonctionner bien:

 #! /bin/sh ### BEGIN INIT INFO # Provides: Xvfb # Required-Start: $remote_fs $syslog # Required-Stop: $remote_fs $syslog # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: Start Xvfb. # Description: Start the X virtual framebuffer. ### END INIT INFO # Author: Hannes Brandstaetter-Mueller <hannes.brandstaetter@fh-hagenberg.at> # # Please remove the "Author" lines above and replace them # with your own name if you copy and modify this script. # Do NOT "set -e" # PATH should only include /usr/* if it runs after the mountnfs.sh script PATH=/sbin:/usr/sbin:/bin:/usr/bin DESC="X virtual framebuffer" NAME="Xvfb" DAEMON=/usr/bin/$NAME DAEMON_ARGS=":1 -screen 0 640x480x24" PIDFILE=/var/run/$NAME.pid SCRIPTNAME=/etc/init.d/$NAME # Exit if the package is not installed [ -x "$DAEMON" ] || exit 0 # Read configuration variable file if it is present [ -r /etc/default/$NAME ] && . /etc/default/$NAME # Load the VERBOSE setting and other rcS variables . /lib/init/vars.sh # Define LSB log_* functions. # Depend on lsb-base (>= 3.0-6) to ensure that this file is present. . /lib/lsb/init-functions # # Function that starts the daemon/service # do_start() { # Return # 0 if daemon has been started # 1 if daemon was already running # 2 if daemon could not be started start-stop-daemon --start --background --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \ || return 1 start-stop-daemon --start --background --quiet --pidfile $PIDFILE --exec $DAEMON -- \ $DAEMON_ARGS \ || return 2 # Add code here, if necessary, that waits for the process to be ready # to handle requests from services started subsequently which depend # on this one. As a last resort, sleep for some time. } # # Function that stops the daemon/service # do_stop() { # Return # 0 if daemon has been stopped # 1 if daemon was already stopped # 2 if daemon could not be stopped # other if a failure occurred start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME RETVAL="$?" [ "$RETVAL" = 2 ] && return 2 # Wait for children to finish too if this is a daemon that forks # and if the daemon is only ever run from this initscript. # If the above conditions are not satisfied then add some other code # that waits for the process to drop all resources that could be # needed by services started subsequently. A last resort is to # sleep for some time. start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON [ "$?" = 2 ] && return 2 # Many daemons don't delete their pidfiles when they exit. rm -f $PIDFILE return "$RETVAL" } # # Function that sends a SIGHUP to the daemon/service # do_reload() { # # If the daemon can reload its configuration without # restarting (for example, when it is sent a SIGHUP), # then implement that here. # start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME return 0 } case "$1" in start) [ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME" do_start case "$?" in 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;; 2) [ "$VERBOSE" != no ] && log_end_msg 1 ;; esac ;; stop) [ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME" do_stop case "$?" in 0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;; 2) [ "$VERBOSE" != no ] && log_end_msg 1 ;; esac ;; status) status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $? ;; #reload|force-reload) # # If do_reload() is not implemented then leave this commented out # and leave 'force-reload' as an alias for 'restart'. # #log_daemon_msg "Reloading $DESC" "$NAME" #do_reload #log_end_msg $? #;; restart|force-reload) # # If the "reload" option is implemented then remove the # 'force-reload' alias # log_daemon_msg "Restarting $DESC" "$NAME" do_stop case "$?" in 0|1) do_start case "$?" in 0) log_end_msg 0 ;; 1) log_end_msg 1 ;; # Old process is still running *) log_end_msg 1 ;; # Failed to start esac ;; *) # Failed to stop log_end_msg 1 ;; esac ;; *) #echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2 echo "Usage: $SCRIPTNAME {start|stop|status|restart|force-reload}" >&2 exit 3 ;; esac 

mettez cela dans /etc/init.d/xvfbd et exécutez-le

 sudo update-rc.d xvfbd defaults 

Maintenant, il devrait fonctionner automatiquement lors du démarrage.