热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

ORA-12547经典错误处理

ORA-12547错误处理今天,领导告知我,让我帮一同事将Oracle安装下,他在安装的过程中出现了问题,报错,无法继续安装。一

ORA-12547错误处理 今天,领导告知我,让我帮一同事将Oracle安装下,他在安装的过程中出现了问题,报错,无法继续安装。 一

ORA-12547错误处理

今天,领导告知我,让我帮一同事将Oracle安装下,他在安装的过程中出现了问题,报错,无法继续安装。

一、由于NLS_LANG设置错误,导致ora-12547错误
我过去看了看,发现在AIX5.3系统中使用DBCA建库到最后一步点完成后立即就出现了ORA-12547 tns lost connect 这个错误,当时感觉挺蹊跷的,随后对系统的环境做了详细检查,异步IO是开启来的,HOST文件也是正常的,参数文件貌似也没有太大的问题,ulimit限制也都改成了-1; 也没有发现有明显的问题,安装日志里面是已经告诉说是操作系统环境不满足。当时实在是查不出来到底是什么原因导致就把之前安装的DBSOFT给删除了,重新进行DBSOFT的安装和建库,DBSOFT的安装中没有报任何错,到最好还是一样的问题,只好再次进行再次的检查,发现了在oracle用户环境配置文件里[db:oracle]$cat~/.profile里发现了NLS_LANG=ZHS16GBK这个参数,后面想想看这个参数并不是必须的,而且有可能会导致安装的时候报错,随即将其禁用掉,参数文件如下:$ cat .profile

PATH=/usr/bin:/etc:/usr/sbin:/usr/ucb:$HOME/bin:/usr/bin/X11:/sbin:.
export PATH
if [ -s "$MAIL" ] # This is at Shell startup. In normal
then echo "$MAILMSG" # operation, the Shell checks
fi # periodically.
ORACLE_BASE=/oracle
ORACLE_SID=orcl
ORACLE_HOME=$ORACLE_BASE/app/10.2.0/db_1
#NLS_LANG=ZHS16GBK
PATH=$ORACLE_HOME/bin:$PATH:
export ORACLE_BASE ORACLE_SID ORACLE_HOME PATH
$
将其禁用后,再次DBCA建库,故障没有再重现,成功建库。

二、dbca建库出现这个问题,后面在网上搜索了下,基本上是由如下四种原因导致:
1、异步IO导致dbca报ORA-12547
解决办法:
AIX:
a、smitty chaio (只有AIX 5系列支持)
b、把STATE to be configured at system restart 设置成available
c、再次运行DBCA创建成功
HP-UNIX 可以参考(Metalink Note:139272.1)

a. 创建aio字符设备
# /sbin/mknod /dev/async c 101 0x0
# chown oracle:dba /dev/async
# chmod 660 /dev/async

b.用sam调整内核参数
-> Kernel Configuration
-> Drivers
-> 选择'asyncdsk'
-> Actions>Add Driver to Kernel. (此时pending state由out变为in状态)
-> Kernel Configuration
-> Configurable Parameters
-> max_async_ports
设置为初始化文件中的'processes'值+oracle后台进程数 (根据v$bgprocess,单实例后台进程数最多为78个)

c. 用sam设置aio_max_ops
-> Kernel Configuration
-> Configurable Parameters
-> aio_max_ops
-> 可设置为默认值2048

以上配置,主机需重构核心,,重启.
d. 设置oracle用户必须有MLOCK权限。
a. 设定dba组的MLOCK的权限
roolt#setprivgrp dba MLOCK b. 避免重启后失效,需要设置:
vi /etc/privgroup 添加如下行:
dba MLOCK
e.检查一下aio是否生效了
   #fuser /dev/async
   有进程列出来说明aio已经生效了。



2、ulimit默认值没有修改
解决办法:
Linux
a、修改limits参数文件,添加如下内容
vi /etc/security/limits.conf
oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536

AIX
a、修改limits参数文件,在最后如下添加如下内容:(注:-1为无限制使用)
vi /etc/security/limits
default:
fsize = -1
core = 2097151
cpu = -1
data = 262144
rss = 65536
stack = 65536
nofiles = 2000
root:
daemon:
bin:
sys:
adm:
uucp:
guest:
nobody:
lpd:
oracle:
data = -1
stack = -1


3、Linux 下SELinux配置不正确,解决办法
a、用root用户登录系统执行 setenforce 0 (不需要重启)
b、修改/etc/selinux/config文件中的SELINUX="" 为 disabled ,需要重启

4、libaio(x86_64) is not installed(同AIX一样,是开启异步IO,在Linux下打这个包)
解决办法:
a、插入操作系统安装光盘
b、root用户登录系统挂载操作系统安装光盘:
#mount -t iso9660 /dev/cdrom /mnt
#cd /mnt/Server
c、检查并安装libaio包,执行如下命令
#rpm -qa| grep -i ^libaio
#rpm -ivh libaio-*.i386.rpm
#rpm -ivh libaio-*.x86_64.rpm
d、检查刚才安装的包是否成功
#rpm -qa | grep ^libaio
e、再次执行安装,问题解决

更多Oracle相关信息见Oracle 专题页面 ?tid=12


推荐阅读
  • 本文探讨了 Boost 库中的 Program Options 组件,这是一个强大的工具,用于解析命令行参数和配置文件。文章介绍了如何正确设置和使用该组件,包括处理复杂选项和负数值的方法。 ... [详细]
  • 对于初次购买阿里云服务器的新手用户来说,如何高效地利用服务器资源并成功部署网站是一个重要的课题。本文将详细指导您完成从购买服务器到网站上线的六个关键步骤。 ... [详细]
  • 本文探讨了Linux/Unix文件系统中两种主要的权限控制方式:传统的UGO(User/Group/Others)和更为精细的ACL(Access Control List)。ACL提供了一种更灵活的权限管理方法,适用于需要对文件系统进行细粒度控制的场景。 ... [详细]
  • 工作中频繁在不同Linux服务器之间切换时,频繁输入密码不仅耗时还影响效率。本文介绍如何通过设置SSH密钥认证,简化登录流程,提高工作效率。 ... [详细]
  • 本文档提供了首次周测的答案解析,涵盖特殊符号、命令作用、路径说明以及实战练习等内容。 ... [详细]
  • 在日常运维中,频繁地对多台Linux服务器进行用户管理是一项耗时的任务。为了提高效率,可以通过编写Expect脚本来实现远程自动化操作,从而简化这一过程。 ... [详细]
  • 一键LNMP配置SSL证书实现全站HTTPS访问
    许多网站搭建者选择了便捷的一键LNMP安装包,但在网站部署完成后,配置SSL证书以支持HTTPS访问是一个不可或缺的步骤。本文将详细介绍如何通过简单的步骤完成这一过程。 ... [详细]
  • 现在的新手程序猿,动不动就是框架,就连外面培训的也是框架,我就问一句,没了框架是不是就啥也不会了 ... [详细]
  • 最新进展:作为最接近官方声明的信息源,本文吸引了大量关注。若需获取最新动态,请访问:lkhill.com/ccie-version-5-update ... [详细]
  • Kubernetes 实践指南:初次体验
    本文介绍了如何通过官方提供的简易示例,快速上手 Kubernetes (K8S),并深入理解其核心概念和操作流程。 ... [详细]
  • 微服务自动化.dockercompose
    目录一、docker-compose二、docker-compose安装与配置1、修改docker.service2、下载文件3、将刚才下载的docker-compose文 ... [详细]
  • 本文探讨了如何在Linux系统中利用iptables和NFQUEUE处理来自镜像端口的流量。当镜像端口的数据包目的MAC地址与主机MAC地址不符时,通常会导致流量无法被NFQUEUE捕获。文章提供了解决这一问题的方法。 ... [详细]
  • 分布式计算助力链力实现毫秒级安全响应,确保100%数据准确性
    随着分布式计算技术的发展,其在数据存储、文件传输、在线视频、社交平台及去中心化金融等多个领域的应用日益广泛。国际知名企业如Firefox、Google、Opera、Netflix、OpenBazaar等均已采用该技术,推动了技术创新和服务升级。 ... [详细]
  • 在Linux系统中使用EncFS实现文件夹加密
    为了保护个人隐私或敏感数据不被未经授权的访问,可以通过加密技术来增强安全性。本文介绍如何在Linux系统上使用EncFS工具创建和管理加密文件夹,以确保即使在系统登录状态下,特定文件夹中的数据也保持加密状态。 ... [详细]
  • 本文概述了在GNU/Linux系统中,动态库在链接和运行阶段的搜索路径及其指定方法,包括通过编译时参数、环境变量及系统配置文件等方式来控制动态库的查找路径。 ... [详细]
author-avatar
是的范德萨
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有