作者:指间流年 | 来源:互联网 | 2023-06-14 14:14
介绍一下最近遇到的情况:最近对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