Когда я захожу на другой компьютер Ubuntu с моей учетной записью (с разрешениями sudo), моя клавиша Backspace генерирует некоторые неудобные символы при нажатии. Также не работают клавиши Tab, Del и Arrow.
С другой стороны, у меня также есть другая учетная запись на той же машине, и когда я ssh через эту учетную запись, его терминал работает отлично. Я не мог понять, почему это происходит.
command-line
gnome-terminal
xterm
gopi1410
источник
источник
Ответы:
РЕДАКТИРОВАТЬ: Ссылка: ответ Матенга
Матенг близок к тому, что я думаю, что вы, вероятно, управляете Bourne Shell. Но вы не должны редактировать свой
/etc/passwd
файл напрямую. Попробуйте использоватьchsh
команду вместо этого:Флаг -s сделает новую оболочку (в данном случае Bash) вашей оболочкой для входа в систему.
источник
sudo chsh -s /bin/bash
Следующие изменения решили проблему для меня. Сначала я проверил, какая оболочка запущена:
который вернулся:
Как я читал в этом посте в Ubuntuforums , изменение оболочки на
/bin/bash
приносит решение. Поэтому я отредактировал свои пользовательские настройки так/etc/passwd
:Я вышел из системы, затем снова вошел в систему. Странно, мне пришлось переключать оболочку вручную (возможно, какой-то кэш был активен), введя это:
Вуаля!
[Проблема возникла из-за обновления дистрибутива.]
источник
при первом входе в ssh попробуйте эти две команды
Я должен сделать это на некоторых машинах, которые я вхожу, чтобы решить именно эту проблему
источник
stty erase <backspace>
(<backspace> где вы на самом деле$ stty erase '^[[A' stty: invalid integer argument '\033[A'
. С [Backspace]:$ stty erase '^?'
это работает. С [Tab]:$ stty erase ' '
нет ошибки, но затем [Backspace] возвращается к странному поведению.export TERM=VT100
, но безрезультатно.stty tab0
не помогает. Я думаю, какая-то общая реконфигурация xterm необходима. Или раскладка клавиатуры просто неверна?Один из самых простых способов решить эту проблему - набрать / bin / bash в командной строке интерфейса:
$ / bin / bash
Вышеупомянутая команда выполнит Оболочку Bourne Again поверх существующей оболочки как подпроцесс. Это представляет собой недостаток использования большего количества ресурсов, но ничего не нужно редактировать и никаких специальных разрешений не требуется. Например, в последних версиях Kubuntu он запускает сеанс / bin / bash поверх интерфейса командной строки по умолчанию / bin / dash.
Однако, чтобы сохранить изменения, можно отредактировать файл / etc / passwd и добавить / отредактировать / заменить оболочку по умолчанию в / bin / bash после последнего символа «:» в строке, соответствующей пользователю. Однако для редактирования этого файла потребуются права администратора.
источник
«Терминал Gbnome» точно не эмулирует «xterm».
из: Википедия >> Терминал GNOME
Терминал GNOME эмулирует эмулятор терминала xterm и предоставляет некоторые из тех же функций.
Трактат о проблеме и ее решениях можно найти здесь:
Linux Backspace / Удалить мини-HOWTO
Самое простое решение (которое может работать здесь) - использовать: bash $ export TERM = gnome
источник
От имени пользователя root отредактируйте файл / etc / passwd для своего пользователя и измените с / bin / sh на / bin / bash
hdfs: x: 1020: 1001 :: / home / hdfs: / bin / sh to hdfs: x: 1020: 1001 :: / home / hdfs: / bin / bash
Это сработало для меня.
источник
Я перепробовал все вышеперечисленные плюсовые заметки от ( эта ссылка ) безуспешно Вы можете проверить, установлен ли vim.
Я обычно использую vi, а не vim. Поэтому я установил vim.
После этого нажатия клавиш начали работать правильно, когда я выполнил vi. Глядя на вывод следующего, похоже, что vi был сделан псевдонимом vim после установки:
источник
Это проблема совместимости с клавиатурой, т. Е. Как она интерпретируется в хост-системе. Возможно, вам придется использовать j или h для перемещения в редакторе vi в командном режиме. Стрелки не будут работать.
Проверьте настройки профиля -> совместимость в хост-системе для этого конкретного пользователя.
источник
Хорошо, я знаю, что это не «решение», скажем так, и это может не помочь многим из вас , но, надеюсь, это поможет по крайней мере 1 из вас . Это решило мою проблему.
Мой шестимесячный ребенок стучал по моей клавиатуре, и мои клавиши со стрелками перестали работать на моей сессии замазки в коробку Debian. Они работали везде (все остальные программы, кроме шпатлевки). После Google и даже посадки здесь (я собирался закрыть эту вкладку, это не решило это для меня). Я попробовал что-то. Я открыл новый сеанс SSH в том же окне, и мои клавиши со стрелками работали. Я присоединился к своему сеансу экрана, и они не работали. Так что что-то произошло, привязанное к текущей сессии экрана, отключив клавиши со стрелками. К сожалению, я был (я) в середине большого проекта, у меня было открыто 28 окон в сеансе экрана, и я не хотел закрывать сеанс, теряя свое место во всех 28 окнах.
Так..
Находясь в оболочке bash, я перепробовал все возможные комбинации: CTRL + вверх, вниз, влево, вправо, ALT + вверх, вниз, влево, вправо, SHIFT + вверх, вниз, влево вправо, CTRL + ALT + вверх, вниз , влево вправо, CTRL + SHIFT + вверх, вниз, влево, вправо и т. д. Тем не менее, безуспешно, я также попробовал меню Windows и клавиши приложения Windows вверх, вниз, влево вправо.
Теперь мои стрелки снова работают! Что-то в одной из комбинаций того, что было выше, и клавиши со стрелками исправили это.
источник
Ни один из приведенных выше ответов не устранил мою идентичную проблему, то есть не может использовать клавишу Backspace или аналогичные ключи после sshing на удаленный компьютер из Ubuntu (здесь ubuntu-17.10 с ncurses-6.0).
Это в конечном итоге проблема с terminfo. По сути, мой gnome-терминал говорит, что это терминал xterm-256color (через переменную TERM, который экспортируется с помощью ssh на удаленный компьютер), но на удаленном компьютере не было конфигурации terminfo для xterm-256color.
Выполнение следующих действий решило проблему:
infocmp без какой-либо опции создает листинг источника для терминала в переменной окружения $ TERM. Так что это эквивалентно infocmp -I $ TERM.
Затем полученный источник компилируется через тик.
Наконец, установите соответствующую конфигурацию terminfo в удаленном месте. Итак, в следующий раз, когда я подключусь к $ remote через $ host, он узнает о моем терминале.
источник