全网最全的linux上docker安装oracle的详细文档,遇到了n个问题,查了几十篇文章,最终汇总版,再有解决不了的,私聊我,我帮你解决
- 全网最全的linux上docker安装oracle的详细文档,遇到了n个问题,查了几十篇文章,最终汇总版,再有解决不了的,私聊我,我帮你解决
- 1. 拉取阿里镜像oracle
- 2. 创建初始化数据
- 3. 创建启动容器 数据持久化
- 4. 进入oracle容器
- 5. 切换到root用户下进行配置
- 6. 编辑profile文件配置ORACLE环境变量
- 7. 创建软连接
- 8. 切换到oracle 用户
- 9. 登录sqlplus并修改sys、system用户密码
- 10. 修改sys、system用户密码并刷新权限
- 11. 查看一下oracle实例状态
- 12. 用navicat连接oracle数据库
- 12.1 用navicat连接报错ORA-12514: TNS :no listener
- 12.2 结果navicat连接继续报错ORA-12514:TNS:listener does not currently know of service requested in connect descriptor
- 12.3 The listener supports no services
- 12.4 oracle修改端口启动的别忘了遇到的1521全改成自定义的,仔细看我上面的listener.ora和tnsname.ora里host和port我全改成一致的了,在此就不多说了。
- 12.5 就在我满心欢喜的时候又报了个错ORA-01031: insufficient privileges
全网最全的linux上docker安装oracle的详细文档,遇到了n个问题,查了几十篇文章,最终汇总版,再有解决不了的,私聊我,我帮你解决
1. 拉取阿里镜像oracle
docker pull registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g

2. 创建初始化数据
#容器启动
docker run -di --name oracle11521 --restart=always \
-p 1521:1521 registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g
# 创建文件夹
mkdir -p /home/esopadm/data/oracle
#复制文件出来
docker cp oracle11521:/home/oracle/app/ /home/esopadm/data/oracle
docker cp oracle11521:/etc/profile /home/esopadm/data/oracle/
cd /home/esopadm/data/oracle
# 500 500 是容器内 oracle 组和用户的 id
chown -R 500.500 app
# 删除容器
docker rm -f oracle11521
3. 创建启动容器 数据持久化
docker run -d -p 11521:11521 -v /home/esopadm/data/oracle/app:/home/oracle/app \
-v /home/esopadm/data/oracle/profile:/etc/profile \
--restart=always --name oracle11521 registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g
4. 进入oracle容器
docker exec -it oracle /bin/bash
这个命令就是我噩梦的开始,由于我用的是公司的开发环境的服务器,别人已经事先装过oracle了,所以我上面那个命令进入的是别人oracle,导致下面执行的命令都是在别人地盘上玩的,白白浪费了好长时间,所以我只能改个端口号继续玩,那容器名也不能一样了,我把端口改成了11521,容器名为oracle11521。
那正确的命令应该是下面这个
docker exec -it oracle11521 /bin/bash
5. 切换到root用户下进行配置
su root
#密码:helowin
6. 编辑profile文件配置ORACLE环境变量
vi /etc/profile
# 添加:
export ORACLE_HOME=/home/oracle/app/oracle/product/11.2.0/dbhome_2
export ORACLE_SID=helowin
export PATH=$ORACLE_HOME/bin:$PATH
7. 创建软连接
ln -s $ORACLE_HOME/bin/sqlplus /usr/bin
8. 切换到oracle 用户
su - oracle
9. 登录sqlplus并修改sys、system用户密码
sqlplus /nolog
conn /as sysdba

10. 修改sys、system用户密码并刷新权限
alter user system identified by 123456;
alter user sys identified by 123456;
ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;
exit 退出
上面简单的三步我这就开始报错了,下面是我遇到的错误及解决办法
10.1 当执行修改密码的时候出现 :database not open
提示数据库没有打开,不急按如下操作
输入:alter database open;
10.2 又提示另一个错误: ORA-01507: database not mounted
输入:alter database mount;
10.3 又提示另一个错误:ORA-00214:control file

这个解决方法很多,我只用了其中一个,想看其他方法,查看这篇文章:https://blog.csdn.net/Ruishine/article/details/115323525
由于control102.ctl版本号是845比control101.ctl版本号841高,所以我将control101.ctl删除,然后将control102.ctl拷贝到control101.ctl目录下并改名为control101.ctl。
也就是说用高版本的覆盖低版本的
11. 查看一下oracle实例状态
lsnrctl status

12. 用navicat连接oracle数据库
服务名:helowin(一定要填写helowin)
用户名:system 第10步设置的用户)
密码:123456(第10步设置的密码)
终于大功告成了,这回开始使用吧。。。结果。。。
12.1 用navicat连接报错ORA-12514: TNS :no listener
这个错误卡了我很久,我也不能每次都指定ip吧,其他同事用我再把他们ip加上?太蠢了。最后终于找到一个靠谱的
修改/home/oracle/app/oracle/product/11.2.0/dbhome_2/network/admin/listener.ora文件里的host

HOST默认是localhost ,本机连接正常,远程无法连接。改为机器名,本地、远程都可以连接!
那我们就通过hostname查看主机名呗。

注意:是容器的主机名,而不是宿主机的。
修改完需要重新开启监听。先停止,再启动。
lsnrctl stop
lsnrctl start
12.2 结果navicat连接继续报错ORA-12514:TNS:listener does not currently know of service requested in connect descriptor
大概意思是当前服务不可用

结果又是一顿瞎搞,结果lsnrctl status命令显示的内容和以前又不一样了,没有可用的服务。

12.3 The listener supports no services
这个问题也找到解决办法了。
继续修改listener.ora 文件。

SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = helowin)
(SID_NAME = helowin)
)
)
继续lsnrctl stop然后lsnrctl start

熟悉的服务、实例终于又回来了。
12.4 oracle修改端口启动的别忘了遇到的1521全改成自定义的,仔细看我上面的listener.ora和tnsname.ora里host和port我全改成一致的了,在此就不多说了。
12.5 就在我满心欢喜的时候又报了个错ORA-01031: insufficient privileges

权限不足???
这个简单查了一下
解决Navicat连接Oracle数据库用户权限问题:
第一步:在cmd窗口运行[sqlplus],
第二步:输入Oracle的用户名和口令连接Oracle数据库,
第三步:执行授权代码,给用户授予DBA权限 [grant dba to 用户名;],
如果还有权限不足问题再执行第四步,
第四步:执行[grant all privileges to 用户名;]
我这里用户名就是system了,执行完了没什么鸟用。
后来想起来了,之前蒙头撞墙的时候改了高级里的角色为sysdba,改回default试一下。

居然成功了!!!

就这样吧。洗洗睡吧。真的累了。
全网最全的linux上docker安装oracle的详细文档,遇到了n个问题,查了几十篇文章,最终汇总版,再有解决不了的,私聊我,我帮你解决的更多相关文章
- Linux上centOs6+安装mysql5.7详细教程 - 前端小鱼塘
https://coyhom.github.io/ 人类的本质是复读机,作为一个非linux专业人员学习linux最好的办法是重复 环境centos6.5 版本5.7 1: 检测系统是否自带安装mys ...
- linux上Docker安装gogs私服亲测(详解)
一.前言 有网友问我为什么要使用私服,可能大部分人都不是太懂,网上那么多存储仓库而且好用方便,但是你想过没有如果企业中的项目,放在人家的仓库上这个安全性不是太好,所以说一般企业都会有自己的私服.本章教 ...
- linux上Docker安装gogs私服
一.背景介绍 Gogs 是一款类似GitHub的开源文件/代码管理系统(基于Git),Gogs 的目标是打造一个最简单.最快速和最轻松的方式搭建自助 Git 服务.使用 Go 语言开发使得 Gogs ...
- linux上docker安装centos7.2
1.安装 docker pull centos:7.2.1511 2.启动镜像 docker run -d -i -t <IMAGE ID> /bin/bash 3.进入容器 docker ...
- Linux通过docker安装运行酷Q--用QQ骰子君进行跑团
Linux通过docker安装运行酷Q 文:铁乐与猫 需求:和小伙伴周末进行愉快的TRPG跑团,需要在QQ讨论组上加了qq小号后,将qq小号用酷Q配合投骰的应用变成骰子君. 限制:我个人的云计算服务器 ...
- 史上最详细最全的Linux上安装Oracle的教程-centos7
一.安装Oracle前准备 1.创建运行oracle数据库的系统用户和用户组 [humf@localhost ~]$ su root #切换到root Password: [root@localhos ...
- 【数据库】Mean web开发 04-MongoDB在Linux上的安装及遇到的问题
简介 Mean是JavaScript的全栈开发框架.更多介绍 用MongoDB实现持久数据的存储是Mean Web全栈开发中的一部分. MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非 ...
- jemalloc在linux上从安装到使用
jemalloc在linux上从安装到使用 上次在引导大家安装Redis时提到可能会报错: 发现了redis有用到jemalloc. 首先,jemalloc是干什么的? 我们看看作者自己的介绍: j ...
- 分布式缓存技术redis学习系列(一)——redis简介以及linux上的安装
redis简介 redis是NoSQL(No Only SQL,非关系型数据库)的一种,NoSQL是以Key-Value的形式存储数据.当前主流的分布式缓存技术有redis,memcached,ssd ...
- GIT在Linux上的安装和使用简介
GIT最初是由Linus Benedict Torvalds为了更有效地管理Linux内核开发而创立的分布式版本控制软件,与常用的版本控制工具如CVS.Subversion不同,它不必服务器端软件支持 ...
随机推荐
- 使用 Auditbeat 模块监控 shell 命令
使用 Auditbeat 模块监控 shell 命令 Auditbeat Audited 模块可以用来监控所有用户在系统上执行的 shell 命令.在终端用户偶尔才会登录的服务器上,通常需要进行监控. ...
- ELK Stack 日志平台性能优化
转载自: https://mp.weixin.qq.com/s?__biz=MzAwNTM5Njk3Mw==&mid=2247487789&idx=1&sn=def0d8c2e ...
- 使用docker-compose部署WordPress项目
创建空文件夹 假设新建一个名为 wordpress 的文件夹,然后进入这个文件夹. 创建 docker-compose.yml 文件 docker-compose.yml 文件将开启一个 wordpr ...
- PAT (Basic Level) Practice 1026 程序运行时间 分数 15
要获得一个 C 语言程序的运行时间,常用的方法是调用头文件 time.h,其中提供了 clock() 函数,可以捕捉从程序开始运行到 clock() 被调用时所耗费的时间.这个时间单位是 clock ...
- python实验报告(第五周)
一.实验目的和要求 学会使用字符串的常用操作方法和正确应用正则表达式. 二.实验环境 软件版本:Python 3.10 64_bit 三.实验过程 1.实例1:使用字符串拼接输出一个关于程序员的笑话 ...
- P3629 [APIO2010] 巡逻 (树的直径)
(这道题考察了求直径的两种方法......) 在原图中,每条边要经过两次,增加1条后,形成了一个环,那么环上的边只需要经过一次了(大量画图分析得),再增加一条又会形成一个环,如果这两个环有重叠,重叠部 ...
- 一文讲清楚 JVM Safe Point
大家好,我是树哥. 关于 Safe Point 是 JVM 中很关键的一个概念,但我估计有不少同学不是很懂.于是今天跟大家来深入聊聊 Safe Point,希望通过这篇文章能解答这样几个问题: 什么是 ...
- 一键生成通用高亮代码块到剪贴板,快捷粘贴兼容 TT/WX/BJ 编辑器
有些在线图文编辑器不支持直接插入代码块,但可以直接粘贴 HTML 格式的高亮代码块. 花了一点时间研究了一下各家的编辑器,规则却各不相同.有的要求代码块被包含于 <code> ... &l ...
- C++ 队列!还是要从 STL 中的说起……
1. 前言 队列和栈一样,都是受限的数据结构. 队列遵循先进先出的存储原则,类似于一根水管,水从一端进入,再从另一端出去.进入的一端称为队尾,出去的一端称为队头. 队列有 2 个常规操作: 入队:进入 ...
- 前端开发日常——CSS动画无限轮播
近来没有什么值得写的东西,空闲的时候帮前端的同学做了些大屏上的展示模块,就放在这里写写吧,手把手"需求->设计-> 实现",受众偏新手向. 为了直观便于理解, 直接把结 ...