OpenVAS 打包记

  • docker pull dustise/openvas
  • git clone https://github.com/fleeto/docker-openvas.git

上回书说到的 OpenVAS,其中的安装过程用的居然不是 Docker,其主要原因有:

  • 第一,安装使用都不熟悉,直接上手第三方比较容易跑偏,官网靠谱一点(现在我知道了,官网也有不靠谱的)。
  • 第二,因为上面的原因,Docker Hub 上的 mikesplain/openvas-docker 不得要领,尤其是客户端连接这部分。(后来知道他的强制更新高估了天朝的网络条件)。
  • 第三,我喜新厌旧,不想用老旧的 8 版本。
  • 第四,多语言支持,在上述 Docker Hub 版本上删节了。

但是作为一个容器云鼓吹者,不弄个顺手的封装的确是不合适的,所以花了些时间,重新来了一次,中间波折蛮多,不过也多了些容器封装方面的经验,就此记录下来。

OpenVAS 组件

  • openvassd:OpenVAS Scanner,扫描器,会根据本地漏洞库对任务目标进行扫描,是扫描任务的执行者。
  • openvasmd:OpenVAS Manager,管理服务,任务和各种漏洞库的管理。
  • gsad:Greenbone Security Assistent,他不是 Open VAS 的产品,在这里用作 Web 端,和 OpenVAS Manager 协同工作。
  • omp: 命令行客户端。

基础镜像的选择

基于尺寸考虑,个人一般是首选 Alpine Linux。对于普通的 Java、PHP 应用,以及相对成熟的被 APK 支持的软件都会使用这个。

需要编译的东西一般就比较烦了,Alpine 的一些基础包跟主流世界不太一样,一般尝试失败的话,会选择 Ubuntu/Debian 或者 CentOS 之类。最先尝试的是 CentOS,但因为库版本的问题导致编译起来问题多多,最后无奈回到 Ubuntu。

守护进程问题

一般来说,各种服务都以后台运行,然而在容器环境下,需要挂在前台保持容器的运行,所以单进程的服务我们一般都会强制其以前台运行,多进程的服务,通常会使用 SupervisorD 来完成各个服务的启动和运行、维持等操作。

调试过程

一般来说我会准备一个脚本用于构建镜像。

  • 首先用交互模式启动基础镜像,例如 docker run -it --rm ubuntu bash,其中可以添加环境变量等设置。
  • 可以利用 docker cp 命令传输文件到运行中的容器。
  • 之后的过程和平时的编译安装并无不同,configure/cmake 等查找缺失的库,尽可能用 apt/yum/apk 进行依赖库的安装。
  • 因为要使用 OMP,所以我们需要调整 OpenVAS Manager 的启动参数,要求其暴露端口。
  • 另外,OpenVAS 提供了配置检查功能,openvas-check-setup,其中对设置会有很多建议,逐条完善即可,窃以为,这是对这个不愉快的安装过程的最大安慰。
  • 每一步都记录到前面提到的 prepare.sh 脚本之中
  • 能正常运行之后,取出脚本,编写 Dockerfile。
  • 打包测试。

gnupg 的问题

OpenVAS Manager 首次运行会需要利用 gnupg 来生成 Key,但是在容器环境下,随机数设备受宿主系统保护,会导致启动过程挂起,因此这里用了个土办法,生成好之后直接植入进去。

Manager 的 Scanner Socket 参数

在 Scanner 指定了不同的 Sock 位置之后,Manager 做出相应的变更进行启动,部分操作仍然会走向缺省配置,推测是其中有一些硬编码,只是推测,并没有深入调查。

SQLite 3

这一软件是 gsad 的一个非常硬的依赖,但是在他的编译过程中并无需求,具体症状就是 Greenbone 有两个同步进程闪退,无法执行,需要用 –selftest 运行才找到问题所在。

更新过程

一定要有互联网连接。

更新过程第一是非常漫长,时间长度需要看网络条件和某伟大基础网络设施的心情。

接下来 Scanner 和 Manager 都需要进行相应的更新,才能正常工作。

最后,写了一个 update.all.sh 来完成这一工作。

Avatar
崔秀龙

简单,是大师的责任;我们凡夫俗子,能做到清楚就很不容易了。

comments powered by Disqus
下一页
上一页

相关