Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

PowerShell/명령행에서 JDK/JRE를 무인(unattended)/자동 설치를 하는 방법

우선, PowerShell에서 JDK/JRE를 설치하는 것에 대해 다음과 같은 방법이 나옵니다.

How to install JDK from PowerShell silently
; http://blag.koveras.org/2011/12/24/how-to-install-jdk-from-powershell-silently/

그런데... 2011년 글이라서 그런지 잘 안되는 군요. ^^; 어쨌든 위의 글로부터 얻은 것은 JDK 설치가 MSI(Microsoft Installer) 방식이라는 점입니다. 일단 그걸로 충분하군요. ^^




JRE 먼저 설명해 보겠습니다. 오라클 사이트에서 JRE 설치 파일(예를 들어, JavaSetup8u51.exe)을 실행만 하면 다음의 경로에,
%LOCALAPPDATA%Low\Sun\Java\jre1.8.0_51

이런 파일들이 생성됩니다.

  • LZMA_EXE
  • jre1.8.0_51full.msi

이 중에서 msi 파일은 설치를 마치면 없어지는 반면 LZMA_EXE는 그대로 남아 있습니다.

따라서, JRE 설치 파일을 실행한 상태에서 "%LOCALAPPDATA%Low\Sun\Java\jre1.8.0_51" 폴더로 이동한 후 그 2개의 파일을 다른 곳에 복사하면 됩니다.

.msi 파일을 구했으니 이걸로 끝난 것 같지만... 아쉽게도 해당 msi 파일을 실행하면 다음과 같은 오류만 만날 뿐입니다.

This installation package could not be opened. Contact the application vendor to verify that this is a valid Windows Installer Package.

왜냐하면 .msi 파일이 압축된 상태이기 때문입니다. 따라서 같이 생성된 LZMA_EXE 파일을 "lzma.exe"로 확장자를 바꾸고 다음과 같이 실행해 주면 원래의 상태로 압축 해제된 파일을 구할 수 있습니다.

lzma.exe d jre1.8.0_51full.msi jre.msi

실제로 오라클의 JRE 설치 파일이 실행되었을 때 Process Explorer로 보면, LZMA_EXE가 하위 프로세스로 생성되고 아래와 같은 실행 절차를 거치는 것을 확인할 수 있습니다.

"%LOCALAPPDATA%Low\Sun\Java\jre1.8.0_51\LZMA_EXE" d "%LOCALAPPDATA%Low\Sun\Java\jre1.8.0_51\jre1.8.0_51full.msi" "%LOCALAPPDATA%Low\Sun\Java\jre1.8.0_51\msi.tmp"

어쨌든, 이렇게 구한 최종 jre.msi 파일을 원하는 옵션을 넣어 실행해 주면 무인 설치가 가능합니다.

msiexec.exe /i d:\temp\jre.msi /quiet /qn /norestart /log d:\temp\install.log INSTALLDIR=d:\jre INSTALLDIRPUBJRE=d:\jre

또는 msiexec.exe를 떼고 다음과 같이 실행해도 됩니다.

d:\temp\jre.msi /quiet /qn /norestart /log d:\temp\install.log INSTALLDIR=d:\jre INSTALLDIRPUBJRE=d:\jre

설치가 끝날 때까지 명령행에서 기다리도록 만드는 것도 가능합니다.

start /wait d:\temp\jre.msi /quiet /qn /norestart /log d:\temp\install.log INSTALLDIR=d:\jre INSTALLDIRPUBJRE=d:\jre

PowerShell이라면 Start-Process를 이용하면 되고!

$arguments = "/quiet /qn /norestart /log d:\temp\install.log INSTALLDIR=d:\jre INSTALLDIRPUBJRE=d:\jre"

start-process -filepath d:\temp\jre.msi -argumentlist $arguments  -passthru -wait 

이때 주의할 것이 있는데요. /log 옵션에 주는 install.log 파일의 생성 위치인 d:\temp 폴더가 미리 존재해 있어야 합니다. 안 그러면 무인 설치는 이유도 알 수 없이 그냥 조용히 설치 작업을 종료합니다.




이제 JDK 무인설치를 해볼까요?

다운로드 받은 파일(예를 들어, jdk-8u51-windows-x64.exe)을 실행시키면 "%LOCALAPPDATA%Low\Sun\Java\jdk1.8.0_51_x64" 폴더에 다음의 5가지 파일이 생성됩니다.

  • jdk1.8.0_51.msi
  • sj180510.cab
  • ss180510.cab
  • st180510.cab
  • sz180510.cab

따라서 이 파일들을 복사/보관해 준 후 그냥 다음의 옵션으로 실행해 주면 됩니다.

msiexec.exe /i d:\temp\jdk1.8.0_51.msi /quiet /qn /norestart /log d:\temp\install.log INSTALLDIR=d:\jdk INSTALLDIRPUBJRE=d:\jre

또 언제 설치 방식이 바뀔지는 모르지만... ^^ 일단 현재는 이런 식으로 해주면 무인 설치를 할 수 있습니다.




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







[최초 등록일: ]
[최종 수정일: 8/10/2015]

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

비밀번호

댓글 작성자
 



2015-08-12 05시53분
조금 다른 케이스인데인데요. *일반 유저*로 PC를 사용하고 있습니다. 그래서, 관리자 권한이 있는 VM에서 설치한 jdk를 적당한 경로에 복사해서 JAVA_HOME 변수만 설정해서 사용하고 있습니다. 일종의 꽁수지요 :-)
GiSeong Eom
2015-08-12 12시32분
@GiSeong Eom님, 멋진 방법입니다. 어차피 내부 사용 목적인데 ^^ 그런 간단한 방법을 생각 못했군요.
정성태
2017-03-23 08시38분
여전히 "일반 유저"로 사용하고 있는데, jdk 설치 파일(.exe)에서 필요한 파일들 추출하는 방법을 찾았습니다.
https://gist.github.com/giseongeom/ce47435dffd13f0880957903d35ac383

GiSeong Eom

... [31]  32  33  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
13198정성태12/18/202214061.NET Framework: 2080. C# - Microsoft.XmlSerializer.Generator 처리 없이 XmlSerializer 생성자를 예외 없이 사용하고 싶다면?파일 다운로드1
13197정성태12/17/202213595.NET Framework: 2079. .NET Core/5+ 환경에서 XmlSerializer 사용 시 System.IO.FileNotFoundException 예외 발생하는 경우파일 다운로드1
13196정성태12/16/202214340.NET Framework: 2078. .NET Core/5+를 위한 SGen(Microsoft.XmlSerializer.Generator) 사용법
13195정성태12/15/202214545개발 환경 구성: 655. docker - bridge 네트워크 모드에서 컨테이너 간 통신 시 --link 옵션 권장 이유
13194정성태12/14/202214347오류 유형: 833. warning C4747: Calling managed 'DllMain': Managed code may not be run under loader lock파일 다운로드1
13193정성태12/14/202214902오류 유형: 832. error C7681: two-phase name lookup is not supported for C++/CLI or C++/CX; use /Zc:twoPhase-
13192정성태12/13/202214881Linux: 55. 리눅스 - bash shell에서 실수 연산
13191정성태12/11/202216439.NET Framework: 2077. C# - 직접 만들어 보는 SynchronizationContext파일 다운로드1
13190정성태12/9/202218463.NET Framework: 2076. C# - SynchronizationContext 기본 사용법파일 다운로드1
13189정성태12/9/202217873오류 유형: 831. Visual Studio - Windows Forms 디자이너의 도구 상자에 컨트롤이 보이지 않는 문제
13188정성태12/9/202217363.NET Framework: 2075. C# - 직접 만들어 보는 TaskScheduler 실습 (SingleThreadTaskScheduler) [1]파일 다운로드1
13187정성태12/8/202216810개발 환경 구성: 654. openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법 (2)
13186정성태12/6/202214674오류 유형: 831. The framework 'Microsoft.AspNetCore.App', version '...' was not found.
13185정성태12/6/202215630개발 환경 구성: 653. Windows 환경에서의 Hello World x64 어셈블리 예제 (NASM 버전)
13184정성태12/5/202213497개발 환경 구성: 652. ml64.exe와 link.exe x64 실행 환경 구성 [1]
13183정성태12/4/202213366오류 유형: 830. MASM + CRT 함수를 사용하는 경우 발생하는 컴파일 오류 정리 [1]
13182정성태12/4/202215233Windows: 217. Windows 환경에서의 Hello World x64 어셈블리 예제 (MASM 버전)
13181정성태12/3/202213979Linux: 54. 리눅스/WSL - hello world 어셈블리 코드 x86/x64 (nasm)
13180정성태12/2/202215220.NET Framework: 2074. C# - 스택 메모리에 대한 여유 공간 확인하는 방법파일 다운로드1
13179정성태12/2/202213771Windows: 216. Windows 11 - 22H2 업데이트 이후 Terminal 대신 cmd 창이 뜨는 경우
13178정성태12/1/202214909Windows: 215. Win32 API 금지된 함수 - IsBadXxxPtr 유의 함수들이 안전하지 않은 이유파일 다운로드1
13177정성태11/30/202215493오류 유형: 829. uwsgi 설치 시 fatal error: Python.h: No such file or directory
13176정성태11/29/202212248오류 유형: 828. gunicorn - ModuleNotFoundError: No module named 'flask'
13175정성태11/29/202216912오류 유형: 827. Python - ImportError: cannot import name 'html5lib' from 'pip._vendor'
13174정성태11/28/202213373.NET Framework: 2073. C# - VMMap처럼 스택 메모리의 reserve/guard/commit 상태 출력파일 다운로드1
13173정성태11/27/202214408.NET Framework: 2072. 닷넷 응용 프로그램의 스레드 스택 크기 변경
... [31]  32  33  34  35  36  37  38  39  40  41  42  43  44  45  ...