Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 483. docker - OracleXE 컨테이너 실행 [링크 복사], [링크+제목 복사],
조회: 12457
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

docker - OracleXE 컨테이너 실행

이전(mssql, postgers, mysql)까지의 DB들이 공식 이미지를 제공했던 반면, Oracle의 경우에는 아쉽게도 직접 만드는 방법은 소개해도,

Deliver Oracle Database 18c Express Edition in Containers
; https://blogs.oracle.com/oraclemagazine/deliver-oracle-database-18c-express-edition-in-containers

Oracle Database on Docker
; https://github.com/oracle/docker-images/tree/master/OracleDatabase/SingleInstance

docker hub를 통한 이미지는 제공하지 않습니다. 그래서 개인들이 제작해 올린 것들을 믿고 사용해야 하는데 (또는 직접 제작하거나) 이 글에서는 다음의 이미지를 사용해 보겠습니다.

oracleinanutshell/oracle-xe-11g
; https://hub.docker.com/r/oracleinanutshell/oracle-xe-11g

docker pull oracleinanutshell/oracle-xe-11g

docker run -p 1521:1521 oracleinanutshell/oracle-xe-11g
    docker run --name oraclexe1 -d -p 1521:1521 oracleinanutshell/oracle-xe-11g
    docker run --name oraclexe1 -d -p 1521:1521 --restart=always oracleinanutshell/oracle-xe-11g

실행 시 출력도 매우 단순합니다.

Starting Oracle Net Listener.
Starting Oracle Database 11g Express Edition instance.

(위의 메시지가 나와도 시스템 성능에 따라 초기화까지 더 기다려야 합니다.)

(oracle-xe-11g 컨테이너 페이지에 보면 원격 연결을 위해 "ORACLE_ALLOW_REMOTE" 환경 변수를 설정해야 한다고 하는데 실제로는 굳이 설정하지 않아도 원격 연결이 가능했습니다.)

이후 오라클이 배포하는 "SQL Developer" 등의 도구를 이용해,

SQL Developer 19.4 Downloads
; https://www.oracle.com/tools/downloads/sqldev-downloads.html

편안하게 DB 구성을 하시면 됩니다. 기본적으로 인증 정보는 "system" 계정에 대해 동일하게 비밀번호가 "oracle"이므로 연결 정보를 다음과 같은 식으로 입력하면 됩니다.

hostname: localhost
port: 1521
sid: xe
username: system
password: oracle

(hr 계정은 system으로 로그인 후 "ALTER USER hr IDENTIFIED BY hr2 ACCOUNT UNLOCK;" 등의 명령어로 해제할 수 있습니다.)




oracle-xe-11g 컨테이너 페이지에 보면 apex 기능이 8080 포트로 제공되는 듯한데,

For APEX user:

docker run --name oraclexe1 -p 1521:1521 -p 8080:8080 oracleinanutshell/oracle-xe-11g

# Login http://localhost:8080/apex/apex_admin with following credential:
username: ADMIN
password: admin

재미있는 것은, IE 웹 브라우저로 접속하는 경우에는 동작을 잘 하는 반면, Chrome 브라우저로 접속하면 다음과 같이,

oracle_container_xe_1.png

별도의 "로그인" 창이 뜨면서 지정된 "ADMIN" / "admin" 계정을 입력해도 인증이 안 됩니다. ^^; 암튼 IE로 "Admin" / "admin"을 입력해 들어가면 기본 비밀번호를 바꾼 후 다시 "http://localhost:8080/apex/apex_admin" 페이지를 방문하면 예의 그 화면으로 넘어갑니다. 이후의 동작은 다음의 글을 참고하시고.

.NET 응용 프로그램에서 Oracle XE 사용
; https://www.sysnet.pe.kr/2/0/821

.NET 응용 프로그램에서 Oracle XE 11g 사용
; https://www.sysnet.pe.kr/2/0/1316

ODP.NET의 완전한 닷넷 버전 Oracle ODP.NET, Managed Driver
; https://www.sysnet.pe.kr/2/0/10928




데이터 유지를 위한 볼륨 지정이 딱히 공개되지 않아서 예측을 해야 하는데요. /u01/app/oracle에 매핑하면,

docker run --name oraclexe1 -p 1521:1521 -v oracle11g_root:/u01/app/oracle oracleinanutshell/oracle-xe-11g

[DockerDesktopVM의 파일 시스템 접근]
/ # find / -name oracle11g_root
/host/var/lib/docker/volumes/oracle11g_root

그래도 잘 동작은 했습니다. (더 좋은 매핑 방식을 아는 분은 덧글 부탁드립니다. ^^)




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/12/2023]

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

비밀번호

댓글 작성자
 



2020-06-15 02시46분
[정이파파] 안녕하세요.
같은 이미지 볼륨 적용하는 방법을 구글링하다가 오게되었습니다.

latest 이미지에선, /u01/app/oracle-product로 설정해야 db가 정상적으로 구동되네요 ^^;;
https://github.com/wnameless/docker-oracle-xe-11g/issues/14
[guest]

... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12581정성태3/28/202110029.NET Framework: 1031. WinForm/WPF에서 Console 창을 띄워 출력하는 방법 (2) - Output 디버깅 출력을 AllocConsole로 우회 [2]
12580정성태3/28/20218772오류 유형: 708. SQL Server Management Studio - Execution Timeout Expired.
12579정성태3/28/20218880오류 유형: 707. 중첩 가상화(Nested Virtualization) - The virtual machine could not be started because this platform does not support nested virtualization.
12578정성태3/27/20219131개발 환경 구성: 560. Docker Desktop for Windows 기반의 Kubernetes 구성 (2) - WSL 2 인스턴스에 kind가 구성한 k8s 서비스 위치
12577정성태3/26/202111199개발 환경 구성: 559. Docker Desktop for Windows 기반의 Kubernetes 구성 - WSL 2 인스턴스에 kind 도구로 k8s 클러스터 구성
12576정성태3/25/20218968개발 환경 구성: 558. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성 (2) - k8s 서비스 위치
12575정성태3/24/20218074개발 환경 구성: 557. Docker Desktop for Windows에서 DockerDesktopVM 기반의 Kubernetes 구성
12574정성태3/23/202112078.NET Framework: 1030. C# Socket의 Close/Shutdown 동작 (동기 모드)
12573정성태3/22/20219918개발 환경 구성: 556. WSL 인스턴스 초기 설정 명령어 [1]
12572정성태3/22/20219436.NET Framework: 1029. C# - GC 호출로 인한 메모리 압축(Compaction)을 확인하는 방법파일 다운로드1
12571정성태3/21/20218610오류 유형: 706. WSL 2 기반으로 "Enable Kubernetes" 활성화 시 초기화 실패 [1]
12570정성태3/19/202112912개발 환경 구성: 555. openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법
12569정성태3/18/202111784개발 환경 구성: 554. WSL 인스턴스 export/import 방법 및 단축 아이콘 설정 방법
12568정성태3/18/20217391오류 유형: 705. C# 빌드 - Couldn't process file ... due to its being in the Internet or Restricted zone or having the mark of the web on the file.
12567정성태3/17/20218785개발 환경 구성: 553. Docker Desktop for Windows를 위한 k8s 대시보드 활성화 [1]
12566정성태3/17/20219117개발 환경 구성: 552. Kubernetes - kube-apiserver와 REST API 통신하는 방법 (Docker Desktop for Windows 환경)
12565정성태3/17/20216603오류 유형: 704. curl.exe 실행 시 dll not found 오류
12564정성태3/16/20217065VS.NET IDE: 160. 새 프로젝트 창에 C++/CLI 프로젝트 템플릿이 없는 경우
12563정성태3/16/20219025개발 환경 구성: 551. C# - JIRA REST API 사용 정리 (3) jira-oauth-cli 도구를 이용한 키 관리
12562정성태3/15/202110163개발 환경 구성: 550. C# - JIRA REST API 사용 정리 (2) JIRA OAuth 토큰으로 API 사용하는 방법파일 다운로드1
12561정성태3/12/20218765VS.NET IDE: 159. Visual Studio에서 개행(\n, \r) 등의 제어 문자를 치환하는 방법 - 정규 표현식 사용
12560정성태3/11/202110115개발 환경 구성: 549. ssh-keygen으로 생성한 개인키/공개키 파일을 각각 PKCS8/PEM 형식으로 변환하는 방법
12559정성태3/11/20219538.NET Framework: 1028. 닷넷 5 환경의 Web API에 OpenAPI 적용을 위한 NSwag 또는 Swashbuckle 패키지 사용 [2]파일 다운로드1
12558정성태3/10/20219011Windows: 192. Power Automate Desktop (Preview) 소개 - Bitvise SSH Client 제어 [1]
12557정성태3/10/20217673Windows: 191. 탐색기의 보안 탭에 있는 "Object name" 경로에 LEFT-TO-RIGHT EMBEDDING 제어 문자가 포함되는 문제
12556정성태3/9/20216944오류 유형: 703. PowerShell ISE의 Debug / Toggle Breakpoint 메뉴가 비활성 상태인 경우
... 31  32  33  34  35  36  37  38  39  40  41  [42]  43  44  45  ...