在Ubuntu上部署Oracle数据库可以通过手动安装或使用Docker容器两种主要方式实现。以下是详细的步骤:
安装依赖包:
sudo apt-get update
sudo apt-get install alien libaio1 unixodbc build-essential
创建用户和用户组:
sudo groupadd oinstall
sudo groupadd dba
sudo useradd -g oinstall -G dba oracle
sudo passwd oracle
配置系统参数:
/etc/sysctl.conf
文件,添加以下内容:kernel.sem = 250 32000 100 128
kernel.shmall = 2097152
kernel.shmmax = 2147483648
kernel.shmmni = 4096
fs.aio-max-nr = 1048576
fs.file-max = 6815744
net.core.rmem_default = 4194304
net.core.rmem_max = 4194304
net.core.wmem_default = 262144
net.core.wmem_max = 1048576
net.ipv4.ip_local_port_range = 9000 65500
sudo sysctl -p
修改hosts文件:
sudo vi /etc/hosts
添加以下内容:
127.0.0.1 localhost
192.168.100.197 oracle
oracle.localdomain
创建安装目录并设置权限:
sudo mkdir -p /u01/app/oracle/product/12.2.0/dbhome_1
sudo chown -R oracle:oinstall /u01
sudo chmod -R 755 /u01
解压Oracle数据库软件包:
cd /path/to/oracle/database/install/dir
unzip linux_11gR2_database_1of2.zip linux_11gR2_database_2of2.zip
配置环境变量:
/home/oracle/.bashrc
文件,添加以下内容:export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/12.2.0/dbhome_1
export ORACLE_SID=orcl
export PATH=$ORACLE_HOME/bin:$PATH
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
export CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/lib/classes.zip
source /home/oracle/.bashrc
运行Oracle安装程序:
cd /path/to/oracle/database/install/dir
./runInstaller
启动Oracle数据库实例并设置为开机自启:
sudo systemctl start oracle-database-preinstall-12cR2-preinstall.service
sudo systemctl enable oracle-database-preinstall-12cR2-preinstall.service
安装Docker:
sudo apt-get update
sudo apt-get install docker.io
下载Oracle数据库容器镜像:
docker pull store/oracle/database-enterprise:12.2.0.1
运行Oracle数据库容器:
docker run -d --name oracle-db -p 1521:1521 -p 5500:5500 store/oracle/database-enterprise:12.2.0.1
进入镜像进行设置:
sudo docker exec -it oracle bash
加载环境变量:
source /home/oracle/.bash_profile
进行软连接:
ln -s $ORACLE_HOME/bin/sqlplus /usr/bin/sqlplus
修改默认密码账号:
sqlplus /nolog
conn / as sysdba
alter user system identified by new_password;
alter user sys identified by new_password;
创建软连接:
ln -s $ORACLE_HOME/bin/sqlplus /usr/bin/sqlplus
修改默认密码账号:
sqlplus /nolog
conn / as sysdba
alter user system identified by new_password;
alter user sys identified by new_password;
切换用户:
su oracle
修改Oracle用户:
sqlplus /nolog
conn / as sysdba