블로그 이미지
초딩입맛제주아재
하고 싶은 것만 하며 살고 싶다

calendar

1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31
2007. 6. 1. 11:09 Programing/기타

2.2 배치 파일을 돕는 실제적인 것들

2.2.1 영원한 숙제, COMMAND.COM의 이해

도스의 주인공이자 실질적인 관리자 역할을 하는 COMMAND.COM의 역할은

이미 많은 사용자들이 잘 알고 있을 것이다. 그러나 도스 프롬프트상태의 명령

행에서 입력되는 모든 명령들을 해석하고 이를 컴퓨터가 알아채도록 번역해 주

는 명령어 해석기로서의 COMMAND.COM의 구성에 대해 말만큼이나 올바로

알고 있는 분들이 적은 것 같다.

이는 몇 가지 매뉴얼에서 이에 대한 정확한 의미를 제대로 전달해 주지 못하

기 때문에 발생한 오해에서 비롯되는 것이므로 이번 기회에 COMMAND.COM

이 컴퓨터에서 행하는 역할을 다시 한번 정확히 짚어 볼 필요가 있을 것이다.

배치 파일뿐만 아니라 메모리 기저에 상주하는 COMMAND.COM의 상주 부분이 키보드로부터 입력되어 들어온 명령들의 해석상의 문제들을 어떻게

처리하는지 확인하는 것도 좋은 방법이 될 것이다.

보통 명령 해석기의 존재는 프로그램 실행 도중 도스쉘로 빠졌을 때의 실

제 처리를 담당하는 SECONDARY COMMAND PROCESSOR와 부팅과 함께

설치되는 도스 커맨드 행 상태의 ORDINARY COMMAND PROCESSOR로

구분할 수 있다.

처음 컴퓨터를 켰을 때 읽어 들인 COMMAND.COM은 일반적인 도스 프

롬프트 상태에서의 도스 명령어 해석기로 작동한다. 그러나 윈도우즈나 도

스의 도스쉘같은 응용 프로그램은 도스쉘로 빠졌을 때 도스 프롬프트를 출

력하기 위해 두 번재 COMMAND.COM을 읽어 들이게 된다. 이렇게 두 가지

이 명령 처리 쉘로 메모리에 상주된 부분이 있기 때문에 도스쉘로 빠져 나

왔을 때의 기본 메모리 사용량은 감소하게 되는 것이다.

이 두 번재 명령 처리기를 탈출하기 위해서는 도스의 내부 명령어인 EXIT

를 입력함으로써 첫 번째 명령 처리기로 제어권을 넘겨줘야 한다.

그럼, 도스 COMMAND.COM의 사용 방법은 어떠한지 구체적인 사용 옵션

과 실행 상의 차이점을 공부해 보도록 하자.

COMMAND[[drive:]path][device][/E:nnnnN][/Y[/C command|/K command]]

 

보통 배치 파일이나 명령행 상태에서는 위와 같은 구조를 가질 수 있지만

CONFIG.SYS 파일 안에서 지정할 경우에는 SHELL 명령 뒤에 적어 줘야 한

. 또한 배치 파일에서 루트 이외의 다른 디렉토리에 COMMAND.COM이

존재할 경우 이의 위치를 도스에게 알려주기 위해 COMSPEC 환경 변수를

사용하여 지정할 수 있다.

 

SHELL=[[dos-drive:]dos-path]COMMAND.COM [[drive:]path][device]

[/E:nnnn][/P [/MSG]]

명령행에서 사용될 때와 CONFIG.SYS에서 사용될 때의 사용 옵션과 스위

치가 다른 것을 알 수 있다. 이는 실행 명령으로서 존재하는 배치 파일과

디바이스나 드라이버의 설치를 위한 CONFIG.SYS 파일의 양쪽 특성을 모두

처리해야 하는 COMMAND.COM의 명령 해석기로서의 특징 때문이다. 그럼

각 파라메터와 스위치에 대한 설명은 다음과 같다.

▶ [drive:]path

도스가 COMMAND.COM의 일부분을 다시 읽어 들일 때, 명령 해석기의

위치를 찾을 수 있는 드라이브와 디렉토리 경로를 지정한다.

▶ drive

CITY 명령을 이용하여 명령의 입력과 출력을 위한 다른 디바이스를 지정

할 수 있다. 기본적으로 현재 사용중인 장치가 계속 사용된다.

▶ /C command

앞의 CALL 명령에서 잠간 설명했듯이 두 번째 명령 해석기를 읽어 들여

command에 지정된 명령을 실행하고 다시 exit로 빠져 제어권을 첫 번째 명령

해석기로 돌려주는 기능을 한다. 이 스위치는 명령행의 마지막에 위치해야

한다.

▶ /E:nnnnn

명령 해석기를 위한 환경 크기를 설정하는 옵션이다. 단위는 바이트로 이

루어지며, 지정 가능한 값의 범위는 160부터 32768까지의 값이 사용된다. 아

무런 값이 지정되지 않으면 디폴트로 256이 사용된다.

▶ /K command

/k 스위치는 다음에 지정된 명령을 실행한다. 이 옵션은 도스 6.0부터 지원

되기 시작했으며, /c 스위치와 마찬가지로 명령행의 마지막에 위치해야 한다.

이 스위치는 윈도우즈에서 MS-DOS 프롬프트를 위한 STARTUP 배치 파일

을 지정하는데 특히 유용하며, 그렇게 하기 위해서는 pif 에디터에서 DOSPRMPT.PIF 파일을 열고 Optional Parameters 박스에 /K 스위치를 적어

줘야 한다. 그러나 이 /k 스위치를 config.sys의 shell행에 이용하지 않는 것이

좋다. 왜냐하면 사용자의 autoexec.bat 파일을 변형시키는 일부 응용 프로그램

과 인스톨 프로그램과 문제를 일으킬 소지가 많기 때문이다.

▶ /P

CONFIG.SYS의 SHELL 명령과 함께 사용되는 옵션이다. 이 스위치는 명령

어 해석기인 COMMAND.COM의 새로운 복사본을 항상 만들게 하여 메모리

에 이 상주 부분이 존재하도록 하는 역할을 한다.

▶ /MSG

이 스위치는 플로피 디스크로부터 MS-DOS를 실행하려고 할 때 유용하며,

/P 스위치와 함께 사용되야 한다.

▶ /Y

이 스위치는 /C나 /K 스위치에 의해 명시된 배치 파일을 한 줄씩 순차적

으로 진행하도록 COMMAND.COM에게 지시한다. 대개 이것은 배치 파일을

디버깅할 때 매우 유용하다.

2.2.2 COMMAND.COM의 환경 구성

도스 명령어 해석기인 COMMAND.COM의 환경은 처음 부팅할 때 구축된 다. 즉 사용자가 새로운 COMMAND.COM을 실행시켰을 때, 도스는 새로운 명

령어 처리 환경을 생성하게 된다는 뜻이다. 그리고 옵션 지정 없이 시작된 새

로운 환경은 기존에 메모리에 상주하고 있던 명령 환경을 복사하여 사용하게

된다. 이때 원래 환경에 영향을 미치지 않고 새로 시작한 COMMAND.COM의

환경을 바꿀 수 있는데 기본값으로는 256bytes가 할당된다.

도스가 명령어 해석기인 COMMAND.COM을 메모리로 불러들일 때 두 가

지 부분으로 나누어 불러들이게 된다. 메모리에 항상 상주하게 될 상주

(RETURN) 부분과 기본 메모리의 위 영역에 필요시마다 일시적으로 머무

TRANSIENT 부분으로 존재하는 COMMAND.COM은 다른 프로그램이

TRANSIENT 부분에 겹쳐 써질 경우 디스크로부터 다시 로딩해야 한다. 이

때 필요한 것이 환경 변수 COMSPEC의 지정 여부이다. 일단 COMSPEC을

통해 COMMAND.COM의 위치를 알고 있다면 지정된 디스크 드라이브에서

COMMAND.COM을 찾게 된다.

또한 DOS=HIGH 명령에 의해 도스 상주부가 HMA(High Memory Area)에

로딩되었다면, 기본 메모리를 차지하고 있던 COMMAND.COM의 상주 영역

이 빠지므로 이용할 수 있는 메모리의 양이 늘어나게 된다. 대개 도스는 에

러 메시지에 관한 내용을 메모리에 저장해 두지 않고 디스크에 존재하는

COMMAND.COM 파일 안에 남겨 두게 되는데, 도스가 에러 상황을 만났을

때마다 필요한 메시지를 디스크로부터 찾아서 화면에 보여주게 된다.

만약 하드 디스크 대신 플로피디스크로부터 부팅하였다면 도스는 드라이브

A로부터 COMMAND.COM을 찾아 에러 메시지를 보여주려 할 것이다. 이때 A

드라이브에 들어 있는 디스켓에 COMMAND.COM이 포함되더 있지 않다면, 도

스는 에러에 적절하고 완전한 메시지를 표시하지 못한다. 그런 경우를 대비해

COMMAND.COM의 /MSD 스위치는 디스크에 저장되어 있는 에러 메시지를

메모리에 상주시켜 완전한 에러 메시지를 보여주게 하는 것이다.

2.2.3 도스 환경의 조율사 SET

SET 명령은 MS-DOS 환경 변수를 화면에 보여주거나 지정하고 제거하는데

이용되는 명령이다. 배치 파일이나 프로그램이 도스 상태에서 적절히 적절한

환경으로 설정되었는지를 나타내거나 제어하는데도 이 SET 명령이 사용되며,

도스를 시작할 때마다 환경 변수를 조정하기 위해서는 AUTOEXEC.BAT나

CONFIG.SYS에 직접 SET VARIABLE=[STRING]과 같은 형식을 통해 지정해

줘야 한다.

도스 프롬프트에서 현재 지정된 환경 변수들을 알아보기 위해서는 그냥SET 이라고 입력하면 설정된 모든 환경 변수와 환경 영역에 기록된 모든 내용을

보여준다. 이 환경변수는 프로그램 사용중이나 배치 파일 실행에 있어서 매우

중요한 요소로 사용될 수 있다.

일반적으로 이름 변수명과 문자열을 연결 지어 환경 영역에 지정해 주기

위해서는 다음과 같이 SET 명령을 이용한다. 예를 들어 노턴 유틸리티 디렉

토리인 C:NORTON을 SYMENTEC이란 이름 변수에 연결 지었다면, 배치 파

일에서 노턴 디렉토리를 % 기호로 둘러친 이름 변수로 표현할 수 있게 된다

다시 말하자면 앞서 SYMENTEC이란 이름 변수에 연결된 C:NORTON이란

디렉토리를 직접 대입 변수명으로 사용할 수 있다는 것이다.

dir %SYMENTEC%

 

이와 비슷하게 SET 명령은 배치 파일에서 또 다른 사용 방법이 있다. 바로

PATH 환경 변수에 새로운 디렉토리를 지정하거나 추가할 때도 이용될 수 있

. 다음의 배치 파일 예제에서 볼 수 있듯이 기존의 %PATH% 변수에 대체 변수 %1이 추가되는 새로운 패스 환경을 만드는 SET PATH = 명령을 사용 하였다.

 

@echo off

rem PATH_ADD.BAT adds anew directory to the PATH environment variable.

set path=%1, %path%

set

<예제 2-14> set문을 이용한 배치 파일

기본적으로 SET 명령을 통하지 않고도 도스는 3가지의 환경 변수를 설정

하게 된다. 경로명을 설정하는 PATH, 명령 대기 상태를 나타내는 PROMPT

그리고 명령 처리기의 선택을 가리키는 CONFIG가 그것이다. 또한 환경 변

수는 변수명에 입력된 모든 문자를 대문자로 기억하게 된다. 실제로 대소문

자 구분이 있는 것은 아니지만 변수명에 치환된 문자열이 대입되는 것을 보

면 쉽게 알 수 있을 것이다.

그리고 IF 명령에서 환경 변수를 사용할 때에는, 널(NULL)값이 사용되는

경우를 대비해서 따옴표로 둘러쳐서 표현해야 할 필요가 있다. 보통은 환경

변수나 문자열에 따옴표를 사용하면 이것까지 환경 영역에 저장되어 표현되

므로 주의해야 한다.

그럼, 사용자의 컴퓨터의 환경 영역을 조회하기 위해서 어떻게 해야 하는

? 그것은 도스 프롬프트에서 SET라고 입력하고 엔터를 치면 현재 설정된

모든 환경 변수의 내용을 보여준다.

C:>SET

CONFIG=4DOS

PATH=C:SYSDOS;C:;C:qemm;C:SYS4DOS;E:HWP25;C:U1;C:U1EQ;

C:U1A;C:U1V;C:U2NT;

LOADHIDATA=C:QEMMLOADHI.RF

COMSPEC=c:sys4dos4dos.com

ARJ_SW= -JYRY -JV -I1 -JM1

TEMP4DOS=f:

TMP=f:

TEMP=F:

PKTMP=f:

.LZH=C:U1ALHA.EXE E

.ARJ=C:U1AARJ.EXE E

.ZIP=C:U1APKUNZIP

.OMP=C:U1AOMP.EXE E

.SQZ=C:U1ASQZ.EXE E

.DOC=C:U1MDS.EXE

.TXT=C:U1MDS.EXE

.HWP=d:hwp25hwp.exe

PROMPT=Type EXIT to return to hwp$_$p$g

SYMANTEC=C:U2NT

PCTOOLS=D:PCTOOLSDATA

HWPSTUB=SWAPDIR E:HNCTEMP -SWAPNAME HWP25.SWP

<SET 명령으로 설정된 환경 변수의 목록>

이제 환경 변수에 대해 어느 정도 이해가 가셨으리라 믿는다. 다음 장은

실제적으로 시스템을 구성하는 autoexec.bat 파일과 config.sys에 대해서 자세

히 살펴볼 것이다. 자신의 컴퓨터를 가지고서도 배치 파일과 config.sys 파일

구성에 어려움을 겪거나 두려움을 가진 분들은 꼭 한번 봐야 할 것이다. 가

장 기본적인 내용이면서도 선뜻 시스템을 망가뜨리지 않을까 겁먹고 계신

분들에게 좋은 해결책이 될 것이다.

윈도우즈의 문제를 해결하는 방법.

윈도우즈를 실행하다 보면 메모리 문제, 디바이스 설치에 관한 문제, INI 파일 설정에

관한 문제와 같은 다양한 문제에 골치를 섞이게 된다. 이런 문제를 도스에서는 직접

AUTOEXEC.BAT나 CONFIG.SYS 파일을 조작하거나 수정함으로써 해결할 수 있지만,

윈도우즈는 복잡한 구성 때문인지 몰라도 만만한 해결책이 없을 것이다.

윈도우즈는 기본적으로 실행 옵션을 여러 개 사용할 수 있는데, 여기서 디버그 모드로

윈도우즈를 실행하면서 충돌이 발생하는 부분을 찾아낼 수 있다.

윈도우즈는 디버그 모드로 실행시킬 때 4가지 옵션을 제공하며, WIN /?를 치면 옵션의

설명이 자세히 나온다. 그럼 4가지 옵션을 주고 디버그 모드로 실행시키는 방법을 알아보자.

① WIN /D:X

이 옵션을 주는 이유는 사용자가 판단하게 메모리 충돌이나 디바이스 램상주 프로그램

이 상위 메모리에 상주했을 때 윈도우즈와 충돌을 일으킬 경우 이를 해결하기 위해 사

용하는 것이다.

② WIN /D:F

이 옵션은 윈도우즈의 386확장 모드 실행시 조정되는 32비트 디스크 엑세스 옵션과

관계된 문제를 해결하는 것이다. 옵션 F는 32비트 디스크 엑세스 방식으로 하드 디

스크에 접근하는 것을 방지하고 표준 바이오스 방식을 통해 하드 디스크에 접근하게

하는 옵션이다.

③ WIN /D:V

V 옵션은 하드 디스크를 가상 메모리로 사용하지 못하게 하는 옵션이다. 스카시 드라

이브를 가지고 있는 경우 이 옵션이 충돌을 해결하는데 중요하다.

④ WIN /D:S

이 옵션 명령은 상위 메모리의 F000에서 FFFF까지의 영역에 존재하는 롬바이오스

부분에서 SYSTEM BREAK POINT라는 지시행을 찾지 못하도록 하는 것이다.



기본적으로 이런 실행 모드 조정을 통해 문제를 발견할 수 있지만, 더욱 세부적인 사

항을 알아내지 못할 경우에는 윈도우즈 실행시 어딘가 문제가 있을 때이다.

윈도우즈 디렉토리에 부트 로그 파일을 만들기 위해서는 윈도우즈를 실행할 때 /B옵

션을 줘서 실행해야 한다. 그러면 윈도우즈가 설치될 때, 메모리에 띄워지는 모든 프

로그램과 파일에 대한 기록을 하게 된다. 여기서 이 로딩기록을 적어 둔 파일을 분석

해 봄으로써 문제의 원인을 찾아낼 수 있다.

이 방법은 INI 파일에 기록된 실행 순서에 맞지 않는 프로그램이나 폰트, 데이터 파일

등이 로딩되는데 실패하는가의 여부를 파악하기 쉽다. 이 같은 사실을 알아내는데는

에러 코드를 로그 파일에 기록하기 때문이다. 에러 코드에 관한 내용은 다음과 같다.

⊙ 윈도우즈의 에러 발생시 각 코드 번호가 의미하는 것

0 : 메모리가 부족한 경우이다.

2 : 지정된 파일이 해당 디렉토리에 없는 경우

3 : 패스가 지정되어 있지 않는 경우, 기존에 있던 디렉토리를 지운 경우에 발생한다

5 : 파일 확장자나 데이터를 작업이나 프로그램에 동작으로 연결하려다 실패한 경우이다.

6 : 라이브러리에서 각 작업에 대해 분리된 데이터 세그먼트를 요구하는 경우

8 : 응용 프로그램을 실행하기 위한 메모리가 부족하다.

10 : 구버전의 윈도우즈 파일을 가져온 경우이다.

11 : EXE 파일이 손상된 경우이거나 윈도우주용 프로그램이 아닌 경우이다.

12 : OS/2전용 응용 프로그램을 윈도우즈에서 실행하려는 경우에 발생한다.

13 : MS-DOS 4.0과 OS/2 1.0에서 실행할 수 있는 패밀리 모드 프로그램을 실행

하려는 경우이다.

14 : EXE 파일이 손상되어 있다.

15 : 보호 모드에서 예전에 만들어 호환되지 않는 윈도우즈 실행 파일을 실행하려는 경우

16 : 여러 개의 데이터 세그먼트가 들어 있는 EXE 파일의 복제본을 띄우려 하는 경우

17 : 대형 프레임에서 EMS모드로 이미 사용 중인 DLL을 응용 프로그램과 연결하려는 경우

18 : 보호 모드용 프로그램을 리얼 모드로 실행하려는 경우에 발생한다.

참고사항 : 도서출판 (혜지원), 저자(오요한), book title(배치와 매크로)

posted by 초딩입맛제주아재