[RESOLU] -.- Kdm already running

bonjour a tous ,

petite question :

voila , depuis quelques semaines , de temps a autres , lorsque je j’eteins mon pc , le lendemain au demmarage ,il stop en ligne de commande et affiche un petit "starting kdm:kdm already running "
et je suis donc obliger de me logguer en utilisateur puis en root afin de faire un poweroff et au redemarrage tout va bien

je voulais donc connaitre la facon de stopper kdm en ligne de commande , j’ai essayer “stop kdm” mais “stop” n’est pas reconnu , je n’ai pas essayer de "killall kdm " par contre

es ce deja arriver a quelqu’un ??? et surtout pourquoi ne s’arrete t il pas a la fermeture.

merci

:slightly_smiling:

re-

bon , apparament j’avais mal formuler la commande , j’avais oublier le “/etc/init.d/kdm stop”

donc desoler pour cela :blush: :blush: , par contre je veux bien savoir si cela vous arrive pour la seconde question

merci merci ;p ;p

Pour être encore plus propre : “invoke-rc.d kdm stop”

Sinon, kdm s’arrête forcément quand tu arrête l’ordi, donc sauf si il démarre kdm plusieurs fois, il ne devrait pas y avoir de kdm lancé. Tu peux le vérifier avec un ps -fe | grep kdm

Il reste peut-être un fichier du style /var/run/kdm.pid qui lui fait croire que kdm est lancé. Essaie de voir les logs d’arrêt du système si il y a une erreur quelque part.

salut twinsen93

merci pour les infos , alors pour le ps -fe | grep kdm il me reponds :

~$ ps -fe | grep kdm
root      6185     1  0 11:51 ?        00:00:00 /usr/bin/kdm -config /var/run/kdm/kdmrc
1000     16501 16365  0 18:32 pts/2    00:00:00 grep kdm

et dans le fichier /var/run/kdm.pid, je n’ai qu’un : 6185 d’inscrit

je suis tout ouie si tu peux me doner plus d’explications , si tu peux :slightly_smiling: je suis preneur

merci :slightly_smiling:

Bonsoir,

En fait, kdm ne peut se lancer 2 fois car le fichier /etc/init.d/kdm procède à une vérification. Le log dont tu parles en est la conséquence.

Par contre, il serait possible que 2 liens de démarrage de kdm puissent exister dans les répertoires /etc/rc.d.

Vérifie les fichiers commençant par S (start comme par exemple Sxxkdm ) dans les /etc/rc.d/ afin d’éliminer un doublon.

bonjour BernardH

merci de ton aide aussi :slightly_smiling:

donc , j’ai dans les /etc/rc.d/ plusieurs dossiers c a dire :

rc0.d
rc1.d
rc2.d
rc3.d
rc4.d
rc5.d
rc6.d
rcS.d

la seule fois ou je trouve un “S99kdm” se trouve dans le rc5.d et contient ceci (peu tu me dire ou pourrais se trouver les doublons si il y en a ? ou a quel niveau , j’ai bien regarder pourtant :

#!/bin/sh
### BEGIN INIT INFO
# Provides:          x-display-manager kdm
# Required-Start:    $local_fs $remote_fs
# Required-Stop:     $local_fs $remote_fs
# Should-Start:      console-screen
# Should-Stop:       console-screen
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: X display manager for KDE
# Description:       KDM manages a collection of X servers, which may be on the local host or remote machines.
### END INIT INFO
# /etc/init.d/kdm: start or stop the X display manager
# Script originally stolen from the xdm package
#
# description: K Display Manager
#
set -e

# To start kdm even if it is not the default display manager, change
# HEED_DEFAULT_DISPLAY_MANAGER to "false."
HEED_DEFAULT_DISPLAY_MANAGER=true
DEFAULT_DISPLAY_MANAGER_FILE=/etc/X11/default-display-manager

PATH=/bin:/usr/bin:/sbin:/usr/sbin
DAEMON=/usr/bin/kdm
PIDFILE=/var/run/kdm.pid
UPGRADEFILE=/var/run/kdm.upgrade

# parameters to support kdm customization
KDMRC=/etc/kde3/kdm/kdmrc
BACKGROUNDRC=/etc/kde3/kdm/backgroundrc

#if configuration is changed by kdmtheme or other tools, don't do magick
if grep -q "Theme=@@@ToBeReplacedByDesktopBase@@@" ${KDMRC} && grep -q "Wallpaper=default_blue.jpg" ${BACKGROUNDRC}
then



KDMOVERRIDEDIR=/etc/default/kdm.d
KDMCFGDIR=/var/run/kdm
KDMCFG=$KDMCFGDIR/kdmrc
BACKGROUNDCFG=$KDMCFGDIR/backgroundrc

test -x $DAEMON || exit 0

# uncomment, if you want auto-logon to be runlevel-dependant
#test "$runlevel" || { runlevel=`runlevel`; runlevel=${runlevel#* }; }
#test "$runlevel" = 4 && ARG=-autolog || ARG=-noautolog

# uncomment, if you want tons of debug info in your syslog
#ARG="$ARG -debug 255"

# we use an alternative kdm master configuration file
ARG="$ARG -config $KDMCFG"

# we source overrides. run-parts sorts the list in a predictable order
if [ -d "$KDMOVERRIDEDIR" ]; then
    for part in $(run-parts --list "$KDMOVERRIDEDIR" 2>/dev/null || true); do
        . "$part"
    done
fi

# we generate kdm configuration files
genkdmconf --in $KDMCFGDIR 1> /dev/null

# we update kdm configuration files (only overridden values)
[ -n "$USEBACKGROUND" ] && sed -i "s|^#\?UseBackground=.*|UseBackground=$USEBACKGROUND|" $KDMCFG
[ -n "$BACKGROUNDCFG" ] && sed -i "s|^#\?BackgroundCfg=.*|BackgroundCfg=$BACKGROUNDCFG|" $KDMCFG
[ -n "$USETHEME" ] && sed -i "s|^#\?UseTheme=.*|UseTheme=$USETHEME|" $KDMCFG
[ -n "$THEME" ] && sed -i "s|^#\?Theme=.*|Theme=$THEME|" $KDMCFG
[ -n "$WALLPAPER" ] && sed -i "s|^#\?Wallpaper=.*|Wallpaper=`readlink -f $WALLPAPER`|" $BACKGROUNDCFG


fi
# autologin overrides are useful for live debian environment
if [ -n "$AUTOLOGINUSER" ]; then
	sed -i "s|^#\?AutoLoginEnable=.*|AutoLoginEnable=true|" $KDMCFG
	sed -i "s|^#\?AutoLoginUser=.*|AutoLoginUser=$AUTOLOGINUSER|" $KDMCFG
fi
[ -n "$AUTOLOGINDELAY" ] && sed -i "s|^#\?AutoLoginDelay=.*|AutoLoginDelay=$AUTOLOGINDELAY|" $KDMCFG
[ -n "$AUTOLOGINAGAIN" ] && sed -i "s|^#\?AutoLoginAgain=.*|AutoLoginAgain=$AUTOLOGINAGAIN|" $KDMCFG
[ -n "$AUTOLOGINLOCKED" ] && sed -i "s|^#\?AutoLoginLocked=.*|AutoLoginLocked=$AUTOLOGINLOCKED|" $KDMCFG

# If we upgraded the daemon, we can't use the --exec argument to
# start-stop-daemon since the inode will have changed.  The risk here is that
# in a situation where the daemon died, its pidfile was not cleaned up, and
# some other process is now running under that pid, start-stop-daemon will send
# signals to an innocent process.  However, this seems like a corner case.
# C'est la vie!
if [ -e $UPGRADEFILE ]; then
  SSD_ARGS="--pidfile $PIDFILE --startas $DAEMON"
else
  SSD_ARGS="--pidfile $PIDFILE --exec $DAEMON"
fi

stillrunning () {
  if expr "$(cat /proc/$DAEMONPID/cmdline 2> /dev/null)" : "$DAEMON" > /dev/null 2>&1; then
    true
  else
    # if the daemon does not remove its own pidfile, we will
    rm -f $PIDFILE $UPGRADEFILE
    false
  fi;
}

case "$1" in
  start)
    if [ -e $DEFAULT_DISPLAY_MANAGER_FILE ] &&
       [ "$HEED_DEFAULT_DISPLAY_MANAGER" = "true" ] &&
       [ "$(cat $DEFAULT_DISPLAY_MANAGER_FILE)" != "$DAEMON" ]; then
      echo "Not starting K Display Manager (kdm); it is not the default display manager."
    else
      echo -n "Starting K Display Manager: kdm"
      start-stop-daemon --start --quiet $SSD_ARGS -- $ARG || echo -n " already running"
      echo "."
    fi
  ;;

  restart)
    /etc/init.d/kdm stop
    if [ -f $PIDFILE ]; then
      if stillrunning; then
        exit 1
      fi
    fi
    /etc/init.d/kdm start
  ;;

  reload)
    echo -n "Reloading K Display Manager configuration..."
    if start-stop-daemon --stop --signal 1 --quiet $SSD_ARGS; then
      echo "done."
    else
      echo "kdm not running."
    fi
  ;;

  force-reload)
    /etc/init.d/kdm reload
  ;;

  stop)
    echo -n "Stopping K Display Manager: kdm"
    if [ ! -f $PIDFILE ]; then
      echo " not running ($PIDFILE not found)."
      exit 0
    else
      DAEMONPID=$(cat $PIDFILE | tr -d '[:blank:]')
      KILLCOUNT=1
      if [ ! -e $UPGRADEFILE ]; then
        if start-stop-daemon --stop --quiet $SSD_ARGS; then
          # give kdm's signal handler a second to catch its breath
          sleep 1
        else
          echo -n " not running"
        fi
      fi
      while [ $KILLCOUNT -le 5 ]; do
        if stillrunning; then
          kill $DAEMONPID
        else
          break
        fi
        sleep 1
        KILLCOUNT=$(( $KILLCOUNT + 1 ))
      done
      if stillrunning; then
        echo -n " not responding to TERM signal (pid $DAEMONPID)"
      else
        rm -f $UPGRADEFILE
      fi
    fi
    echo "."
  ;;

  *)
    echo "Usage: /etc/init.d/kdm {start|stop|restart|reload|force-reload}"
    exit 1
    ;;
esac

exit 0

merci

Je vois pas ou il pourrait y avoir un doublon.

Tu peux voir si il y a quelque chose dans les logs. Sur ma lenny, j’ai des messages a propos de kdm dans /var/log/syslog /var/log/daemon.log /var/log/kdm /var/log/boot

Pour le dernier, il faut l’activer dans /etc/default/bootlogd

Les fichiers dans les répertoires rc.d sont des liens qui pointent vers les fichiers /etc/init.d/. Ce sont des liens servent à lancer, entre autres, les daemons.

Il doit y avoir un fichier qui relance kdm en sus du lien S99kdm de rc5.d.

Fais donc une recherche du fichier kdm.* pour voir s’il y autre chose que S99kdm et /etc/ini.d/kdm.

Si le fichier commence par S il est démarré, si il commence par K il est arrêté.

Ce sont des liens symboliques vers /etc/init.d, donc au lieu de chercher les fichiers nommés *kdm il faut chercher ceux qui sont des liens vers /etc/init.d/kdm, quel que soit leur nom.

Je suis d’accord avec ton analyse et sur le but visé.

Par contre, quel est le nom que tu vas mettre dans le moteur de recherche ?

C’est pourquoi je te propose kdm entouré de jockers soit kdm.*.
J’ai pas trouvé mieux.

Voila :

ls -l /etc/rc?.d/* | grep kdm

J’entends bien ta formule, mais il faut désormais faire une recherche à partir de la racine et non des répertoires rc.d.

bonjour ,

merci pour toute ses infos encore une fois :slightly_smiling:

le ls -l /etc/rc?.d/* | grep kdm me donne :

lrwxrwxrwx 1 root root  13 jun 23  2008 /etc/rc5.d/S99kdm -> ../init.d/kdm

je vais regarder pour /etc/ini.d/kdm.

:slightly_smiling:

Sur ma lenny, ca donne :

lrwxrwxrwx 1 root root 13 oct 19 13:09 /etc/rc0.d/K01kdm -> ../init.d/kdm lrwxrwxrwx 1 root root 13 oct 19 13:09 /etc/rc1.d/K01kdm -> ../init.d/kdm lrwxrwxrwx 1 root root 13 oct 19 13:09 /etc/rc2.d/S99kdm -> ../init.d/kdm lrwxrwxrwx 1 root root 13 oct 19 13:09 /etc/rc3.d/S99kdm -> ../init.d/kdm lrwxrwxrwx 1 root root 13 oct 19 13:09 /etc/rc4.d/S99kdm -> ../init.d/kdm lrwxrwxrwx 1 root root 13 oct 19 13:09 /etc/rc5.d/S99kdm -> ../init.d/kdm lrwxrwxrwx 1 root root 13 oct 19 13:09 /etc/rc6.d/K01kdm -> ../init.d/kdm

Il te manque les liens K01kdm qui servent à arrêter kdm, donc au redémarrage le fichier kdm.pid est toujours présent et kdm refuse de démarrer.

Tu peux les ajouter directement avec

cd /etc/rc0.d/ && ln -s ../init.d/kdm K01kdm
cd /etc/rc1.d/ && ln -s ../init.d/kdm K01kdm
cd /etc/rc6.d/ && ln -s ../init.d/kdm K01kdm

Il y a aussi update-rc.d pour gérer les liens des scipts init, mais je sais pas m’en servir. Il y a aussi une interface KDE : ksysv.

re-

merci , je vais donc creer les liens ,
j’ai remarquer aussi que j’avais un Sxxgdm activer c’est normale a ton avis d’avoir un autre bureau qui tourne en meme temps ou c’est afin d’utiliser quelques progs qui appartiennes a gnome?? (dont j’utilise certains)

Non c’est pas normal, d’ailleurs je crois pas que les deux peuvent tourner en même temps, en tout cas pas sur le même serveur X. Si gdm essaie de démarrer en même temps que kdm, il doit surement terminer en erreur.

Rien a voir, les progs gnome ont juste besoin des bibliothèques gnome (paquets libgnome-quelquechose et libgtk-quelquechose).

[quote]Si gdm essaie de démarrer en même temps que kdm, il doit surement terminer en erreur.
[/quote]

bien , donc un nouveau petit soucie a regler…je trouvais ca bizarre remarque

comment fait on pour enlever le lien de démarrage du rc*.d concerner ??

je vais revoir les logs

thx

re

apparament c’est dans la config d’origine de knoppix (???), il essais de demmarrer gnome mais n’etant pas le bureau par default (chez moi c KDE), donc il stoppe la chose en allant sur la mosaique (sous knoppix je peux choisir avec quel bureau je veux travailler j’en ai au moins une dizaines …) , mais c’est etrange tout ca tout de meme , j’ai installe knoppix via KDE il ne devrais pas me faire un coup comme cela …

si vous avez une tit idée … :blush:

Pour enlever le lien de démarrage du rc.d, tu peux tout simplement le supprimer comme nimporte quel fichier :

okay , merci pour ton aide :slightly_smiling:

:smt006