Ich habe dieses Problem nach dem Upgrade von Lubuntu von 12.10 auf 13.04.
Ich drücke Ctrl+ Alt+ 1, geben Sie Login, Passwort, warten 2 Sekunden und erhalten: ♦: command not found"
. Nach dieser Meldung kann ich ohne Probleme Befehle eingeben, aber was ist das?
echo $PATH
/usr/lib/lightdm/lightdm:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/home/vitaly/bin:/usr/java/jdk1.7.0_17/bin
Meine .bashrc
Datei ist:
# ~/.bashrc: executed by bash(1) for non-login shells.
# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc)
# for examples
# If not running interactively, don't do anything
case $- in
*i*) ;;
*) return;;
esac
# don't put duplicate lines or lines starting with space in the history.
# See bash(1) for more options
HISTCONTROL=ignoreboth
# append to the history file, don't overwrite it
shopt -s histappend
# for setting history length see HISTSIZE and HISTFILESIZE in bash(1)
HISTSIZE=1000
HISTFILESIZE=2000
# check the window size after each command and, if necessary,
# update the values of LINES and COLUMNS.
shopt -s checkwinsize
# If set, the pattern "**" used in a pathname expansion context will
# match all files and zero or more directories and subdirectories.
#shopt -s globstar
# make less more friendly for non-text input files, see lesspipe(1)
[ -x /usr/bin/lesspipe ] && eval "$(SHELL=/bin/sh lesspipe)"
# set variable identifying the chroot you work in (used in the prompt below)
if [ -z "${debian_chroot:-}" ] && [ -r /etc/debian_chroot ]; then
debian_chroot=$(cat /etc/debian_chroot)
fi
# set a fancy prompt (non-color, unless we know we "want" color)
case "$TERM" in
xterm-color) color_prompt=yes;;
esac
# uncomment for a colored prompt, if the terminal has the capability; turned
# off by default to not distract the user: the focus in a terminal window
# should be on the output of commands, not on the prompt
#force_color_prompt=yes
if [ -n "$force_color_prompt" ]; then
if [ -x /usr/bin/tput ] && tput setaf 1 >&/dev/null; then
# We have color support; assume it's compliant with Ecma-48
# (ISO/IEC-6429). (Lack of such support is extremely rare, and such
# a case would tend to support setf rather than setaf.)
color_prompt=yes
else
color_prompt=
fi
fi
if [ "$color_prompt" = yes ]; then
PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ '
else
PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '
fi
unset color_prompt force_color_prompt
# If this is an xterm set the title to user@host:dir
case "$TERM" in
xterm*|rxvt*)
PS1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$PS1"
;;
*)
;;
esac
# enable color support of ls and also add handy aliases
if [ -x /usr/bin/dircolors ]; then
test -r ~/.dircolors && eval "$(dircolors -b ~/.dircolors)" || eval "$(dircolors -b)"
alias ls='ls --color=auto'
#alias dir='dir --color=auto'
#alias vdir='vdir --color=auto'
alias grep='grep --color=auto'
alias fgrep='fgrep --color=auto'
alias egrep='egrep --color=auto'
fi
# some more ls aliases
alias ll='ls -alF'
alias la='ls -A'
alias l='ls -CF'
# Add an "alert" alias for long running commands. Use like so:
# sleep 10; alert
alias alert='notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e '\''s/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//'\'')"'
# Alias definitions.
# You may want to put all your additions into a separate file like
# ~/.bash_aliases, instead of adding them here directly.
# See /usr/share/doc/bash-doc/examples in the bash-doc package.
if [ -f ~/.bash_aliases ]; then
. ~/.bash_aliases
fi
# enable programmable completion features (you don't need to enable
# this, if it's already enabled in /etc/bash.bashrc and /etc/profile
# sources /etc/bash.bashrc).
if ! shopt -oq posix; then
if [ -f /usr/share/bash-completion/bash_completion ]; then
. /usr/share/bash-completion/bash_completion
elif [ -f /etc/bash_completion ]; then
. /etc/bash_completion
fi
fi
Meine .profile
Datei ist:
# ~/.profile: executed by the command interpreter for login shells.
# This file is not read by bash(1), if ~/.bash_profile or ~/.bash_login
# exists.
# see /usr/share/doc/bash/examples/startup-files for examples.
# the files are located in the bash-doc package.
# the default umask is set in /etc/profile; for setting the umask
# for ssh logins, install and configure the libpam-umask package.
#umask 022
# if running bash
if [ -n "$BASH_VERSION" ]; then
# include .bashrc if it exists
if [ -f "$HOME/.bashrc" ]; then
. "$HOME/.bashrc"
fi
fi
# set PATH so it includes user's private bin if it exists
if [ -d "$HOME/bin" ] ; then
PATH="$HOME/bin:$PATH"
fi
Die Datei /etc/profile
befindet sich hier: http://paste.ubuntu.com/5781361/
command-line
login
lubuntu
tty
Vitaly Zdanevich
quelle
quelle
echo $PATH
? (Bitte bearbeiten Sie es in Ihre Frage und antworten Sie dann).echo $PATH
meiner Frage hinzugefügt .Antworten:
Umgehung
Erstens glaube ich , dass Sie finden , wenn Sie gehen in tty1 - Ctrl+ Alt+ F1.
Nun denke, ich geschieht , was Sie gesagt sehr wahrscheinlich , weil Sie einen seltsamen Charakter wie ♦ haben ( Diamant - Anzug Charakter oder die spezielle Abzeichen für einen askubuntu Moderator ) in
~/.bashrc
oder~/.profile
Datei oder eine andere Datei , die verschiedene Initialisierungskommandos enthalten.Wie Sie im nächsten Bild sehen können, habe ich die
~/.bashrc
Datei bearbeitet , indem ich ♦ Zeichen in eine einzelne Zeile eingefügt habe. Als Ergebnis erhalte ich beim Öffnen des Terminals das von Ihnen beschriebene Problem:Das gleiche passiert, wenn ich mit Ctrl+ Alt+ in tty1 gehe F1.
Dateien , die Initialisierung Befehle enthalten , wenn ein Shell aufgerufen wird:
/etc/profile
,/etc/bashrc
,~/.bash_login
,~/.profile
,~/.bashrc
,~/.bash_aliases
und vielleicht andere. Siehe Shell-Initialisierungsdateien .Um schnell zu überprüfen, ob in einer dieser Dateien etwas nicht stimmt, können Sie den
source
Befehl verwenden. Beispielsweise:Endgültige Lösung
Nach einer Überprüfung
/etc/profile
unter http://paste.ubuntu.com/5781361/ stellte ich fest, dass in Zeile 31 "Rechts-Links-Überschreibung" steht -‮
Unicode-Zeichen. Öffnen Sie einfach die/etc/profile
Datei mitsudo -H gedit /etc/profile
, löschen Sie das seltsame Zeichen und das Problem verschwindet.Wenn Sie beispielsweise in HTML dieses Unicode-Zeichen mit dem Dezimalcode (
‮
) vor einer Zeile einfügen, sehen Sie sich amüsant an , was passiert:Eine weitere allgemeinere Lösung
Wir werden den genauen Befehl, der den Fehler verursacht, mit einer " Falle " finden.
Zuerst müssen wir eine neue Skriptdatei im
~/bin
Verzeichnis erstellen , nennen wir sielib.trap.sh
(gedit ~/bin/lib.trap.sh
), mit folgendem Inhalt:Nun müssen Sie nur noch die nächste Zeile am Anfang der Datei einfügen
/etc/profile
(sudo -H gedit /etc/profile
):Ändern Sie
<user_name>
mit Ihrem Benutzernamen. Auf diese Weise durchlaufen alle Dateien, die beim Aufrufen einer Shell Initialisierungsbefehle enthalten, den "Trap".Um zu testen, ob beispielsweise ein falscher Befehl
/etc/profile
eingegeben wurde, führen Sie die folgenden Befehle im Terminal aus:Bash-Quelle / etc / profile
Wenn etwas nicht stimmt, wie in diesem Fall, lautet das Ergebnis:
Jetzt wissen wir also sicher, dass es ein Problem (
command not found
) in der/etc/profile
Datei in Zeile 32 gibt (es befindet sich nicht in der Zeile 31 wie oben, da wir eine neue Zeile am Anfang der Datei eingefügt haben).Vielen Dank an Luca Borrione für sein Skript aus dieser Antwort , das mir geholfen hat, diese verallgemeinerte Lösung zu vervollständigen.
quelle
.bashrc
und.profile
zur Frage hinzugefügt - ich kann ♦ hier nicht finden..bash_aliases
,.pam_environment
usw.) enthalten, auf etwas Merkwürdiges prüfen, nicht unbedingt genau dieses Zeichen./etc/profile
. Sie haben dort etwas sehr Seltsames. Löschen Sie einfach alles zwischenfi
und drücken SieJAVA_HOME
nach ein oder zwei "Enter" und alles sollte danach in Ordnung sein. Ändern Sie die Datei mitsudo gedit /etc/profile
/etc/profile
. Seltsame Tasche.Führen Sie zum Debuggen der Initialisierungsskripten von bash Folgendes aus (nachdem Sie sich an der virtuellen Konsole angemeldet haben).
Der obige Befehl führt Bash im interaktiven (
-i
) Login (-l
) - Modus aus, genau wie daslogin
Programm, wenn Sie sich bei einer virtuellen Konsole anmelden.-c ''
macht es unmittelbar nach dem Durchlaufen des Initialisierungsskripts verlassen, und das-x
undPS4=...
macht es jede Befehlsausgabe, bevor es sie läuft, zusammen mit der Dateinamen und die Zeilennummer des Befehls. Dies sollte helfen, festzustellen, in welcher Zeile welcher Datei sich der ungültige Befehl befindet.Nebenbei bemerkt ist ♦ das Symbol, das die Standardschriftart für die virtuelle Konsole verwendet, um Zeichen zu drucken, für die es kein Symbol gibt.
quelle
Beim Durchsuchen Ihrer Initialisierungsdateien kann es hilfreich sein, nach dem Hexadezimalwert zu suchen, der für die Ausgabe von ♦ verwendet wird. Der Hex-Code für ♦ lautet laut Unicode-Zeichen 'BLACK DIAMOND SUIT' 2666 . Hinweis: Es gibt mindestens einen anderen Hex-Code, 25C6, der das gleiche oder ein ähnliches Symbol erzeugt. Suchergebnisse für "Diamant" anzeigen. Unicode-Zeichensuche
Vielleicht steht sowas
\u2666
in einem der Skripte. From Bash Reference Manual for echo - "\ uhhhh das Unicode-Zeichen (ISO / IEC 10646), dessen Wert der Hexadezimalwert HHHH (eine bis vier Hexadezimalziffern) ist"Dies hängt von der verwendeten Zeichenkodierung ab. Daher möchten Sie möglicherweise zuerst die wahrscheinlichsten suchen.
echo $LC_CTYPE
sollte die von Ihrer Shell verwendete Zeichenkodierung zurückgeben. Siehe So rufen Sie die Zeichencodierung des Terminals abquelle
~/.bash_history
gespeichert sind die auf PS1 interaktiv ausgeführten Befehle.\u2666
und ♦ in Catfish (Lubuntu-Suche) - nichts. Ich säehistory
- nichts. Ich sehe diese Nachricht nur in tty erst nach dem Login. Nachdemecho $LC_CTYPE
ich eine leere Zeile bekommen habe.locale
sollte den LC_CTYPE anzeigen. localeNotieren Sie den vollständigen Pfad zu einem bekannten Tool, mit dem Sie Ihre bashrc-Datei bearbeiten können, sowie den vollständigen Pfad zu Ihrer bashrc-Datei.
Finden Sie einen Missbrauch Ihrer
PATH
Variablen und kommentieren Sie ihn aus. Wahrscheinlich, wenn Sie versuchen, Ihrem Pfad etwas hinzuzufügen, wurde es in einfachen Anführungszeichen anstatt in doppelten Anführungszeichen angegeben.Kopieren Sie Ihre .bashrc-Datei in ein Tool wie https://www.shellcheck.net/ , um festzustellen , ob Sie Probleme mit der Verwendung von bash haben.
Hoffentlich hilft das.
quelle