Псевдонимы, недоступные при использовании sudo

Похоже, у вас есть файл, который вам нужен для доступа, но только после того, как пароль его разблокировал, правильно?

Если это так, я настоятельно рекомендую вам взглянуть на использование TrueCrypt - http: / /www.truecrypt.org/. Вы можете установить его как в Windows, так и в Ubuntu и использовать один и тот же пароль для разблокировки одного и того же файла в любой системе.

Единственным недостатком вашей ситуации является то, что вы конкретно указываете «защиту паролей файлов», но TrueCrypt создает том с зашифрованным содержимым внутри тома.

134
задан 18 January 2011 в 03:02

127 ответов

у меня есть другое решение, в котором вы не должны добавить sudo в качестве псевдонима. Я запускаю Линукс Минт 17.3, но он должен быть очень похож на Ubuntu.

когда вы root, то .profile запускается из своего домашнего каталога. Если Вы не знаете, что домашний каталог под корень, затем вы можете проверить с:

sudo su echo $HOME

как вы можете видеть, дом root это /root/. Проверьте его содержимое:

cd $HOME ls -al

должен быть файл .profile. Откройте файл и добавьте следующие строки:

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

в общем, что этот скрипт делает это, чтобы проверить файл на [F9]. Если файлы присутствуют, он выполняет файл.

сохранить [F10] для файл и создавать свои псевдонимы на [F11]. Если у вас уже есть файл aliases готов, затем скопируйте файл в эту папку

повторно запустите терминал и вы хорошо идти!

0
ответ дан 4 August 2018 в 20:06

у меня есть еще одно хорошее решение, которое добавляет немного доверия тоже:

использовать автодополнение bash для автоматической замены слов sudo с их псевдонимы, когда нажав клавишу Tab.

Сохранить как /etc/bash_completion.d/sudo-alias.bashcomp, и он автоматически будет загружен в интерактивный запуска командной оболочки:

_comp_sudo_alias() { from="$2"; COMPREPLY=() if [[ $COMP_CWORD == 1 ]]; then COMPREPLY=( "$( alias -p | grep "^ *alias $from=" | sed -r "s/^ *alias [^=]+='(.*)'$/\1/" )" ) return 0 fi return 1 } complete -o bashdefault -o default -F _comp_sudo_alias sudo

после входа в новый терминал, и вы должны быть хорошо идти.

1
ответ дан 4 August 2018 в 20:06
  • 1
    Есть способ получить список псевдонимов, специально предназначенных для завершения: compgen -a – muru 8 September 2017 в 20:04
  • 2
    @muru: Спасибо, но в этом случае мне нужны значения, а не ключи. Итак, какой псевдоним, который был введен, будет заменен. Вы вводите псевдоним (например, в sudo ll), нажмите [TAB ↹], и сценарий находит ll в списке назначений псевдонимов, вырезает то, что ему назначено, и вставляет это. (Таким образом, вы получите, например, sudo ls -lahvF --color=auto --time-style=long-iso.) – Evi1M4chine 9 September 2017 в 04:29

Ответ @Alvins является самым коротким. Без сомнений! : -)

Однако я подумал о решении командной строки для выполнения команды aliased в sudo, где нет необходимости переопределять sudo с помощью команды alias.

Здесь мое предложение для тех, кому это может быть интересно:

Решение

type -a <YOUR COMMAND HERE> | grep -o -P "(?<=\`).*(?=')" | xargs sudo

Пример

В случае команды ll

type -a ll | grep -o -P "(?<=\`).*(?=')" | xargs sudo

Объяснение

, когда у вас есть псевдоним (например: ll), команда type -a возвращает выражение с псевдонимом:

$type -a ll ll is aliased to `ls -l'

с grep вы выбираете текст между акцентом `и апострофом 'в этом случае ls -l

И xargs выполняет выделенный текст ls -l как параметр sudo.

Да, немного дольше, но выполняет команду aliased в sudo ;-) Нет необходимости переопределять sudo как псевдоним.

3
ответ дан 4 August 2018 в 20:06
  • 1
    Может быть проще, если вы использовали встроенный модуль alias, так как его вывод чище. alias ll alias ll='ls -ahlF'. – muru 15 February 2015 в 23:41
  • 2
    Вот версия, включающая предложение @ muru: alias ll | sed "s/.*'\(.*\)'.*/\1/g" | xargs sudo. – ACK_stoverflow 27 July 2016 в 20:07
  • 3
    Я думаю, что смысл изначальный вопрос был, чтобы сохранить работу, не имея sudo -i во-первых, чтобы запустить псевдоним команды, но делать это сразу. Имея такой сложной команда побеждает, что. Вы могли бы просто сделать первое, и значительно быстрее. – Evi1M4chine 8 September 2017 в 18:13

Псевдонимы специфичны для пользователя - вам нужно определить их в /root/.bashrc

3
ответ дан 4 August 2018 в 20:06
  • 1
    Они уже находятся под /корень/.bashrc и поэтому это не проблема – kemra102 19 January 2011 в 00:55
  • 2
    Этот ответ был бы правильным только для ситуации, когда вы запускаете оболочку как root, как в случае с sudo -s или sudo -i (и только , если они запускаются сами по себе, чтобы получить корневую оболочку, не с формами sudo -s command... или sudo -i command...) или sudo bash или sudo su, или ситуация, когда вы включили учетные записи root и имеете корневую оболочку таким образом. Когда пользователь, не являющийся пользователем root, запускает sudo command... из своей собственной оболочки, расширение псевдонима выполняется их собственной оболочкой без полномочий root. sudo сам не расширяет псевдонимы, поэтому применительно к ситуации, описанной в вопросе , этот ответ неверен. – Eliah Kagan 17 September 2017 в 10:31

я написал функцию bash, что тени sudo.

он проверяет, есть ли у меня псевдоним для данной команды и запускает псевдоним команды вместо литерала с [F4] и в этом случае.

вот моя функция как один-лайнер:

sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" ; else command sudo $@ ; fi }

или красиво отформатировано:

sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" else command sudo "$@" fi }

Вы может добавить его в свой файл .bashrc, не забудьте источник его или перезагрузить терминальную сессию потом применять изменения.

6
ответ дан 4 August 2018 в 20:06

топ-проголосовали ответ будет один большой. Однако, если вы Тип [F2] и поднять на суда оперативную (#) Вы не будете иметь псевдонимы, которую вы хотите использовать.

, чтобы использовать свои псевдонимы (и все остальное) на клавиши [F4] подскажите, использование:

sudo cp "$PWD"/.bashrc /root/.bashrc

, где "$ФРД" автоматически раскладывается в положение "/Home/ВАШЕ_ИМЯ_ПОЛЬЗОВАТЕЛЯ"

0
ответ дан 4 August 2018 в 20:06

У меня есть другое решение, в котором вам не нужно добавлять sudo в качестве псевдонима. Я запускаю Linux Mint 17.3, но он должен быть очень похож на Ubuntu.

Когда вы являетесь пользователем root, тогда .profile запускается из его домашнего каталога. Если вы не знаете, что такое домашний каталог под root, вы можете проверить:

sudo su echo $HOME

Как вы можете видеть, дом root - /root/. Проверьте его содержимое:

cd $HOME ls -al

Должен быть файл .profile. Откройте файл и добавьте следующие строки:

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

В основном, этот скрипт bash выполняет проверку файла с именем .bash_aliases. Если файлы присутствуют, он выполняет файл.

Сохраните файл .profile и создайте свои псевдонимы в .bash_aliases. Если вы уже подготовили файл псевдонимов, скопируйте файл в это место

Перезапустите терминал, и вы готовы к работе!

0
ответ дан 6 August 2018 в 04:06

У меня есть еще одно приятное решение, которое добавляет немного доверия:

Использовать завершение bash, чтобы автоматически заменить слова позади sudo своими псевдонимами при нажатии вкладки.

Сохранить это как /etc/bash_completion.d/sudo-alias.bashcomp, и он должен автоматически загружаться при запуске интерактивной оболочки:

_comp_sudo_alias() { from="$2"; COMPREPLY=() if [[ $COMP_CWORD == 1 ]]; then COMPREPLY=( "$( alias -p | grep "^ *alias $from=" | sed -r "s/^ *alias [^=]+='(.*)'$/\1/" )" ) return 0 fi return 1 } complete -o bashdefault -o default -F _comp_sudo_alias sudo

Затем войдите в новый терминал, и вам должно быть хорошо идти.

1
ответ дан 6 August 2018 в 04:06
  • 1
    Есть способ получить список псевдонимов, специально предназначенных для завершения: compgen -a – muru 8 September 2017 в 20:04
  • 2
    @muru: Спасибо, но в этом случае мне нужны значения, а не ключи. Итак, какой псевдоним, который был введен, будет заменен. Вы вводите псевдоним (например, в sudo ll), нажмите [TAB ↹], и сценарий находит ll в списке назначений псевдонимов, вырезает то, что ему назначено, и вставляет это. (Таким образом, вы получите, например, sudo ls -lahvF --color=auto --time-style=long-iso.) – Evi1M4chine 9 September 2017 в 04:29

Ответ @Alvins является самым коротким. Без сомнений! : -)

Однако я подумал о решении командной строки для выполнения команды aliased в sudo, где нет необходимости переопределять sudo с помощью команды alias.

Здесь мое предложение для тех, кому это может быть интересно:

Решение

type -a <YOUR COMMAND HERE> | grep -o -P "(?<=\`).*(?=')" | xargs sudo

Пример

В случае команды ll

type -a ll | grep -o -P "(?<=\`).*(?=')" | xargs sudo

Объяснение

, когда у вас есть псевдоним (например: ll), команда type -a возвращает выражение с псевдонимом:

$type -a ll ll is aliased to `ls -l'

с grep вы выбираете текст между акцентом `и апострофом 'в этом случае ls -l

И xargs выполняет выделенный текст ls -l как параметр sudo.

Да, немного дольше, но выполняет команду aliased в sudo ;-) Нет необходимости переопределять sudo как псевдоним.

3
ответ дан 6 August 2018 в 04:06
  • 1
    Может быть проще, если вы использовали встроенный модуль alias, так как его вывод чище. alias ll alias ll='ls -ahlF'. – muru 15 February 2015 в 23:41
  • 2
    Вот версия, учитывающая предложение @Муру по: alias ll | sed "s/.*'\(.*\)'.*/\1/g" | xargs sudo. – ACK_stoverflow 27 July 2016 в 20:07
  • 3
    Я думаю, что исходный вопрос заключался в том, чтобы сохранить работу, не имея сначала sudo -i, чтобы запустить команду aliased, но сразу же это сделало. Такая сложная команда побеждает. Вы могли бы просто сделать первое, и быть намного быстрее. – Evi1M4chine 8 September 2017 в 18:13

Псевдонимы специфичны для пользователя - вам нужно определить их в /root/.bashrc

3
ответ дан 6 August 2018 в 04:06
  • 1
    Они уже находятся под /корень/.bashrc и поэтому это не проблема – kemra102 19 January 2011 в 00:55
  • 2
    Этот ответ был бы правильным только для ситуации, когда вы запускаете оболочку как root, например, sudo -s или sudo -i (и только , если они запускаются сами по себе, чтобы получить корневую оболочку, не с формами sudo -s command... или sudo -i command...) или sudo bash или sudo su, или ситуация, когда вы включили учетные записи root и имеете корневую оболочку таким образом. Когда пользователь, не являющийся пользователем root, запускает sudo command... из своей собственной оболочки, расширение псевдонима выполняется их собственной оболочкой без полномочий root. sudo сам не расширяет псевдонимы, поэтому применительно к ситуации, описанной в вопросе , этот ответ неверен. – Eliah Kagan 17 September 2017 в 10:31

Я написал для него функцию Bash, которая затеняет sudo.

Он проверяет, есть ли у меня псевдоним для данной команды и запускается команда aliased вместо литеральной с sudo в этом case

Вот моя функция как однострочный:

sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" ; else command sudo $@ ; fi }

Или красиво отформатирован:

sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" else command sudo "$@" fi }

Вы можете добавить его в свой .bashrc, не забудьте указать его или перезапустить сеанс терминала после этого, чтобы применить изменения.

6
ответ дан 6 August 2018 в 04:06

Ответ на главный голос - отличный. Однако, если вы наберете sudo -i и поднимите сообщение sudo (#), вы не будете использовать псевдонимы, которые хотите использовать.

Чтобы использовать ваши псевдонимы (и все остальное) в # prompt, use:

sudo cp "$PWD"/.bashrc /root/.bashrc

Где «$ PWD» автоматически расширяется в «/ home / YOUR_USER_NAME»

0
ответ дан 6 August 2018 в 04:06

У меня есть другое решение, в котором вам не нужно добавлять sudo в качестве псевдонима. Я запускаю Linux Mint 17.3, но он должен быть очень похож на Ubuntu.

Когда вы являетесь пользователем root, тогда .profile запускается из его домашнего каталога. Если вы не знаете, что такое домашний каталог под root, вы можете проверить:

sudo su echo $HOME

Как вы можете видеть, дом root - /root/. Проверьте его содержимое:

cd $HOME ls -al

Должен быть файл .profile. Откройте файл и добавьте следующие строки:

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

В основном, этот скрипт bash выполняет проверку файла с именем .bash_aliases. Если файлы присутствуют, он выполняет файл.

Сохраните файл .profile и создайте свои псевдонимы в .bash_aliases. Если вы уже подготовили файл псевдонимов, скопируйте файл в это место

Перезапустите терминал, и вы готовы к работе!

0
ответ дан 6 August 2018 в 04:07

У меня есть еще одно приятное решение, которое добавляет немного доверия:

Использовать завершение bash, чтобы автоматически заменить слова позади sudo своими псевдонимами при нажатии вкладки.

Сохранить это как /etc/bash_completion.d/sudo-alias.bashcomp, и он должен автоматически загружаться при запуске интерактивной оболочки:

_comp_sudo_alias() { from="$2"; COMPREPLY=() if [[ $COMP_CWORD == 1 ]]; then COMPREPLY=( "$( alias -p | grep "^ *alias $from=" | sed -r "s/^ *alias [^=]+='(.*)'$/\1/" )" ) return 0 fi return 1 } complete -o bashdefault -o default -F _comp_sudo_alias sudo

Затем войдите в новый терминал, и вам должно быть хорошо идти.

1
ответ дан 6 August 2018 в 04:07
  • 1
    Есть способ получить список псевдонимов, специально предназначенных для завершения: compgen -a – muru 8 September 2017 в 20:04
  • 2
    @muru: Спасибо, но в этом случае мне нужны значения, а не ключи. Итак, какой псевдоним, который был введен, будет заменен. Вы вводите псевдоним (например, в sudo ll), нажмите [TAB ↹], и сценарий находит ll в списке назначений псевдонимов, вырезает то, что ему назначено, и вставляет это. (Таким образом, вы получите, например, sudo ls -lahvF --color=auto --time-style=long-iso.) – Evi1M4chine 9 September 2017 в 04:29

@Элвинами ответ самый короткий. Без сомнения! :-)

однако я думал, что решения командную строку для выполнения псевдонима команды в команду sudo, где нет необходимости переосмысления sudo с помощью команды alias.

вот мое предложение для тех, кого это может заинтересовать:

решение

type -a <YOUR COMMAND HERE> | grep -o -P "(?<=\`).*(?=')" | xargs sudo

пример

в случае ll команда

type -a ll | grep -o -P "(?<=\`).*(?=')" | xargs sudo

объяснение

, когда у вас есть псевдоним (например: ll) команды нажать [F8] возвращает искаженные выражения:

$type -a ll ll is aliased to `ls -l'

с [F9] и вы выделите текст между акцентом и апостроф ' в таком случае ls -l

и xargs выполняет выбранный текст ls -l, а параметр [от f13].

да, немного дольше, но выполнить псевдонима команды в судо ;-) не нужно переопределять sudo в качестве псевдонима.

3
ответ дан 6 August 2018 в 04:07
  • 1
    Может быть проще, если вы использовали встроенный модуль alias, так как его вывод чище. alias ll alias ll='ls -ahlF'. – muru 15 February 2015 в 23:41
  • 2
    Вот версия, включающая предложение @ muru: alias ll | sed "s/.*'\(.*\)'.*/\1/g" | xargs sudo. – ACK_stoverflow 27 July 2016 в 20:07
  • 3
    Я думаю, что смысл изначальный вопрос был, чтобы сохранить работу, не имея sudo -i во-первых, чтобы запустить псевдоним команды, но делать это сразу. Имея такой сложной команда побеждает, что. Вы могли бы просто сделать первое, и значительно быстрее. – Evi1M4chine 8 September 2017 в 18:13

псевдонимы конкретного пользователя - нужно их определять в /root/.bashrc

3
ответ дан 6 August 2018 в 04:07
  • 1
    Они уже находятся под /корень/.bashrc и поэтому это не проблема – kemra102 19 January 2011 в 00:55
  • 2
    Этот ответ был бы правильным только для ситуации, когда вы запускаете оболочку как root, например, sudo -s или sudo -i (и только , если они запускаются сами по себе, чтобы получить корневую оболочку, не с формами sudo -s command... или sudo -i command...) или sudo bash или sudo su, или ситуация, когда вы включили учетные записи root и имеете корневую оболочку таким образом. Когда пользователь, не являющийся пользователем root, запускает sudo command... из своей собственной оболочки, расширение псевдонима выполняется их собственной оболочкой без полномочий root. sudo сам не расширяет псевдонимы, поэтому применительно к ситуации, описанной в вопросе , этот ответ неверен. – Eliah Kagan 17 September 2017 в 10:31

я написал функцию bash, что тени sudo.

он проверяет, есть ли у меня псевдоним для данной команды и запускает псевдоним команды вместо литерала с [F4] и в этом случае.

вот моя функция как один-лайнер:

sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" ; else command sudo $@ ; fi }

или красиво отформатировано:

sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" else command sudo "$@" fi }

Вы может добавить его в свой файл .bashrc, не забудьте источник его или перезагрузить терминальную сессию потом применять изменения.

6
ответ дан 6 August 2018 в 04:07

Ответ на главный голос - отличный. Однако, если вы наберете sudo -i и поднимите сообщение sudo (#), вы не будете использовать псевдонимы, которые хотите использовать.

Чтобы использовать ваши псевдонимы (и все остальное) в # prompt, use:

sudo cp "$PWD"/.bashrc /root/.bashrc

Где «$ PWD» автоматически расширяется в «/ home / YOUR_USER_NAME»

0
ответ дан 6 August 2018 в 04:07

У меня есть другое решение, в котором вам не нужно добавлять sudo в качестве псевдонима. Я запускаю Linux Mint 17.3, но он должен быть очень похож на Ubuntu.

Когда вы являетесь пользователем root, тогда .profile запускается из его домашнего каталога. Если вы не знаете, что такое домашний каталог под root, вы можете проверить:

  sudo su echo $ HOME  

Как вы можете видеть, дом root - / root / . Проверьте его содержимое:

  cd $ HOME ls -al  

Должен быть файл .profile . Откройте файл и добавьте следующие строки:

 , если ["$ BASH"];  то если [-f ~ / .bash_aliases], то.  ~ / .bash_aliases fi fi  

В основном, этот скрипт bash выполняет проверку файла с именем .bash_aliases . Если файлы присутствуют, он выполняет файл.

Сохраните файл .profile и создайте свои псевдонимы в .bash_aliases . Если вы уже подготовили файл псевдонимов, скопируйте файл в это место

Перезапустите терминал, и вы готовы к работе!

0
ответ дан 7 August 2018 в 22:06

Псевдонимы специфичны для пользователя - вам нужно определить их в /root/.bashrc

3
ответ дан 7 August 2018 в 22:06

Я написал для него функцию Bash, которая затеняет sudo .

Он проверяет, имеет ли я псевдоним для данной команды и запускает команду aliased вместо буквенного с sudo в этом случае.

Вот моя функция как однострочный:

  sudo () {если псевдоним «$ 1» & amp; gt;  ;  / dev / null;  затем $ (введите «$ 1» | sed -E '/ ^ .* `(. *). $ / \ 1 /')" $ {@: 2} ";  else command sudo $ @;  fi}  

Или красиво отформатирован:

  sudo () {если псевдоним «$ 1» & gt; & gt;  / dev / null;  затем $ (введите «$ 1» | sed -E 's /^.* `(. *). $ / \ 1 /')" $ {@: 2} "else command sudo" $ @ "fi}  

Вы можете добавить его в свой файл .bashrc , не забудьте его загрузить или перезапустить сеанс терминала, чтобы применить изменения.

6
ответ дан 7 August 2018 в 22:06

Высший проголосовавший ответ - отличный. Однако, если вы наберете sudo -i и поднимите сообщение sudo ( # ), вы не будете использовать псевдонимы, которые хотите использовать.

To используйте свои псевдонимы (и все остальное) в приглашении # , используйте:

  sudo cp "$ PWD" /. bashrc /root/.bashrc   

Где «$ PWD» автоматически расширяется до «/ home / YOUR_USER_NAME»

0
ответ дан 7 August 2018 в 22:06

У меня есть еще одно приятное решение, которое добавляет немного доверия:

Использовать завершение bash для автоматической замены слов позади sudo с их псевдонимами при нажатии вкладки.

Сохраните это как /etc/bash_completion.d/sudo-alias.bashcomp , и он должен автоматически загружаться при запуске интерактивной оболочки:

  _comp_sudo_alias (  ) {from = "$ 2";  COMPREPLY = (), если [[$ COMP_CWORD == 1]];  затем COMPREPLY = ("$ (alias -p | grep" ^ * alias $ from = "| sed -r" s / ^ * alias [^ =] + = '(. *)' $ / \ 1 / ")"  ) return 0 fi return 1} complete -o bashdefault -o default -F _comp_sudo_alias sudo  

Затем войдите в новый терминал, и вам должно быть хорошо идти.

1
ответ дан 7 August 2018 в 22:06
Ответ

@ Алвинс самый короткий. Без сомнений! : -)

Однако я подумал о решении командной строки для выполнения команды aliased в sudo, где нет необходимости переопределять sudo с псевдонимом

Вот мое предложение для тех, кому это может быть интересно:

Решение

  type -a & YOUR COMMAND HERE & gt;  |  grep -o -P "(? & lt; = \`). * (? = ') "|  xargs sudo  

Пример

В случае команды ll

  type -a ll |  grep -o -P "(? & lt; = \`). * (? = ') "|  xargs sudo  

Объяснение

, когда у вас есть псевдоним (например: ll ), команда типа -a ] возвращает выражение с псевдонимом:

  $ type -a ll ll является псевдонимом `ls -l ' 

с grep вы выбираете текст между акцентом `и апострофом 'в этом случае ls -l

И xargs выполняет выделенный текст ls -l как параметр sudo .

Да, немного дольше, но полностью чист ;-) Не нужно переопределять sudo как псевдоним. [ ! d24]

3
ответ дан 7 August 2018 в 22:06

Высший проголосовавший ответ - отличный. Однако, если вы наберете sudo -i и поднимите сообщение sudo ( # ), вы не будете использовать псевдонимы, которые хотите использовать.

To используйте свои псевдонимы (и все остальное) в приглашении # , используйте:

  sudo cp "$ PWD" /. bashrc /root/.bashrc   

Где «$ PWD» автоматически расширяется до «/ home / YOUR_USER_NAME»

0
ответ дан 10 August 2018 в 10:21

Я написал для него функцию Bash, которая затеняет sudo .

Он проверяет, имеет ли я псевдоним для данной команды и запускает команду aliased вместо буквенного с sudo в этом случае.

Вот моя функция как однострочный:

  sudo () {если псевдоним «$ 1» & amp; gt;  ;  / dev / null;  затем $ (введите «$ 1» | sed -E '/ ^ .* `(. *). $ / \ 1 /')" $ {@: 2} ";  else command sudo $ @;  fi}  

Или красиво отформатирован:

  sudo () {если псевдоним «$ 1» & gt; & gt;  / dev / null;  затем $ (введите «$ 1» | sed -E 's /^.* `(. *). $ / \ 1 /')" $ {@: 2} "else command sudo" $ @ "fi}  

Вы можете добавить его в свой файл .bashrc , не забудьте его загрузить или перезапустить сеанс терминала, чтобы применить изменения.

6
ответ дан 10 August 2018 в 10:21

У меня есть еще одно приятное решение, которое добавляет немного доверия:

Использовать завершение bash для автоматической замены слов позади sudo с их псевдонимами при нажатии вкладки.

Сохраните это как /etc/bash_completion.d/sudo-alias.bashcomp , и он должен автоматически загружаться при запуске интерактивной оболочки:

  _comp_sudo_alias (  ) {from = "$ 2";  COMPREPLY = (), если [[$ COMP_CWORD == 1]];  затем COMPREPLY = ("$ (alias -p | grep" ^ * alias $ from = "| sed -r" s / ^ * alias [^ =] + = '(. *)' $ / \ 1 / ")"  ) return 0 fi return 1} complete -o bashdefault -o default -F _comp_sudo_alias sudo  

Затем войдите в новый терминал, и вам должно быть хорошо идти.

1
ответ дан 10 August 2018 в 10:21
Ответ

@ Алвинс самый короткий. Без сомнений! : -)

Однако я подумал о решении командной строки для выполнения команды aliased в sudo, где нет необходимости переопределять sudo с псевдонимом

Вот мое предложение для тех, кому это может быть интересно:

Решение

  type -a & YOUR COMMAND HERE & gt;  |  grep -o -P "(? & lt; = \`). * (? = ') "|  xargs sudo  

Пример

В случае команды ll

  type -a ll |  grep -o -P "(? & lt; = \`). * (? = ') "|  xargs sudo  

Объяснение

, когда у вас есть псевдоним (например: ll ), команда типа -a ] возвращает выражение с псевдонимом:

  $ type -a ll ll является псевдонимом `ls -l ' 

с grep вы выбираете текст между акцентом `и апострофом 'в этом случае ls -l

И xargs выполняет выделенный текст ls -l как параметр sudo .

Да, немного дольше, но полностью чист ;-) Не нужно переопределять sudo как псевдоним. [ ! d24]

3
ответ дан 10 August 2018 в 10:21

Псевдонимы специфичны для пользователя - вам нужно определить их в /root/.bashrc

3
ответ дан 10 August 2018 в 10:21

У меня есть другое решение, в котором вам не нужно добавлять sudo в качестве псевдонима. Я запускаю Linux Mint 17.3, но он должен быть очень похож на Ubuntu.

Когда вы являетесь пользователем root, тогда .profile запускается из его домашнего каталога. Если вы не знаете, что такое домашний каталог под root, вы можете проверить:

  sudo su echo $ HOME  

Как вы можете видеть, дом root - / root / . Проверьте его содержимое:

  cd $ HOME ls -al  

Должен быть файл .profile . Откройте файл и добавьте следующие строки:

 , если ["$ BASH"];  то если [-f ~ / .bash_aliases], то.  ~ / .bash_aliases fi fi  

В основном, этот скрипт bash выполняет проверку файла с именем .bash_aliases . Если файлы присутствуют, он выполняет файл.

Сохраните файл .profile и создайте свои псевдонимы в .bash_aliases . Если вы уже подготовили файл псевдонимов, скопируйте файл в это место

Перезапустите терминал, и вы готовы к работе!

0
ответ дан 10 August 2018 в 10:21

Другие вопросы по тегам:

Похожие вопросы: