ubuntu18+docker+数据库
docker安装
curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun
# 查看版本
docker -v
docker安装oracle环境
# 搜索oracle镜像
docker search oracle
# 下载oracle镜像
docker pull registry.cn-hangzhou.aliyuncs.com/qida/oracle-xe-11g
# 查看镜像
docker images
# 创建一个停止状态的容器,运行容器需要单独启动
# docker create
# 启动镜像(创建并启动容器)
docker run -d -p 1521:1521 --name oracle11 4ea53ad65b45
# -d 允许后台运行
# oracle11 容器名称
# 4ea53ad65b45 镜像ID
# 查看运行的容器
docker ps
# 进入容器
docker exec -it oracle11 bash
# --user root 以root身份进入容器,默认为当前linux系统用户
# 安装vim
apt-get update
apt-get install -y vim
# 查看环境变量
export
# declare -x ORACLE_HOME="/u01/app/oracle/product/11.2.0/xe"
# declare -x ORACLE_SID="XE"
# 登录sqlplus并建表空间TEST
# 进入sqlplus
sqlplus /nolog
# 使用sysdba角色登录sqlplus(出现Connected说明链接成功)
conn sys/oracle as sysdba
# 创建表空间TEST
CREATE TABLESPACE TEST
LOGGING
DATAFILE '/u01/app/oracle/product/11.2.0/xe/TEST.DBF'
SIZE 32M
AUTOEXTEND ON
NEXT 32M MAXSIZE UNLIMITED
EXTENT MANAGEMENT LOCAL;
# 创建用户
CREATE USER tester IDENTIFIED BY 123456
ACCOUNT UNLOCK
DEFAULT TABLESPACE TEST;
# 用户授权
GRANT CONNECT,RESOURCE TO tester;
GRANT DBA TO tester;
# 退出
exit;
# tester用户连接oracle
sqlplus tester/123456
# 至此,可以使用Navicat连接了。(Navicat配置驱动这里就不多说了,不是本文的重点)
服务名称:XE
登录账号/ 密码:tester / 123456
# 问题:连接成功后,能看到创建的用户tester,但是没有找到表空TEST???????????????????????
# 停止容器
docker stop oracle11
# docker kill oracle11
# 启动已停止的容器
docker start oracle11
# 删除容器(容器目录: /var/lib/docker/containers/ )
docker rm -flv oracle11
# -f 强制终止并删除运行中的容器
# -l 删除容器链接,保留容器
# -v 删除容器数据卷