docker构建oracle集群,docker 构建 oracle数据库 镜像-Go语言中文社区
前言
之前docker 部署的 oracle 鏡像,突然從 dockerhub 下架了。所以沒(méi)辦法,只能自己打包一個(gè)oracle 數(shù)據(jù)庫(kù)的鏡像。
找來(lái)找去,其實(shí)oracle 自身就提供了oracle 的產(chǎn)品 docker 構(gòu)建腳本。所以直接按照oracle 官方的docker 構(gòu)建倉(cāng)庫(kù)的說(shuō)明打包。
oracle 官方 docker image
官方提供了一個(gè)開源倉(cāng)庫(kù),里面有所有的oracle產(chǎn)品的docker image構(gòu)建的腳本。
地址:https://github.com/oracle/docker-images
將上述的倉(cāng)庫(kù)clone 到本地。
docker images clone下來(lái)的目錄結(jié)構(gòu)
我們需要打包的oracle 數(shù)據(jù)庫(kù),在 OracleDatabase 這個(gè)目錄中。
進(jìn)入到OracleDatabase 可以看到兩個(gè)文件夾,其實(shí)比較關(guān)鍵。
一個(gè)RAC,一個(gè)SingleInstance。
看名字就可以很明白,如果做集群鏡像,就打包RAC的 ,如果要是做單節(jié)點(diǎn)的就打包SingleInstance的。
我們這邊僅需要一個(gè)單節(jié)點(diǎn)數(shù)據(jù)庫(kù),所以就打包SingleInstance。
支持的oracle database 版本
版本號(hào)11.2.0.2
12.1.0.2
12.2.0.1
18.3.0
18.4.0
19.3.0
我們以12.2.0.1版本作為例子
docker-images這個(gè)倉(cāng)庫(kù)只有build的腳本,并不攜帶任何oracle database 的安裝包。所以我們還得去下載oracle database 對(duì)應(yīng)版本的安裝包。
準(zhǔn)備oracle 12.2.0.1 的安裝包
全版本的下載地址 https://www.oracle.com/cn/database/technologies/enterprise-edition/documentation/database.html
我們需要的12.2.0.1 版本 https://www.oracle.com/database/technologies/oracle12c-linux-12201-downloads.html
下載12.2.0.1 版本的linux 版本安裝包。下載好后,將壓縮包文件放到
docker-images/OracleDatabase/SingleInstance/dockerfiles/12.2.0.1
目錄下即可。
構(gòu)建
cd docker-images/OracleDatabase/SingleInstance/dockerfiles
執(zhí)行該目錄下的 buildDockerImage.sh
Usage: buildDockerImage.sh -v [version] [-e | -s | -x] [-i] [-o] [Docker build o ption]
Builds a Docker Image for Oracle Database.
Parameters:
-v: version to build
Choose one of: 11.2.0.2 12.1.0.2 12.2.0.1 18.3.0 18.4.0 19.3.0
-e: creates image based on 'Enterprise Edition'
-s: creates image based on 'Standard Edition 2'
-x: creates image based on 'Express Edition'
-i: ignores the MD5 checksums
-o: passes on Docker build option
* select one edition only: -e, -s, or -x
LICENSE UPL 1.0
Copyright (c) 2014-2019 Oracle and/or its affiliates. All rights reserved.
該腳本的幫助文檔 還是比較全面的 ,所以按照提示執(zhí)行編譯即可。
我這邊的build 參數(shù)
./buildDockerImage.sh -v 12.2.0.1 -e
打包成功后,會(huì)在docker images 下生成 oracle/database:12.2.0.1-ee 這個(gè)鏡像。
運(yùn)行容器
docker run --name
--shm-size=1g
-p 1521:1521 -p 8080:8080
-e ORACLE_PWD=
-v [:]/u01/app/oracle/oradata
-d
oracle/database:12.2.0.1-ee
可以設(shè)置的參數(shù)如下
Parameters:
--name: The name of the container (default: auto generated)
--shm-size: Amount of Linux shared memory
-p: The port mapping of the host port to the container port.
Two ports are exposed: 1521 (Oracle Listener), 8080 (APEX)
-e ORACLE_PWD: The Oracle Database SYS, SYSTEM and PDB_ADMIN password (default: auto generated)
-v /u01/app/oracle/oradata
The data volume to use for the database.
Has to be writable by the Unix "oracle" (uid: 1000) user inside the container!
If omitted the database will not be persisted over container recreation.
-v /u01/app/oracle/scripts/startup | /docker-entrypoint-initdb.d/startup
Optional: A volume with custom scripts to be run after database startup.
For further details see the "Running scripts after setup and on startup" section below.
-v /u01/app/oracle/scripts/setup | /docker-entrypoint-initdb.d/setup
Optional: A volume with custom scripts to be run after database setup.
For further details see the "Running scripts after setup and on startup" section below.
大概看一下就明白了,其他的也沒(méi)啥特別的參數(shù)。
這個(gè)容器啟動(dòng)成功后,實(shí)例名為ORCLPDB1 的數(shù)據(jù)庫(kù)就可以測(cè)試連接一下。
連接參數(shù)如下
即可連接成功,剩下的如何使用,自由發(fā)揮咯……
總結(jié)
以上是生活随笔為你收集整理的docker构建oracle集群,docker 构建 oracle数据库 镜像-Go语言中文社区的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 成信钟楼定时微博报时的设计与实现
- 下一篇: ref的mysql_ref:Mysql授