日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

docker构建oracle集群,docker 构建 oracle数据库 镜像-Go语言中文社区

發(fā)布時間:2023/12/10 数据库 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 docker构建oracle集群,docker 构建 oracle数据库 镜像-Go语言中文社区 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

前言

之前docker 部署的 oracle 鏡像,突然從 dockerhub 下架了。所以沒辦法,只能自己打包一個oracle 數(shù)據(jù)庫的鏡像。

找來找去,其實oracle 自身就提供了oracle 的產(chǎn)品 docker 構(gòu)建腳本。所以直接按照oracle 官方的docker 構(gòu)建倉庫的說明打包。

oracle 官方 docker image

官方提供了一個開源倉庫,里面有所有的oracle產(chǎn)品的docker image構(gòu)建的腳本。

地址:https://github.com/oracle/docker-images

將上述的倉庫clone 到本地。

docker images clone下來的目錄結(jié)構(gòu)

我們需要打包的oracle 數(shù)據(jù)庫,在 OracleDatabase 這個目錄中。

進入到OracleDatabase 可以看到兩個文件夾,其實比較關(guān)鍵。

一個RAC,一個SingleInstance。

看名字就可以很明白,如果做集群鏡像,就打包RAC的 ,如果要是做單節(jié)點的就打包SingleInstance的。

我們這邊僅需要一個單節(jié)點數(shù)據(jù)庫,所以就打包SingleInstance。

支持的oracle database 版本

版本號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這個倉庫只有build的腳本,并不攜帶任何oracle database 的安裝包。所以我們還得去下載oracle database 對應(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

打包成功后,會在docker images 下生成 oracle/database:12.2.0.1-ee 這個鏡像。

運行容器

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.

大概看一下就明白了,其他的也沒啥特別的參數(shù)。

這個容器啟動成功后,實例名為ORCLPDB1 的數(shù)據(jù)庫就可以測試連接一下。

連接參數(shù)如下

即可連接成功,剩下的如何使用,自由發(fā)揮咯……

總結(jié)

以上是生活随笔為你收集整理的docker构建oracle集群,docker 构建 oracle数据库 镜像-Go语言中文社区的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。