Lightdm не запускается при загрузке в Ubuntu 14.04

32037
Paul Bergström

Я читал много постов об этой проблеме относительно предыдущих версий Ubuntu, но, похоже, они не работают в моем случае.

При загрузке и показанном в /var/log/boot.log демон / usr / sbin / lightdm просто выключается - по-видимому, без какой-либо явной ошибки, оставляя меня застрявшим в ухмылке «Kubuntu». Затем, если я запустлю терминал, войду в систему и выполню «сервис lightdm start», он запустится идеально.

Я попробовал несколько «уродливых хаков», чтобы запустить его, например, добавив нижнюю строку в сервисе init-script «/etc/init.d/lightdm» для запуска lightdm или /etc/init.d/lightdm start, но все равно он не запустится при загрузке. Все остальные диспетчера отображения (gdm и kdm) удалены.

Есть идеи?

#!/bin/sh  # Largely adapted from xdm's init script: # Copyright 1998-2002, 2004, 2005 Branden Robinson <branden@debian.org>. # Copyright 2006 Eugene Konev <ejka@imfi.kspu.ru> # # This is free software; you may redistribute it and/or modify # it under the terms of the GNU General Public License as # published by the Free Software Foundation; either version 2, # or (at your option) any later version. # # This is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License with # the Debian operating system, in /usr/share/common-licenses/GPL; if # not, write to the Free Software Foundation, Inc., 51 Franklin Street,  # Fifth Floor, Boston, MA 02110-1301, USA.  ### BEGIN INIT INFO # Provides: lightdm # Required-Start: $local_fs $remote_fs # Required-Stop: $local_fs $remote_fs # Should-Start: $named acpid hal # Should-Stop: $named # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: Start lightdm ### END INIT INFO  set -e  HEED_DEFAULT_DISPLAY_MANAGER= # To start lightdm even if it is not the default display manager, change # HEED_DEFAULT_DISPLAY_MANAGER to "false." # Also overridable from command line like: # HEED_DEFAULT_DISPLAY_MANAGER=false /etc/init.d/lightdm start [ -z "$HEED_DEFAULT_DISPLAY_MANAGER" ] && HEED_DEFAULT_DISPLAY_MANAGER=true  DEFAULT_DISPLAY_MANAGER_FILE=/etc/X11/default-display-manager  PATH=/bin:/usr/bin:/sbin:/usr/sbin DAEMON=/usr/sbin/lightdm PIDFILE=/var/run/lightdm.pid  if [ -r /etc/default/locale ]; then . /etc/default/locale export LANG LANGUAGE fi  test -x $DAEMON || exit 0  . /lib/lsb/init-functions  SSD_START_ARGS="--pidfile $PIDFILE --name $(basename $DAEMON) --startas $DAEMON -- -d" SSD_STOP_ARGS="--pidfile $PIDFILE --name $(basename $DAEMON) --retry TERM/5/TERM/5"  case "$1" in start) if [ "$HEED_DEFAULT_DISPLAY_MANAGER" = "true" ] && [ -e $DEFAULT_DISPLAY_MANAGER_FILE ] && [ "$(cat $DEFAULT_DISPLAY_MANAGER_FILE)" != "/usr/bin/lightdm" -a "$(cat $DEFAULT_DISPLAY_MANAGER_FILE)" != "/usr/sbin/lightdm" ]; then echo "Not starting X display manager (lightdm); it is not the default" \ "display manager." else log_daemon_msg "Starting X display manager" "lightdm" start-stop-daemon --start --quiet $SSD_START_ARGS \ || log_progress_msg "already running" log_end_msg 0 fi ;;  restart) [ -f $PIDFILE ] && /etc/init.d/lightdm stop [ -f $PIDFILE ] && exit 1 /etc/init.d/lightdm start ;;  stop) log_daemon_msg "Stopping X display manager" "lightdm" if ! [ -f $PIDFILE ]; then log_progress_msg "not running ($PIDFILE not found)" else start-stop-daemon --stop --quiet $SSD_STOP_ARGS SSD_RES=$? if [ $SSD_RES -eq 1 ]; then log_progress_msg "not running" fi if [ $SSD_RES -eq 2 ]; then log_progress_msg "not responding to TERM signals" else if [ -f $PIDFILE ]; then log_progress_msg "(removing stale $PIDFILE)" rm $PIDFILE fi fi fi log_end_msg 0 ;; force-reload) /etc/init.d/lightdm restart ;;  *) echo "Usage: /etc/init.d/lightdm " exit 1 ;; esac exit 0 
6
Что находится в вашем `/ etc / default / grub`? Возможно, что в нем есть строка `GRUB_CMDLINE_LINUX_DEFAULT =" тихий текст "`. Кроме того, редактирование `/ etc / init.d / lightdm` не подходит, потому что оно будет просто вызывать себя рекурсивно. Danatela 10 лет назад 0
Что находится в журналах в /var/log/Xorg.0.log? Lawrence 10 лет назад 0
Danatela: The line you suggested in /etc/default/grub was not there. It was "quiet splash". I have also reset the /etc/init.d/lightdm to it's original state. Lawrence: Now when I study the /var/log/Xorg.0.log there are a few errors: cat Xorg.0.log | grep EE [ 94.517] (EE) open /dev/dri/card0: No such file or directory [ 97.226] (EE) AIGLX error: failed to open /usr/X11R6/lib/modules/dri/fglrx_dri.so, error[/usr/X11R6/lib/modules/dri/fglrx_dri.so: cannot open shared object file: No such file or directory] [ 873.817] (EE) Server terminated successfully (0). Closing log file. Paul Bergström 10 лет назад 0
Я нашел кое-что здесь: http://wiki.cchtml.com/index.php/Ubuntu_Gutsy_Installation_Guide#If_you_get_.2Fusr.2FX11R6.2Flib.2Fmodules.2Fdri.2Ffglrx_dri.so_not_found, который относится к этой проблеме. Я попытаюсь сделать символическую ссылку как предложено там, чтобы видеть, будет ли это работать. Paul Bergström 10 лет назад 0
Ну, был небольшой успех. Ошибка [97.226] (EE) Ошибка AIGLX: не удалось открыть /usr/X11R6/lib/modules/dri/fglrx_dri.so, ошибка [/usr/X11R6/lib/modules/dri/fglrx_dri.so: не удается открыть общий объект файл: нет такого файла или каталога] теперь нет в журнале. Это было решено в два этапа, mkdir -p / usr / X11R6 / lib / modules / dri и затем в том же каталоге sudo ln -s /usr/lib/fglrx/dri/fglrx_dri.so. К сожалению, lightdm все еще не запускается при загрузке :( Paul Bergström 10 лет назад 1
@Danatela: Я начинаю верить, что что-то не так с init-скриптом lightdm. В журналах я могу найти только строку об остановке lightdm - ничего из этого никогда не начиналось. В моем посте на superuser.com есть еще немного информации, но я думаю, что сделал неправильно, когда использовал уведомления. Paul Bergström 10 лет назад 0
@Lawrence: Я начинаю верить, что что-то не так с init-скриптом lightdm. В журналах я могу найти только строку об остановке lightdm - ничего из этого никогда не начиналось. В моем посте на superuser.com есть еще немного информации, но я думаю, что сделал неправильно, когда использовал уведомления. Paul Bergström 10 лет назад 0
Так что опубликуйте свой скрипт `lightdm`, и мы сравним его с нашим. Danatela 10 лет назад 0
@Danatela: я разместил это в своем основном посте. Извините, если это не правильный способ сделать это, но я не знал, как еще ..... Paul Bergström 10 лет назад 0
Это правильный путь для обмена стека! Большинство новичков публикуют важные вещи в комментариях, затрудняя их поиск. Но вы интуитивно поступили правильно! Поздравляю;) Однако, это требует некоторого форматирования. Я сделаю это для тебя. Danatela 10 лет назад 0
Попробуйте `sudo update-rc.d lightdm удалить && sudo update-rc.d lightdm по умолчанию && sudo update-rc.d lightdm enable`. Danatela 10 лет назад 0
@Danatela: Я получаю update-rc.d: /etc/init.d/lightdm существует во время очистки rc.d (используйте -f для принудительного ввода) в первой команде. Я тоже пробовал с -f, но все так же. Может я должен выйти из Xsession? Paul Bergström 10 лет назад 0
Это должно существовать. update-rc.d` фактически не удаляет скрипт инициализации, он только удаляет его из очереди инициализации. Danatela 10 лет назад 0
@Danatela: Во-первых, спасибо за ваши усилия :) Тогда был небольшой успех. Я смог выполнить команды в текстовом режиме с флагом -f. После этого происходит перезагрузка и некоторое другое поведение. Экран становится черным и в /var/log/boot.log он гласит: «Не запускается lightdm, так как это не диспетчер отображения по умолчанию». Однако в / etc / X11 / default-display-manager написан только один демон - / usr / sbin / lightdm. Может ли загрузка читать диспетчера отображения по умолчанию в другом месте? Paul Bergström 10 лет назад 0
@Danatela: УСПЕХ !!!! В init-скрипте я изменил строку HEED_DEFAULT_DISPLAY_MANAGER = true на HEED_DEFAULT_DISPLAY_MANAGER = false и вуаля, это работает !!!!! Paul Bergström 10 лет назад 0
Поздравляем! Так что напишите решение как ответ. Попытайтесь сделать это достаточно многословным, чтобы быть полезным. Danatela 10 лет назад 0

1 ответ на вопрос

6
Paul Bergström

Теперь, когда я изучаю /var/log/Xorg.0.log, есть несколько ошибок:

$ cat Xorg.0.log | grep EE  [ 94.517] (EE) open /dev/dri/card0: No such file or directory [ 97.226] (EE) AIGLX error: failed to open /usr/X11R6/lib/modules/dri/fglrx_dri.so, error[/usr/X11R6/lib/modules/dri/fglrx_dri.so: cannot open shared object file: No such file or directory] [ 873.817] (EE) Server terminated successfully (0). Closing log file. 

Это было решено в два этапа:

  1. sudo mkdir -p /usr/X11R6/lib/modules/dri а затем в том же каталоге,

  2. sudo ln -s /usr/lib/fglrx/dri/fglrx_dri.so,

К сожалению, lightdm все еще не запускается при загрузке :(

Однако выполнение следующих команд в текстовом режиме и, возможно, использование флага -fбыли первым шагом к решению проблемы:

sudo update-rc.d lightdm remove  sudo update-rc.d lightdm defaults sudo update-rc.d lightdm enable 

Последним шагом, который полностью решил проблему, было редактирование /etc/init.d/lightdm, где строка:

HEED_DEFAULT_DISPLAY_MANAGER=true 

был изменен на,

HEED_DEFAULT_DISPLAY_MANAGER=false 

После перезагрузки lightdm запускается красиво :)

Похожие вопросы