Microsoft MVP성태의 닷넷 이야기
오류 유형: 941. Golang - os.StartProcess() 사용 시 오류 정리 [링크 복사], [링크+제목 복사],
조회: 6132
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

Golang - os.StartProcess() 사용 시 오류 정리

살을 붙여 가면서 설명해 보겠습니다. ^^

// 명령행에서 "c:\temp> sc delete test_app"이라고 실행하는 것을 go 언어로 실행

package main

import (
	"log"
	"os"
)

func main() {
	exePath := "sc"
	args := []string{"delete", "test_app"}

	p, err := os.StartProcess(exePath, args, &os.ProcAttr{})
	if err == nil {
		status, err := p.Wait()
		if err == nil {
			log.Printf("errorlevel: %v", status.ExitCode())
		}
	}

	if err != nil {
		log.Println(err)
	}
}

우선, 위와 같은 식으로 프로그램을 실행하면 이런 오류가 발생합니다.

fork/exec sc: invalid argument

왜냐하면, os.ProcAttr 구조체에는 3개의 표준 I/O, Error 스트림을 지정해야 하기 때문입니다. 그래서 이렇게 지정하면,

var procAttr os.ProcAttr
procAttr.Files = []*os.File{os.Stdin, os.Stdout, os.Stderr}

exePath := "sc"
args := []string{"delete", "test_app"}

p, err := os.StartProcess(exePath, args, &procAttr)

이제는 이런 오류가 발생합니다.

fork/exec sc: The system cannot find the file specified.

오류 메시지에도 나오지만, 비록 윈도우 명령행에서 어디서든지 실행할 수 있는 sc.exe 실행 파일을 지정했어도 os.StartProcess의 인자에는 정확한 경로를 지정해야 합니다. 따라서 다음과 같이 설정해야 합니다.

exePath := "c:\\windows\\system32\\sc.exe"

// 또는,
// exePath, err := exec.LookPath("sc")

하지만, 그래도 이런 오류가 발생합니다. ^^

ERROR:  Unrecognized command
...[생략: sc.exe 실행 결과]...
errorlevel: 1639

실행 결과를 보면, sc.exe 실행 파일 자체는 정상적으로 구동이 된 것을 볼 수 있지만 이제는 명령어에 전달한 옵션이 잘못되었기 때문에 나온 현상입니다. 윈도우 개발자들이 흔히 할 수 있는 실수인데요, *NIX 관행에서는 인자에 실행 파일까지 전달하는 관습(?)이 있어서 옵션에도 다음과 같이 전달해야 합니다.

args := []string{"sc", "delete", "test_app"}
// 또는,
// args := []string{exePath, "delete", "test_app"}

끝입니다. ^^ 저렇게까지 해야 이제 정상적으로 실행됩니다.




그나마 다행인 것은, 전달한 인자에 공백이 있어도 이것을 하나로 인식해 처리해 준다는 점입니다. 그래서 다음과 같이 프로그램 경로와 그 인자에 공백이 있어도,

exePath := "C:\\Program Files\\dotnet\\dotnet.exe"
args := []string{exePath, "C:\\temp\\Console App1\\ConsoleApp1\\bin\\Debug\\net8.0\\ConsoleApp1.dll"}

실행에 문제가 없습니다. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 12/28/2024]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  82  83  84  85  86  87  88  [89]  90  ...
NoWriterDateCnt.TitleFile(s)
11745정성태10/15/201818258오류 유형: 495. TFS 파일/폴더 삭제 - The item [...] could not be found in your workspace, or you do not have permission to access it.
11744정성태10/15/201819948개발 환경 구성: 410. msbuild로 .pubxml 설정에 따른 배포 파일을 만드는 방법
11743정성태10/15/201821001웹: 37. Bootstrap의 dl/dt/dd 조합에서 문자열이 잘리지 않도록 CSS 설정
11742정성태10/15/201826282스크립트: 13. 윈도우 배치(Batch) 스크립트에서 날짜/시간 문자열을 구하는 방법
11741정성태10/15/201820618Phone: 13. Android - LinearLayout 간략 설명
11740정성태10/15/201821844사물인터넷: 51. Synology NAS(DS216+II)를 이용한 원격 컴퓨터의 전원 스위치 제어
11739정성태10/15/201823579Windows: 151. 윈도우 10의 전원 관리가 "균형 조정(Balanced)"으로 바뀌는 문제
11738정성태10/15/201822055오류 유형: 494. docker - 윈도우에서 실행 시 "unknown shorthand flag" 오류 [1]
11737정성태10/13/201818321오류 유형: 493. Azure Kudu - There are ... items in this directory, but maxViewItems is set to 299
11736정성태10/12/201819896오류 유형: 492. Visual Studio 로딩 시 오류 - The 'Scc Display Information' package did not load correctly.
11735정성태10/12/201825732VS.NET IDE: 129. Visual Studio - 특정 문자(열)를 개행 문자로 바꾸는 방법
11734정성태10/10/201819313Linux: 4. Synology NAS(DS216+II)에 FTDI 장치 연결 후 C#(.NET Core)으로 DTR 제어파일 다운로드1
11733정성태10/10/201822767Linux: 3. Synology NAS(DS216+II)에서 FTDI 장치를 C/C++로 제어
11732정성태10/10/201822691디버깅 기술: 119. windbg 분석 사례 - 종료자(Finalizer)에서 예외가 발생한 경우 비정상 종료(Crash) 발생파일 다운로드1
11731정성태10/9/201821859개발 환경 구성: 409. C# - REST API를 이용해 Azure Kudu 서비스 이용 - 웹 앱 확장 처리파일 다운로드1
11730정성태10/9/201821297개발 환경 구성: 408. C# - REST API를 이용해 Azure Kudu 서비스 이용 - 파일 처리파일 다운로드1
11729정성태10/9/201823950Windows: 150. 윈도우에서 ARP Cache 목록 확인 및 삭제하는 방법
11728정성태10/9/201821638사물인터넷: 50. Audio Jack 커넥터의 IR 적외선 송신기 [1]
11727정성태10/8/201823013오류 유형: 491. Visual Studio의 리눅스 SSH 원격 연결 - "Connectivity Failure. Please make sure host name and port number are correct."
11726정성태10/7/201825616사물인터넷: 49. 라즈베리 파이를 이용해 원격 컴퓨터의 전원 스위치 제어파일 다운로드1
11724정성태10/5/201825527개발 환경 구성: 407. 유니코드와 한글 - "Hangul Compatibility Jamo"파일 다운로드1
11723정성태10/4/201818304개발 환경 구성: 406. "Docker for Windows" 컨테이너 내의 .NET Core 응용 프로그램에서 직렬 포트(Serial Port, COM Port) 사용 방법
11722정성태10/4/201822830.NET Framework: 798. C# - Hyper-V 가상 머신의 직렬 포트와 연결된 Named Pipe 간의 통신파일 다운로드1
11721정성태10/4/201823192.NET Framework: 797. Linux 환경의 .NET Core 응용 프로그램에서 직렬 포트(Serial Port, COM Port) 사용 방법파일 다운로드1
11720정성태10/4/201824702개발 환경 구성: 405. Hyper-V 가상 머신에서 직렬 포트(Serial Port, COM Port) 사용
11719정성태10/4/201825236.NET Framework: 796. C# - 인증서를 윈도우에 설치하는 방법
... 76  77  78  79  80  81  82  83  84  85  86  87  88  [89]  90  ...