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

... 46  47  48  49  50  51  [52]  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12337정성태9/21/202010572오류 유형: 653. Windows - Time zone 설정을 바꿔도 반영이 안 되는 경우
12336정성태9/21/202013078.NET Framework: 942. C# - WOL(Wake On Lan) 구현
12335정성태9/21/202022439Linux: 31. 우분투 20.04 초기 설정 - 고정 IP 및 SSH 설치
12334정성태9/21/20207876오류 유형: 652. windbg - !py 확장 명령어 실행 시 "failed to find python interpreter"
12333정성태9/20/20208328.NET Framework: 941. C# - 전위/후위 증감 연산자에 대한 오버로딩 구현 (2)
12332정성태9/18/202010376.NET Framework: 940. C# - Windows Forms ListView와 DataGridView의 예제 코드파일 다운로드1
12331정성태9/18/20209520오류 유형: 651. repadmin /syncall - 0x80090322 The target principal name is incorrect.
12330정성태9/18/202010571.NET Framework: 939. C# - 전위/후위 증감 연산자에 대한 오버로딩 구현 [2]파일 다운로드1
12329정성태9/16/202012490오류 유형: 650. ASUS 메인보드 관련 소프트웨어 설치 후 ArmouryCrate.UserSessionHelper.exe 프로세스 무한 종료 현상
12328정성태9/16/202012723VS.NET IDE: 150. TFS의 이력에서 "Get This Version"과 같은 기능을 Git으로 처리한다면?
12327정성태9/12/202010303.NET Framework: 938. C# - ICS(Internet Connection Sharing) 제어파일 다운로드1
12326정성태9/12/20209779개발 환경 구성: 516. Azure VM의 Network Adapter를 실수로 비활성화한 경우
12325정성태9/12/20209318개발 환경 구성: 515. OpenVPN - 재부팅 후 ICS(Internet Connection Sharing) 기능이 동작 안하는 문제
12324정성태9/11/202010581개발 환경 구성: 514. smigdeploy.exe를 이용한 Windows Server 2016에서 2019로 마이그레이션 방법
12323정성태9/11/20209439오류 유형: 649. Copy Database Wizard - The job failed. Check the event log on the destination server for details.
12322정성태9/11/202010559개발 환경 구성: 513. Azure VM의 RDP 접속 위치 제한 [1]
12321정성태9/11/20208795오류 유형: 648. netsh http add urlacl - Error: 183 Cannot create a file when that file already exists.
12320정성태9/11/202010004개발 환경 구성: 512. RDP(원격 데스크톱) 접속 시 비밀 번호를 한 번 더 입력해야 하는 경우
12319정성태9/10/20209735오류 유형: 647. smigdeploy.exe를 Windows Server 2016에서 실행할 때 .NET Framework 미설치 오류 발생
12318정성태9/9/20209237오류 유형: 646. OpenVPN - "TAP-Windows Adapter V9" 어댑터의 "Network cable unplugged" 현상
12317정성태9/9/202011559개발 환경 구성: 511. Beats용 Kibana 기본 대시 보드 구성 방법
12316정성태9/8/20209992디버깅 기술: 170. WinDbg Preview 버전부터 닷넷 코어 3.0 이후의 메모리 덤프에 대해 sos.dll 자동 로드
12315정성태9/7/202012285개발 환경 구성: 510. Logstash - FileBeat을 이용한 IIS 로그 처리 [2]
12314정성태9/7/202010838오류 유형: 645. IIS HTTPERR - Timer_MinBytesPerSecond, Timer_ConnectionIdle 로그
12313정성태9/6/202012028개발 환경 구성: 509. Logstash - 사용자 정의 grok 패턴 추가를 이용한 IIS 로그 처리
12312정성태9/5/202015921개발 환경 구성: 508. Logstash 기본 사용법 [2]
... 46  47  48  49  50  51  [52]  53  54  55  56  57  58  59  60  ...