J'ai ce problème après la mise à niveau de Lubuntu du 12.10 au 13.04.
Je presse Ctrl+ Alt+ 1, entrez login, mot de passe, attendez deux secondes et obtenir: ♦: command not found"
. Après ce message, je peux taper des commandes sans problème, mais qu'est-ce que c'est?
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
Mon .bashrc
dossier est:
# ~/.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
Mon .profile
dossier est:
# ~/.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
Le fichier /etc/profile
est ici: http://paste.ubuntu.com/5781361/
command-line
login
lubuntu
tty
Vitaly Zdanevich
la source
la source
echo $PATH
? (Veuillez l' éditer dans votre question puis répondre).echo $PATH
à ma question.Réponses:
solution de contournement
Tout d'abord, je pense que vous faites référence à quand vous allez dans tty1 - Ctrl+ Alt+ F1.
Maintenant, je pense qu'il se passe ce que vous avez dit le plus probablement parce que vous avez un caractère étrange comme ♦ ( caractère de costume de diamant ou le badge spécial pour un modérateur askubuntu ) dans
~/.bashrc
ou~/.profile
fichier ou autre fichier contenant diverses commandes d'initialisation.Comme vous pouvez le voir dans l'image suivante, j'ai édité le
~/.bashrc
fichier en mettant ♦ le caractère sur une seule ligne. Par conséquent, lorsque j'ouvre le terminal, le problème décrit par vous est résolu:Il se passe la même chose quand je vais en tty1 avec Ctrl+ Alt+ F1.
Les fichiers qui contiennent des commandes d' initialisation lorsqu'un shell est appelé:
/etc/profile
,/etc/bashrc
,~/.bash_login
,~/.profile
,~/.bashrc
,~/.bash_aliases
et peut - être d' autres. Voir Fichiers d'initialisation du shell .Pour vérifier rapidement si l'un de ces fichiers contient quelque chose de mal à l'intérieur, vous pouvez utiliser la
source
commande. Par exemple:Solution finale
Après avoir inspecté à
/etc/profile
partir de http://paste.ubuntu.com/5781361/ , j'ai trouvé que sur la ligne 31 il y a "Override de droite à gauche" -‮
caractère unicode. Ouvrez simplement le/etc/profile
fichier avecsudo -H gedit /etc/profile
, assurez-vous de supprimer ce caractère étrange et le problème disparaîtra.Comme amusement, en HTML par exemple, si vous insérez ce caractère unicode en utilisant du code décimal (
‮
) devant une ligne, regardez ce qui se passe:Une autre solution plus généralisée
Nous trouverons la commande exacte qui provoque l'erreur en utilisant un " trap ".
Tout d'abord, nous devons créer un nouveau fichier de script dans le
~/bin
répertoire, appelons-lelib.trap.sh
(gedit ~/bin/lib.trap.sh
), avec ce qui suit à l'intérieur:Maintenant, la seule chose que vous avez à faire est de mettre la ligne suivante au début du fichier
/etc/profile
(sudo -H gedit /etc/profile
):Changez
<user_name>
avec votre nom d'utilisateur. Comme ça, tous les fichiers qui contiennent des commandes d'initialisation lorsqu'un shell est invoqué passeront par le "trap".Pour tester s'il y a une mauvaise commande,
/etc/profile
par exemple, exécutez les commandes du terminal suivant:bash source / etc / profile
Si quelque chose ne va pas, comme dans ce cas, le résultat sera:
Donc, maintenant nous savons avec certitude qu'il y a un problème (
command not found
) dans le/etc/profile
fichier à la ligne 32 (ce n'est pas à la ligne 31 comme ci-dessus car nous avons inséré une nouvelle ligne au début du fichier).Un grand merci à Luca Borrione pour son script de cette réponse qui m'a aidé à compléter cette solution généralisée.
la source
.bashrc
et.profile
vers la question - je ne trouve pas ♦ ici..bash_aliases
,.pam_environment
, etc.) pour somenthing l' intérieur étrange, ce personnage pas nécessairement exactement./etc/profile
. Vous avez là quelque chose de très étrange. Il suffit de supprimer tout ce qui se trouve entrefi
etJAVA_HOME
, après avoir appuyé sur un ou deux "Entrée", tout devrait être correct après. Modifier le fichier avecsudo gedit /etc/profile
/etc/profile
. Sac étrange.Pour déboguer les scripts d'initialisation de bash, exécutez ce qui suit (après vous être connecté sur la console virtuelle).
Ce qui précède exécute bash en mode de
-i
connexion interactif ( )-l
, de la même manière que lelogin
programme lorsque vous vous connectez à une console virtuelle.-c ''
lui fait quitter immédiatement après avoir exécuté les scripts d'initialisation, et le-x
et luiPS4=...
fait sortir chaque commande, avant de les exécuter, avec le nom de fichier et le numéro de ligne de cette commande. Cela devrait aider à déterminer quelle ligne de quel fichier réside cette commande non valide.Sur une note latérale, ♦ est le symbole que la police par défaut pour la console virtuelle utilise pour imprimer les caractères pour lesquels il n'a pas de symbole.
la source
Lors de la recherche de vos fichiers d'initialisation, il peut être utile de rechercher l'hexadécimal utilisé pour sortir le ♦. Le code hexadécimal pour ♦ est 2666, selon le caractère Unicode 'BLACK DIAMOND SUIT' . Remarque: Il existe au moins un autre code hexadécimal, 25C6, qui produit le même symbole ou un aspect similaire. Voir les résultats de la recherche pour "diamant". Recherche de caractères Unicode
Peut-être que quelque chose comme
\u2666
c'est dans l'un des scripts. Du manuel de référence de Bash pour l'écho - "\ uhhhh le caractère Unicode (ISO / IEC 10646) dont la valeur est la valeur hexadécimale HHHH (un à quatre chiffres hexadécimaux)"Cela dépend du codage de caractères utilisé, vous pouvez donc commencer par rechercher les plus probables.
echo $LC_CTYPE
devrait retourner le codage de caractères utilisé par votre shell. Voir Comment obtenir l'encodage de caractères du terminalla source
~/.bash_history
sont stockées les commandes exécutées interactivement sur PS1.\u2666
♦ dans Catfish (recherche Lubuntu) - rien. Je sèmehistory
- rien. Je vois ce message uniquement en tty seulement après la connexion. Aprèsecho $LC_CTYPE
avoir obtenu une ligne vide.locale
doit afficher le LC_CTYPE. localeÉcrivez le chemin d'accès complet à un outil connu qui vous permettra de modifier votre fichier bashrc, ainsi que le chemin d'accès complet à votre fichier bashrc.
Trouvez tout abus à votre
PATH
variable et commentez-le. Probablement lorsque vous essayez d'ajouter quelque chose à votre chemin d'accès, il a été placé entre guillemets simples au lieu de guillemets doubles.Copiez votre .bashrc dans un outil comme https://www.shellcheck.net/ pour voir si vous avez des problèmes flagrants avec l'utilisation de bash.
J'espère que ça t'as aidé.
la source