Решено: GNU Screen не видит сеанса (Сеанс запускается init скриптом)

На самом деле это единственный раздел про unix на этом форуме

Модераторы: /dev/random, Модераторы разделов

Аватара пользователя
kma21
Сообщения: 874
Статус: Странный экспериментатор...

Решено: GNU Screen не видит сеанса

Сообщение kma21 »

Привет всем!

Debian Squeeze, GNU Screen 4.0.3-14.

Запускаю сервер Minecraft следующим скриптом:

Код:

maxim@maxim-server:~$ cat /etc/init.d/minecraft #!/bin/bash # /etc/init.d/minecraft # version 0.3.7 2012-03-06 (YYYY-MM-DD) ### BEGIN INIT INFO # Provides: minecraft # Required-Start: $local_fs $remote_fs # Required-Stop: $local_fs $remote_fs # Should-Start: $network # Should-Stop: $network # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # Short-Description: Minecraft server # Description: Starts the minecraft server ### END INIT INFO #Settings SERVICE='minecraft_server.jar' OPTIONS='nogui' USERNAME='minecraft' WORLD='world' MCPATH='/home/minecraft/Minecraft_Server' BACKUPPATH='/media/remote.share/minecraft.backup' CPU_COUNT=1 INVOCATION="java -Xmx512M -Xms512M -XX:+UseConcMarkSweepGC -XX:+CMSIncrementalPacing -XX:ParallelGCThreads=$CPU_COUNT -XX:+AggressiveOpts -jar $SERVICE $OPTIONS" ME=`whoami` as_user() { if [ $ME == $USERNAME ] ; then bash -c "$1" else su - $USERNAME -c "$1" fi } mc_start() { if pgrep -u $USERNAME -f $SERVICE > /dev/null then echo "$SERVICE is already running!" else echo "Starting $SERVICE..." cd $MCPATH as_user "cd $MCPATH && screen -dmS minecraft $INVOCATION" sleep 7 if pgrep -u $USERNAME -f $SERVICE > /dev/null then echo "$SERVICE is now running." else echo "Error! Could not start $SERVICE!" fi fi } mc_saveoff() { if pgrep -u $USERNAME -f $SERVICE > /dev/null then echo "$SERVICE is running... suspending saves" as_user "screen -p 0 -S minecraft -X eval 'stuff \"say SERVER BACKUP STARTING. Server going readonly...\"\015'" as_user "screen -p 0 -S minecraft -X eval 'stuff \"save-off\"\015'" as_user "screen -p 0 -S minecraft -X eval 'stuff \"save-all\"\015'" sync sleep 10 else echo "$SERVICE is not running. Not suspending saves." fi } mc_saveon() { if pgrep -u $USERNAME -f $SERVICE > /dev/null then echo "$SERVICE is running... re-enabling saves" as_user "screen -p 0 -S minecraft -X eval 'stuff \"save-on\"\015'" as_user "screen -p 0 -S minecraft -X eval 'stuff \"say SERVER BACKUP ENDED. Server going read-write...\"\015'" else echo "$SERVICE is not running. Not resuming saves." fi } mc_stop() { if pgrep -u $USERNAME -f $SERVICE > /dev/null then echo "Stopping $SERVICE" as_user "screen -p 0 -S minecraft -X eval 'stuff \"say SERVER SHUTTING DOWN IN 10 SECONDS. Saving map...\"\015'" as_user "screen -p 0 -S minecraft -X eval 'stuff \"save-all\"\015'" sleep 10 as_user "screen -p 0 -S minecraft -X eval 'stuff \"stop\"\015'" sleep 7 else echo "$SERVICE was not running." fi if pgrep -u $USERNAME -f $SERVICE > /dev/null then echo "Error! $SERVICE could not be stopped." else echo "$SERVICE is stopped." fi } mc_update() { if pgrep -u $USERNAME -f $SERVICE > /dev/null then echo "$SERVICE is running! Will not start update." else MC_SERVER_URL=http://s3.amazonaws.com/MinecraftDownload/launcher/minecraft_server.jar?v=`date | sed "s/[^a-zA-Z0-9]/_/g"` as_user "cd $MCPATH && wget -q -O $MCPATH/minecraft_server.jar.update $MC_SERVER_URL" if [ -f $MCPATH/minecraft_server.jar.update ] then if `diff $MCPATH/$SERVICE $MCPATH/minecraft_server.jar.update >/dev/null` then echo "You are already running the latest version of $SERVICE." else as_user "mv $MCPATH/minecraft_server.jar.update $MCPATH/$SERVICE" echo "Minecraft successfully updated." fi else echo "Minecraft update could not be downloaded." fi fi } mc_backup() { mc_saveoff NOW=`date "+%Y-%m-%d_%Hh%M"` BACKUP_FILE="$BACKUPPATH/${WORLD}_${NOW}.tar" echo "Backing up minecraft world..." #as_user "cd $MCPATH && cp -r $WORLD $BACKUPPATH/${WORLD}_`date "+%Y.%m.%d_%H.%M"`" as_user "tar -C \"$MCPATH\" -cf \"$BACKUP_FILE\" $WORLD" echo "Backing up $SERVICE" as_user "tar -C \"$MCPATH\" -rf \"$BACKUP_FILE\" $SERVICE" #as_user "cp \"$MCPATH/$SERVICE\" \"$BACKUPPATH/minecraft_server_${NOW}.jar\"" mc_saveon echo "Compressing backup..." as_user "gzip -f \"$BACKUP_FILE\"" echo "Done." } mc_command() { command="$1"; if pgrep -u $USERNAME -f $SERVICE > /dev/null then pre_log_len=`wc -l "$MCPATH/server.log" | awk '{print $1}'` echo "$SERVICE is running... executing command" as_user "screen -p 0 -S minecraft -X eval 'stuff \"$command\"\015'" sleep .1 # assumes that the command will run and print to the log file in less than .1 seconds # print output tail -n $[`wc -l "$MCPATH/server.log" | awk '{print $1}'`-$pre_log_len] "$MCPATH/server.log" fi } #Start-Stop here case "$1" in start) mc_start ;; stop) mc_stop ;; restart) mc_stop mc_start ;; update) mc_stop mc_backup mc_update mc_start ;; backup) mc_backup ;; status) if pgrep -u $USERNAME -f $SERVICE > /dev/null then echo "$SERVICE is running." else echo "$SERVICE is not running." fi ;; command) if [ $# -gt 1 ]; then shift mc_command "$*" else echo "Must specify server command (try 'help'?)" fi ;; *) echo "Usage: $0 {start|stop|update|backup|status|restart|command \"server command\"}" exit 1 ;; esac exit 0


Сервер работает, но screen -r не видит сессии.

Код: Выделить всё

maxim@maxim-server:~$ screen -r
There is no screen to be resumed.


Если запускать программы через screen, то всё работает.

В чём может быть причина?
Спасибо сказали:
Аватара пользователя
/dev/random
Администратор
Сообщения: 5456
ОС: Gentoo

Re: Решено: GNU Screen не видит сеанса

Сообщение /dev/random »

В screen у каждого юзера свой список сессий. Вы пытаетесь из-под пользователя maxim приаттачиться к сессии пользователя minecraft. Чтобы это сделать, вам нужно:
Шаг 1. Собрать screen с поддержкой многопользовательского режима. Пропустите этот шаг, если в вашем дистрибутиве он так и собран.
Шаг 2. Настроить многопользовательский доступ к создаваемой в скрипте сессии (по умолчанию он, разумеется, запрещён, иначе это было бы дырой в безопасности).
Шаг 3. При подключении указывать, к чьей сессии подключаетесь.
Спасибо сказали:
Аватара пользователя
ZyX
Сообщения: 355
ОС: Gentoo

Re: Решено: GNU Screen не видит сеанса

Сообщение ZyX »

Ваш скрипт запускается от суперпользователя, а присоединиться вы пытаетесь от пользователя «maxim», как я понял. Разумеется, нихрена не работает. Запускайте присоединения от того же пользователя, от которого screen запускается изначально.
Спасибо сказали:
Аватара пользователя
kma21
Сообщения: 874
Статус: Странный экспериментатор...

Re: Решено: GNU Screen не видит сеанса

Сообщение kma21 »

Код: Выделить всё

minecraft@maxim-server:~$ screen -r
Cannot open your terminal '/dev/pts/0' - please check.


Что-то не так, да?

Код: Выделить всё

root@maxim-server:~# screen -r
There is no screen to be resumed.
Спасибо сказали:
Аватара пользователя
ZyX
Сообщения: 355
ОС: Gentoo

Re: Решено: GNU Screen не видит сеанса

Сообщение ZyX »

kma21 писал(а):
25.03.2012 02:44

Код: Выделить всё

minecraft@maxim-server:~$ screen -r
Cannot open your terminal '/dev/pts/0' - please check.


Что-то не так, да?

Код: Выделить всё

root@maxim-server:~# screen -r
There is no screen to be resumed.

Поправка: от того же пользователя, от которого запускается screen. Прочитав ваш скрипт, я понял, что это не суперпользователь (скрипты из /etc/init.d запускаются от него), а «minecraft», для чего вы используете функцию as_user.
Спасибо сказали:
Аватара пользователя
/dev/random
Администратор
Сообщения: 5456
ОС: Gentoo

Re: Решено: GNU Screen не видит сеанса

Сообщение /dev/random »

kma21 писал(а):
25.03.2012 02:44

Код: Выделить всё

minecraft@maxim-server:~$ screen -r
Cannot open your terminal '/dev/pts/0' - please check.


Что-то не так, да?

Пользователь minecraft не имеет доступа к терминалу, на котором вы выполняете эту команду. Проблема не имеет отношения к предыдущей. Попробуйте _залогиниться_ под пользователем minecraft, а не просто выполнить su/sudo.
Спасибо сказали:
Аватара пользователя
kma21
Сообщения: 874
Статус: Странный экспериментатор...

Re: Решено: GNU Screen не видит сеанса

Сообщение kma21 »

/dev/random, разобрался, спасибо!

Я думал, что su является полноценным relogin.
Спасибо сказали:
Аватара пользователя
sash-kan
Администратор
Сообщения: 13939
Статус: oel ngati kameie
ОС: GNU

Re: Решено: GNU Screen не видит сеанса

Сообщение sash-kan »

как подсказывают интернеты, можно терминал создать программой script:
$ su - <user> -c "script -c 'screen -RD' /dev/null"
Писать безграмотно - значит посягать на время людей, к которым мы адресуемся, а потому совершенно недопустимо в правильно организованном обществе. © Щерба Л. В., 1957
при сбоях форума см.блог
Спасибо сказали: