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

滴水穿石~

介绍一下最近遇到的情况:最近对Linux服务器上部署的Oracle数据库进行每晚定时备份的要求1、但是通过crontab运行Oracle数据库备份脚本文件:下图红框最后一行是我新创

介绍一下最近遇到的情况:

最近对Linux服务器上部署的Oracle数据库进行每晚定时备份的要求

1、但是通过crontab运行Oracle数据库备份脚本文件:下图红框最后一行是我新创建的要自动备份oracle数据库的crontab,crontab -e 修改定时任务;crontab -l 查看定时任务,因为是测试于是设了每3分钟执行一次。图中>>是将运行的日志输出到log文件中,方便查看问题所在。

 

 

2、报错找不到/root/oracle目录下的xxx.so.x 错误,但是通过命令 find / -name xxx.so.x ,结果是是能找到该动态库的,单独手动运行oraclebackup.sh是可以正常备份的,但是在crontab中则失败。

 

 

于是开始在网上进行百度,寻找解决方法,可能是我对Linux系统不熟悉吧,找了好几种方法都没有解决(可能是自己操作错误导致)

因为手动可以备份,于是排除了crontab服务未启动、权限不足等问题,估计是加载动态库的路径没有找到

通过一通百度和尝试,找到了一种自己能看得懂,并且照猫画虎也能修改出来的解决方法,下面是网上找到的解决方法:

==================================================start===============================================

在了解/etc/ld.so.conf.d/目录下文件的作用之前,先介绍下程序运行是加载动态库的几种方法:
第一种,通过ldconfig命令
    ldconfig命令的用途, 主要是在默认搜寻目录(/lib和/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下, 搜索出可共享的动态链接库(格式如lib*.so*), 进而创建出动态装入程序(ld.so)所需的连接和缓存文件. 缓存文件默认为/etc/ld.so.cache, 此文件保存已排好序的动态链接库名字列表. 
    这里面涉及到的关键内容有命令:ldconfig,配置文件目录:/etc/ld.so.conf.d,配置文件在/etc/ld.so.conf内容由用户编辑,缓冲文件/etc/ld.so.cache。下面举个例子,比如你在部署软件时,有些动态库安装在exe目录下,可以通过如下方法实现,
1)配置exe.conf文件,里面加一行~/exe,然后将该文件放到/etc/ld.so.conf.d目录下;
2)在/etc/ld.so.conf文件中增加一行include ld.so.conf.d/exe.conf
3)执行 ldconfig命令
之后程序运行时,会自动增加在exe目录中搜索动态库。
第二种,通过LD_LIBRARY_PATH环境变量
可以通过在.bashrc或者.cshrc中配置该环境变量,LD_LIBRARY_PATH的意思是告诉loader在哪些目录中可以找到共享库. 可以设置多个搜索目录, 这些目录之间用冒号分隔开.
同样是上面的例子,可以通过以上的方法来实现
在.bashrc或.cshrc中增加一行,export LD_LIBRARY_PATH = ~/exe:$LD_LIBRARY_PATH即可。

第三种,通过编译选项-Wl, -rpath指定动态搜索的路径
    -Wl选项告诉编译器将后面的参数传递给链接器。
    通过上面的介绍,对/etc/ld.so.conf.d/的作用就比较清晰了。

==================================================end===============================================

 

我使用的是第一种:通过ldconfig命令

按照要求在/etc/ld.so.conf.d下创建oracle-x86_64.conf文件,将/root/oracle放在新建文件中,然后重新打开一个新的SSH,输入命令ldconfig。

至此,在crontab中运行oraclebackup.sh文件可以正常进行备份了。

困扰了自己两天的问题,终于解决,记录一下。

原文链接:https://blog.csdn.net/huangjin0507/article/details/50372721



推荐阅读
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社区 版权所有