Підказка Bash загублена і тепер показує помилку в PuTTY


1

Термінал мого VPS спочатку виглядав так у PuTTY:

[root@user ~]#

Тоді зараз це виглядає так:

-bash-4.1#

Це помилка, яка зараз з’являється:

-bash: /root/.bash_profile: line 6: syntax error near unexpected token `fi'
-bash: /root/.bash_profile: line 6: `fi'

Я не знаю, що сталося з цим.

Як мені повернутися до очікуваного [root@user ~]#?

У /root/.bash_profileвиглядає наступним чином : всередині

Знімок екрана PuTTY вмісту "/root/.bash_profile"


2
Виправити .bash_profile. Ми не можемо сказати вам, що з цим не так, оскільки ви не включите це у своє запитання.
DavidPostill

Привіт @DavidPostill, добре, відредагували питання, додавши .bash_profile друк, хоча це не виглядає інакше, ніж коли він був спочатку.
Жоао

Відсутня кишка -> . ~/.bashrc;?
DavidPostill

Тоді у вас повинен бути якийсь інший проблемний символ (символ Unicode?, Неправильний символ EOL?). Спробуйте ввести if ... fiрядки та видалити існуючі. Чи є там бродячий '? (питання згадує fi')
DavidPostill

@David ;не вніс жодних змін, 'у файлі немає жодних змін, fi'схоже на зображення. Я оновив файл тими ж речами і залишається тією ж проблемою.
Жоао

Відповіді:


1

Що спричинило проблему проти того, як її вирішити, це дві різні речі. Що я це знаю, це вміст досить стандартного .bash_profileфайлу Bash ; через RedHat 7:

# .bash_profile

# Get the aliases and functions
if [ -f ~/.bashrc ]; then
    . ~/.bashrc
fi

# User specific environment and startup programs

PATH=$PATH:$HOME/.local/bin:$HOME/bin

export PATH

І це вміст досить стандартного .bashrcфайлу Bash ; через RedHat 7:

# .bashrc

# Source global definitions
if [ -f /etc/bashrc ]; then
    . /etc/bashrc
fi

# Uncomment the following line if you don't like systemctl's auto-paging feature:
# export SYSTEMD_PAGER=

# User specific aliases and functions

Також вміст /etc/bashrcRedHat 7 є таким:

# /etc/bashrc

# System wide functions and aliases
# Environment stuff goes in /etc/profile

# It's NOT a good idea to change this file unless you know what you
# are doing. It's much better to create a custom.sh shell script in
# /etc/profile.d/ to make custom changes to your environment, as this
# will prevent the need for merging in future updates.

# are we an interactive shell?
if [ "$PS1" ]; then
  if [ -z "$PROMPT_COMMAND" ]; then
    case $TERM in
    xterm*|vte*)
      if [ -e /etc/sysconfig/bash-prompt-xterm ]; then
          PROMPT_COMMAND=/etc/sysconfig/bash-prompt-xterm
      elif [ "${VTE_VERSION:-0}" -ge 3405 ]; then
          PROMPT_COMMAND="__vte_prompt_command"
      else
          PROMPT_COMMAND='printf "\033]0;%s@%s:%s\007" "${USER}" "${HOSTNAME%%.*}" "${PWD/#$HOME/~}"'
      fi
      ;;
    screen*)
      if [ -e /etc/sysconfig/bash-prompt-screen ]; then
          PROMPT_COMMAND=/etc/sysconfig/bash-prompt-screen
      else
          PROMPT_COMMAND='printf "\033k%s@%s:%s\033\\" "${USER}" "${HOSTNAME%%.*}" "${PWD/#$HOME/~}"'
      fi
      ;;
    *)
      [ -e /etc/sysconfig/bash-prompt-default ] && PROMPT_COMMAND=/etc/sysconfig/bash-prompt-default
      ;;
    esac
  fi
  # Turn on parallel history
  shopt -s histappend
  history -a
  # Turn on checkwinsize
  shopt -s checkwinsize
  [ "$PS1" = "\\s-\\v\\\$ " ] && PS1="[\u@\h \W]\\$ "
  # You might want to have e.g. tty in prompt (e.g. more virtual machines)
  # and console windows
  # If you want to do so, just add e.g.
  # if [ "$PS1" ]; then
  #   PS1="[\u@\h:\l \W]\\$ "
  # fi
  # to your custom modification shell script in /etc/profile.d/ directory
fi

if ! shopt -q login_shell ; then # We're not a login shell
    # Need to redefine pathmunge, it get's undefined at the end of /etc/profile
    pathmunge () {
        case ":${PATH}:" in
            *:"$1":*)
                ;;
            *)
                if [ "$2" = "after" ] ; then
                    PATH=$PATH:$1
                else
                    PATH=$1:$PATH
                fi
        esac
    }

    # By default, we want umask to get set. This sets it for non-login shell.
    # Current threshold for system reserved uid/gids is 200
    # You could check uidgid reservation validity in
    # /usr/share/doc/setup-*/uidgid file
    if [ $UID -gt 199 ] && [ "`/usr/bin/id -gn`" = "`/usr/bin/id -un`" ]; then
       umask 002
    else
       umask 022
    fi

    SHELL=/bin/bash
    # Only display echos from profile.d scripts if we are no login shell
    # and interactive - otherwise just process them to set envvars
    for i in /etc/profile.d/*.sh; do
        if [ -r "$i" ]; then
            if [ "$PS1" ]; then
                . "$i"
            else
                . "$i" >/dev/null
            fi
        fi
    done

    unset i
    unset -f pathmunge
fi
# vim:ts=4:sw=4

Також зверніть увагу, що ви повинні редагувати такі файли лише за допомогою редактора чистого тексту. Якщо ви використовуєте текстовий процесор або що-небудь "більш фантазійне", то до вашого файлу можуть бути додані додаткові крихти та "gremlins", які змусять його задихатися.


1
Привіт Джейку, дякую за відповідь. Я скопіював ваш перший в той .bash_profileі несподіваний маркер все-таки трапляється. Я використовую linux centos 6-64.
Жоао

1
@Joao Який редактор ви використовуєте?
Олексій

@Joao Точно так, як заявляє Алекс. Реальність ця така проста, наскільки це виходить. Якщо помилка все ж з’являється, причиною цього може стати проблема з вашим редактором.
JakeGould

@ Алекс, я змінюю відкриття .bash_profileбезпосередньо через wincp, однак, коли ця проблема сталася, я не вносив жодних змін до неї, проблема сталася раптово під час входу в шпаклівку
Жоао

2
Якщо ви використовували WinSCPта намагалися редагувати його (можливо, за допомогою якоїсь програми Windows), велика ймовірність того, що закінчення рядка було порушено. Windows поставить у 0x0D,0x0Aтой час як баш очікуючи закінчення рядка як 0x0Aтільки
Alex

1

Видаліть ~/.bash_profileі додайте вміст нижче, ~/.profile
він також працюватиме з іншими оболонками.

# ~/.profile: executed by Bourne-compatible login shells.

if [ "$BASH" ]; then
  if [ -f ~/.bashrc ]; then
    . ~/.bashrc
  fi
fi

export PATH="${PATH}:${HOME}/bin"

Не забудьте пам’ятати, як різні оболонки обробляють файли запуску.
Ось схема .

Якщо ви використовуєте будь-які програми Windows для редагування вмісту файлів сценаріїв або файлів конфігурації на комп’ютерах на базі Unix, завжди слід пам’ятати, що рядки, що закінчуються в цих двох операційних системах, відрізняються. В Linux, кінець рядка - це характер 0x0A. Використовуйте редактори, які підтримують перемикання між завершенням рядків Unix та Windows, наприклад, Notepad++або використовуйте портовий vimредактор Windows .


Привіт @Alex, зробив те, що ви запропонували, але все ще з'являється несподіваний жетон з-bash-4.1#
Жоао

@Joao Якщо ви можете використовувати WinSCP, ви, ймовірно, можете також увійти і через ssh. Увійдіть у свій ящик через ssh та відредагуйте вміст у ~ / .profile nanoбезпосередньо на віддаленому комп’ютері. Запуск , коли ви увійшли: nano ~/.profile. Якщо ви не маєте доступу до віддаленого вікна через ssh, використовуйте notepad++для редагування, але переконайтеся, що ви змінили закінчення рядка (!!!) на Unix.
Олексій

1
"Якщо у вас немає доступу до віддаленого вікна через ssh", - Прочитайте питання. :) ОП працює там Bash, повний доступ.
Каміль Маціоровський

@KamilMaciorowski Величезний + для цього! Ви маєте рацію як завжди :) На жаль, момент ...
Алекс

0

Як згадував Алекс, ви, можливо, ненароком створили проблему в кінці рядка. Якщо припустити, що у вас є утиліта, спробуйте:

dos2unix /root/.bash_profile

Це перетворить нові символи рядка.


Привіт @ user10216038, спробували, і він повертає це:-bash: dos2unix: command not found
Жоао

Додайте утиліту dos2unix, якщо зможете. Крім того, ви можете спробувати скористатися командою strings, щоб зробити щось подібне: "strings /root/.bash_profile> tempbash.txt". Це змінить вікно 0D0A повертається до 0A, але воно також позбавить послідовних повернень, тому це не ідеально. Уважно порівняйте отриманий файл tempbash і скопіюйте його назад у bash_profile, якщо він виглядає правильно.
користувач10216038
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.