root用户和子账户的OPENSSLDIR不一样导致docker容器内程序访问报证书错误

问题背景

机器环境:redhat9

docker部署了一个应用程序quartzui,作用是定时任务调度平台,但是最近由于IT部门更新了根证书,导致出现docker容器内的任务调度平台调用程序url都失败,且这些url很明显的一个问题就是https开头。

过程分析

我跟IT部门的老外先简单阐述了我的问题如下:

On my Linux environment respectively with rbadmin_app1 and root account to perform the curl command request address ' https://aaacn-dan.apac.bosch.com:444/api/Wiki/UpdateLeaderHierarchy'. rbadmin_app1 runs normally, but the root account fails. And then I execute commands under the root account 'openssl verify the/etc/pki/ca - trust/source/anchors/xxxx - ca - DE_pem. Cer', verification certificate result ok, but at the root account validation error failure. So I want know what is the reason for this?

得到的回复却是:Sorry, I don't know, maybe you should check your anaconda service, we did't installed that service.

然而在他提醒我后,我才发现图中的CAfile地址中包含了anaconda3的地址,这让我感觉很奇怪,为什么会去读这个下面的证书?如果去这个路径下面找,那自然是没有根证书信息的,定时任务平台请求其他服务,肯定会报证书相关的错误。所以带着疑问我去找了下是什么原因,最终发现是Anaconda默认进入虚拟环境设置开启了,将环境变量切换成了anaconda所在证书的路径,所以才导致docker读取环境变量的时候读到了错误的地址,引发了这个问题。

解决

执行如下命令关闭该功能即可,同时我去验证容器内定时任务平台的访问也都正常了,读取到了正常应该读取的OPENSSLDIR地址

bash 复制代码
conda config --set auto_activate_base false

至于怎么看OPENSSLDIR,命令如下

bash 复制代码
openssl version -d
相关推荐
I · T · LUCKYBOOM19 分钟前
2.2yum安装--单服务器托管多网站
linux·运维·服务器
是Judy咋!23 分钟前
基于kube-prometheus-release监控---k8s集群与业务服务
容器·kubernetes·prometheus
释怀不想释怀32 分钟前
Linux(复习常见命令)
linux·运维·服务器
Wpa.wk32 分钟前
接口自动化 - 解决大量响应数据字段的格式断言 -Json-schema
运维·经验分享·测试工具·自动化·json·接口测试
_F_y34 分钟前
负载均衡在线oj(文件版)
linux·运维·负载均衡
Chase_______38 分钟前
【Linux指南】:vi编辑器
linux·运维·编辑器
喵叔哟43 分钟前
16.项目架构设计
后端·docker·容器·.net
Dxy12393102161 小时前
Nginx中的worker_processes如何设置:从“盲目填数”到“精准调优”
运维·nginx
礼拜天没时间.1 小时前
【生产级实战】Linux 集群时间同步详解(NTP + Cron,超详细)
linux·运维·服务器·时间同步·cron·ntp
艾莉丝努力练剑1 小时前
【Linux进程控制(一)】进程创建是呼吸,进程终止是死亡,进程等待是重生:进程控制三部曲
android·java·linux·运维·服务器·人工智能·安全