21

Как мне получить стандартный вывод всех команд, которые выполняются в скрипте bash?

То есть вывод должен содержать команды вывода и сами команды.

я нашел

#!/bin/bash -x

но это не совсем то же самое, потому что вместо

 mysql -v dbname < dump.sql | grep "CREATE TABLE"

это показывает

+ mysql -v dbname
+ grep 'CREATE TABLE'

2 ответа2

25

Используйте bash -v .

Это скрипт:

#!/bin/bash -v

echo "Hello, World" | sed 's|Hello|Goodbye|'

echo "Done."

Это вывод:

#!/bin/bash -v

echo "Hello, World" | sed 's|Hello|Goodbye|'
Goodbye, World

echo "Done."
Done.

К сожалению, нет специального маркера, такого как PS4 для печати расширенных команд. Вы можете комбинировать и то и другое, чтобы быстро определить команды:

#!/bin/bash -vx

echo "Hello, World" | sed 's|Hello|Goodbye|'
+ echo 'Hello, World'
+ sed 's|Hello|Goodbye|'
Goodbye, World

echo "Done."
+ echo Done.
Done.
8

set -x это другой способ сделать это.

$ cat a.sh
#!/bin/bash

set -x
echo "Hello, World" | sed 's|Hello|Goodbye|'
echo "Done."

Выход будет:

sh a.sh
+ echo 'Hello, World'
+ sed 's|Hello|Goodbye|'
Goodbye, World
+ echo Done.
Done.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .