Bash 스크립트 기초: 디버깅 기법 이해 (16일차)







스크립트 디버깅 – Bash 스크립트 기초

스크립트 디버깅 – Bash 스크립트 기초

안녕하세요, mj입니다! 오늘은 셸 스크립트 디버깅의 중요성과 다양한 디버깅 기법을 배워보겠습니다. 스크립트를 작성할 때 발생할 수 있는 오류를 찾고 수정하는 과정은 매우 중요합니다. 디버깅 기술을 익히면 효율적으로 문제를 해결할 수 있습니다. 다양한 실습을 통해 디버깅 능력을 향상시켜보세요!

1. 디버깅의 중요성

디버깅은 프로그램의 오류를 찾아 수정하는 과정입니다. 스크립트가 예상대로 작동하지 않을 때, 그 원인을 찾는 것이 디버깅의 핵심입니다. 이 과정에서 발생하는 오류를 이해하고 해결하는 능력은 프로그래머에게 필수적입니다.

2. Bash에서의 디버깅 기법

Bash 스크립트에서 사용할 수 있는 주요 디버깅 기법은 다음과 같습니다:

  • set -x: 스크립트 실행 시 각 명령어를 출력하여 실행 과정을 확인합니다.
  • set -e: 명령어 실행 중 오류가 발생하면 즉시 스크립트를 종료합니다.
  • echo: 변수의 값을 출력하여 현재 상태를 확인합니다.
  • trap: 오류 발생 시 특정 명령어를 실행하도록 설정할 수 있습니다.

3. 실습 예제 1: set -x 사용하기

먼저 set -x를 사용하여 스크립트의 실행 과정을 출력해보겠습니다:

#!/bin/bash

set -x  # 디버깅 모드 활성화

echo "디버깅 시작"
a=5
b=10
c=\$((a + b))
echo "결과는: \$c"
echo "디버깅 종료"

출력 결과 1

+ echo '디버깅 시작'
디버깅 시작
+ a=5
+ b=10
+ c=15
+ echo '결과는: 15'
결과는: 15
+ echo '디버깅 종료'
디버깅 종료

4. 실습 예제 2: set -e 사용하기

다음으로 set -e를 사용하여 오류 발생 시 스크립트를 종료해보겠습니다:

#!/bin/bash

set -e  # 오류 발생 시 종료

echo "디버깅 시작"
mkdir /root/testdir  # 권한이 없는 디렉토리 생성 시도
echo "디버깅 종료"

출력 결과 2

디버깅 시작
mkdir: /root/testdir: Permission denied

5. 실습 예제 3: echo로 변수 값 확인하기

변수의 값을 확인하기 위해 echo를 사용해보겠습니다:

#!/bin/bash

echo "디버깅 시작"
name="mj"
echo "사용자 이름은: \$name"
echo "디버깅 종료"

출력 결과 3

디버깅 시작
사용자 이름은: mj
디버깅 종료

6. 실습 예제 4: trap 사용하기

오류 발생 시 특정 명령어를 실행하도록 설정할 수 있는 trap를 사용해보겠습니다:

#!/bin/bash

trap 'echo "오류 발생!"' ERR  # 오류 발생 시 메시지 출력

echo "디버깅 시작"
invalid_command  # 존재하지 않는 명령어
echo "디버깅 종료"

출력 결과 4

디버깅 시작
bash: invalid_command: command not found
오류 발생!

7. 결론

오늘은 Bash 스크립트의 디버깅 기법에 대해 배워보았습니다. set 명령어, echo, trap 등을 활용하여 스크립트의 오류를 찾아 수정하는 방법을 익혔습니다. 이러한 디버깅 기술은 스크립트의 안정성을 높이고 문제를 빠르게 해결하는 데 큰 도움이 됩니다. 다음 포스팅에서는 더 고급 디버깅 기법을 다뤄보겠습니다.

감사합니다!


Leave a Comment