谨记 关闭操作系统之前先关闭oracle数据库
oracle用户登录,执行lsnrctl start启动网络监听服务,执行dbstart启动数据库系统。
oracle用户登录,执行lsnrctl stop关闭网络监听服务,执行dbshut关闭数据库系统。
>>>>>>>>>>>>>>>>>>>>>>>>> 故障排除 <<<<<<<<<<<<<<<<<<<<<<<<<<
1) 缺少 lib*
先尝试 dnf -y lib*
如果没有则 https://pkgs.org/ 搜索下载
rpm -ivh 安装 *.rpm
2) 安装图形界面中文乱码 首先下载字体zysong.ttf
mkdir -p /usr/share/fonts/zh_CN/TrueType
cd /usr/share/fonts/zh_CN/TrueType
chmod -R 75 zysong.ttf
3) supportedOSCheck
因IOS版本导致的 [WARNING] [INS-08101] Unexpected error while executing the action at state: 'supportedOSCheck'
只要版本大于 RHEL7.6
export CV_ASSUME_DISTID=RHEL7.6
4) 防火墙也可打开端口
firewall-cmd --zone=public --add-port=1521/tcp --add-port=5500/tcp --add-port=5520/tcp --add-port=3938/tcp --permanent
firewall-cmd --reload
firewall-cmd --list-ports
5) ERROR: Unable to verify the graphical display setup. This application requires X display. Make sure that xdpyinfo exist under PATH variable.
export DISPLAY=:0.0
这个如果试了不行就重启一下,直接用下面这个命令
xhost +
6) dbstart 和dbshut 报错
vi /u01/app/oracle/product/19.3/dbhome_1/bin/dbstart
vi /u01/app/oracle/product/19.3/dbhome_1/bin/dbshut
将 ORACLE_HOME_LISTNER=$1 改为 ORACLE_HOME_LISTNER=$ORACLE_HOME
7) dbstart 和dbshut 无提示
vi /etc/oratab
orcl:xxx:N为orcl:xxx:Y
8) Oracle Database Configuration Assistant
su -
chmod -R 777 /var/tmp/.oracle
9) lsnrctl start 时 The listener supports no services
vi /u01/app/oracle/product/19.3/dbhome_1/network/admin/listener.ora
# 添加
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = orcl)
(SID_NAME = orcl)
)
)
10) 解决乱码
echo $LANG
获得当前系统字符集 如 zh_CN.UTF-8
参考locale ID与字符集对照表 如: 常见的locale ID与字符集名称的对应关系
找到对应的 Chinese (simplified) zh_CN.UTF-8 SIMPLIFIED CHINESE_CHINA.AL32UTF8
vi ~/.bashrc 或 /etc/bashrc
添加或修改
export NLS_LANG="SIMPLIFIED CHINESE_CHINA.AL32UTF8"
source vi ~/.bashrc 或 /etc/bashrc
重启客户端,解决
不要试图 直接让 NLS_LANG的值等于 select userenv('language') from dual; 的结果,因为这可能是错误的错
应该让系统的 $LANG,数据库字符集,oracle的 $NLS_LANG三者一样
操作系统设置的是Locale ID ->环境变量的LANG, oracle环境变量NLS_LANG
数据输出时:数据库字符集原始数据->客户端字符集翻译传来的数据->操作系统字符集翻译传来的数据输出到屏幕上。
>>>>>>>>>>>>>>>>>>>>>>>>> 故障排除 <<<<<<<<<<<<<<<<<<<<<<<<<<
开始
安装依赖包:
sudo dnf install -y binutils* compat-libstdc* elfutils-libelf* gcc* glibc* ksh* libaio* libgcc* libstdc* make* sysstat* libXp* glibc-kernheaders libnsl
sudo dnf install -y ksh binutils compat-libstdc++-33 elfutils-libelf elfutils-libelf-devel gcc gcc-c++ glibc glibc-common glibc-devel libaio libaio-devel libgcc libstdc++ libstdc++-devel make numactl sysstat libXp unixODBC unixODBC-devel
创建用户&组
su -
groupadd -g 54321 oinstall
groupadd -g 54322 dba
groupadd -g 54323 oper
useradd -u 54321 -g oinstall -G dba,oper oracle
passwd oracle
关闭防火墙和selinux
systemctl stop firewalld.service
systemctl disable firewalld.service
setenforce 0
vi /etc/selinux/config
SELINUX=enforcing
创建目录赋予权限
mkdir -p /u01/app/oracle/product/19.3/dbhome_1
chown -R oracle:oinstall /u01/
chmod -R 775 /u01/
切换用户配置环境
su - oracle
vi .bash_profile 或 vi .bashrc 或 vi /etc/bashrc 也可以 /etc/profile.d/ 下vi 一个.sh文件
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib:$ORACLE_HOME/oracm/lib
export PATH=$PATH:$ORACLE_HOME/bin
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/19.3/dbhome_1
export ORACLE_SID=orcl
export NLS_LANG="SIMPLIFIED CHINESE_CHINA.AL32UTF8"
# 以上特别重要
export ORACLE_UNQNAME=orcl
export NLS_DATE_FORMAT="YYYY:MM:DDHH24:MI:SS"
export TNS_ADMIN=$ORACLE_HOME/network/admin
export ORA_NLS11=$ORACLE_HOME/nls/data;
export CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib:$ORACLE_HOME/network/jlib
export THREADS_FLAG=native
export TEMP=/tmp
export TMPDIR=/tmp
umask 022
其他参数配置
vi /etc/sysctl.conf
# kernel.shmmax = (物理内存/2)*1024^2
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 4294967296
kernel.shmmni = 4096
kernel.sem = 250 32000 100 128
net.ipv4.ip_local_port_range = 9000 65500
net.core.rmem_default = 262144
net.core.rmem_max = 4194304
net.core.wmem_default = 262144
net.core.wmem_max = 1048586
kernel.panic_on_oops = 1
net.ipv4.conf.all.rp_filter = 2
net.ipv4.conf.default.rp_filter = 1
sysctl --system
vi /etc/security/limits.conf
oracle soft nofile 1024
oracle hard nofile 65536
oracle soft nproc 16384
oracle hard nproc 16384
oracle soft stack 10240
oracle hard stack 32768
oracle hard memlock 134217728
oracle soft memlock 134217728
vi /etc/pam.d/login
session required /lib64/security/pam_limits.so
vi /etc/profile
if [ $USER = "oracle" ] ; then
if [ $SHELL = "/bin/ksh" ] ; then
ulimit -p 16384
ulimit -n 65536
else
ulimit -u 16384 -n 65536
fi
fi
安装
unzip oracle19c3.zip -d /u01/app/oracle/product/19.3/dbhome_1/
cd /u01/app/oracle/product/19.3/dbhome_1/
./runInstall
配置选项
创建并配置单例数据库
系统类
服务器类
数据库版本
企业版
安装位置
默认
配置类型
数据仓库 (并发量大,事务多,执行较短,另一个相反)
配置选项
内存 50%
字符集 AL32UTF8 其他还有ZHS16GBK等, 与系统相符的字符集, echo $LANG 然后 对比 设置当前系统的就行
数据库存储
指定数据库文件位置 默认 或自己创建 /u01/app/oracle/oradata
管理选项
下一步 (看需求
启用恢复
下一步 (看需求
方案口令
设置口令
操作系统组
下一步
root脚本执行
自动
安装等待完成
开启
su - oracle
dbstart
lsnrctl starp
sqlplus / as sysdba
SQL > startup
然后就可以愉快的玩耍了