Я искал это раньше, но так и не смог найти ответ.
В Windows, если у меня открыто окно консоли, введите winmine
и нажмите Enter, появится Minesweeper, совершенно отдельный от программы cmd. Экземпляр Minesweeper не связан с командной строкой каким-либо известным мне способом, за исключением того, что родительский уровень Minesweeper установлен на этот экземпляр командной строки. Однако в Linux все по-другому.
В Linux, если у меня открыто окно консоли, введите emacs
и нажмите Enter, откроется Emacs, но, похоже, он связан с командной строкой. В частности, похоже, что я больше не могу использовать командную строку, пока этот экземпляр Emacs не будет закрыт. Есть ли способ реплицировать поведение Windows в Linux?
Спасибо!
linux
command-line
Джейсон
источник
источник
Ответы:
В
bash
,detach
является встроенным, используется следующим образом:В
zsh
, вы можете фон и отделить в одной операции:источник
Добавить
&
в командную строку :Это поместит emacs в фоновый режим и позволит вам продолжать использовать ваш терминал.
Обратите внимание, что это все равно оставит emacs как подпроцесс вашего терминала, и когда вы выйдете из терминала, он также выйдет из emacs. Чтобы избежать этого, введите:
Скобки указывают терминалу отключить процесс emacs от терминала.
Тем не менее, сообщения stdout и stderr из программы будут отображаться на терминале. Чтобы предотвратить это, используйте:
источник
Ctrl
+C
в окне терминала эта команда была выполнена, процесс прекращается: <Используйте
nohup
. Нравится:nohup amarok &
Надеюсь это поможет.
источник
Я разместил ответ на более старую ветку схожей темы с ответами из разных источников. Ниже приводится копия этого ответа, адаптированная для этой темы.
Следующие работы:
Это ответ Натана Феллмана плюс перенаправление.
«&> / dev / null» перенаправляет как stdout, так и stderr на нулевое устройство. Последний амперсанд заставляет процесс работать в фоновом режиме. Скобки вокруг команды приведут к тому, что ваш «gui_app» будет запущен в подоболочке.
Выполнение этого отсоединит процесс «gui_app» от консоли, с которой вы выполняете эту команду. Так что даже если вы закроете окно, в котором запущен эмулятор родительского терминала, «gui_app» не закроется. Я запустил это, затем посмотрел на дерево процессов с помощью команды "pstree" и обнаружил, что приложение, запущенное таким образом, станет дочерним процессом для "init".
Например,
запустит приложение в фоновом режиме, но оно станет дочерним процессом консольного процесса и прекратит работу при закрытии терминала. (Хотя выход из терминала через bash с помощью команды выхода или Ctrl-D позволит bash очиститься, передав фоновый процесс init.)
«nohup» работает так, как предложил NawaMan, но по умолчанию перенаправляет вывод и ошибку в файл. Как ответил JeffG, команда «disown» (если она доступна в оболочке) может отсоединить процесс от терминала после того, как вы запустили фоновый процесс:
(Кстати, все это относится к bash. Я уверен, что другие оболочки имеют другие методы / синтаксис для этого.)
Некоторая справка: Отказ от процессов (UNIX Power Tools)
Если это простой вызов приложения с графическим интерфейсом - без сложных опций и тому подобного - кажется, что использование средства запуска, такого как "gmrun" или dmenu (предупреждение: громкий звук), также является хорошим вариантом. Свяжите это с комбинацией клавиш. Я пока не пользуюсь лаунчером, но попробовал эти два.
ПРИМЕЧАНИЕ. CarlF в комментариях других потоков сообщает, что приложения с графическим интерфейсом, запущенные с помощью метода gui_app &, не закрываются при выходе из родительского терминала. Я думаю, что мы закрывали терминал по-разному. Я закрывал окно, в котором работал эмулятор терминала. Я думаю, что он мог выходить из эмулятора терминала через оболочку (команда выхода или Ctrl-D). Я проверил это и увидел, что выход через bash не останавливает запуск GUI в качестве фонового процесса терминала, как говорит CarlF. Кажется, что bash передает фоновые процессы инициализации, когда ему дают возможность очистить. Фактически, это должен быть механизм, с помощью которого фоновый процесс, запущенный в подоболочке, передается init.
источник
util-linux включает в себя инструмент с именем setsid, который в основном делает то, что делает detach:
Это запустится
someprogram
в новом сеансе.источник
Попробуйте набрать,
xemacs &
чтобы открыть XEmacs в фоновом режиме.Пожалуйста, не называйте это «эмуляцией поведения Windows». Уч.
Вы также можете:
источник
Я поместил следующий код в исполняемый файл сценария с именем «sbg» для «тихий фон». Он выполняет все необходимые действия, чтобы полностью отключить программу, запускаемую из оболочки: перенаправляет stdin, stdout и stderr из / в
/dev/null
, игнорирует зависания, работает в фоновом режиме и отключается.Тогда вы можете просто сделать
sbg emacs
. Вы также можете передавать любые аргументы , которые вы хотите:sbg emacs --daemon FILE1 FILE2
.источник
(gui_app &> /dev/null &)
вместо этого (ответ @ EMPraptor)Поставьте амперсанд после команды.
источник
если вы используете bash, вы можете отказаться от процесса:
источник
Вы можете использовать эту единственную строку:
источник
Как говорят другие ответы, вы можете использовать следующее:
Если вы забыли
&
, просто нажмите,Ctrl-z
затем используйтеbg
:К вашему сведению:
Ctrl-z
останавливает процесс Emacs иbg
отправляет в фоновом режиме.источник
просто используя,
&
как в$ x &
листьях процесс, подключенный к терминалу, я подобрал небольшую программу под названиемdetach
http://inglorion.net/software/detach/, которую я назвал псевдонимом, так какd
она немного похожа,nohup
но не оставляет после себя файл журнала. используйте это, чтобы отделить mupdf :d mupdf x.pdf
источник
Поместите это в свой
~/.bashrc
:Теперь вам не нужно запоминать, какие программы X11, и выполнять для них специальные манипуляции, потому что они будут отключаться автоматически. Обратите внимание, что
setsid
это лучше, чемnohup
потому, что последний блокирует сигнал HUP, который вам не нужен.PS Теперь вы уже
winmine
в Linux.источник