一、概览
NetBox 是一个开源的 IP 地址管理(IPAM)和数据中心基础设施管理(DCIM)工具,广泛用于管理和跟踪企业网络的设备、连接、IP 地址、虚拟化资源等。它由 DigitalOcean 开发并开源,目的是提供一个集中化的平台来管理网络基础设施,帮助网络管理员、系统管理员和基础设施工程师提高工作效率。
二、主要功能
- DCIM (数据中心基础设施管理)
netbox 的 dcim 可以将站点、区域、租户、机柜、设备等很好的管理起来,并且这几项元素之间可以产生关联关系,能够通过其中一个,找到其他的,例如通过站点看到有多少机柜或设备
可以在每个设备创建接口,然后连接起来,可以追踪线缆的连接关系 - IPAM
IP 地址管理功能,需要先定义前缀列表,会自动组成父子的关系,例如 16 位的会自动包含 24 位的地址段
三、部署
推荐使用 docker-compose 部署,比较简单方便些
可以在 netbox-docker 项目的 readme 中找到安装方式,这里将其列出
如上所示,安装完成后会侦听 8000 端口。
使用:
docker compose exec netbox /opt/netbox/
netbox/manage.py createsuperuser
命令创建超级管理员。
创建成功后,可通过 http://ip:8000 端口访问。
四、创建设备
1、介绍
强烈推荐使用 API 创建设备,而不是通过 Web 端添加,虽然 netbox 能够导出数据,但是不方便将所有数据批量导出,而且再导入也没那么方便。
有些信息,例如服务器的 CPU、内存、硬盘等信息,可以通过代码获取,并写入到 netbox,这样就保证了数据的准确性,更新的及时性。
可以通过定义 toml 格式的文件,将配置都写到 toml 内,用 Python 读取写入到 Mongo 再使用 netbox 的 Python 模块写入到 netbox。
2、编写toml
定义租户。
定义 regions。
定义 sites。
可以看到 sites 关联了 region。
定义 locations。
locations 中关联了 site。
定义 racks。
racks 中关联了 site, location, tenant。
定义 manufacturers。
定义 device-types。
定义堆叠组。
定义 devices。
定义 interface。
定义 cables。
定义 prefixes。
定义 ip-addresses。
定义 ip-ranges。
3、编写代码
在使用 netbox 的 rest api 时,发现有部分 API 的 POST 请求无法更新,未找到具体的原因,所以推荐使用 pynetbox 模块,使用很方便。
读取 toml 配置可以使用 toml 模块,加载后是字典格式,使用很方便。
导入模块并做初始化。
创建:
查询:
特殊情况处理。
有些字段,例如 regions、cables 是存在关联关系的。
例如 regions 中有时需要写 parent 字段,就像武汉的 parent 是湖北。
我们在配置文件中是这么定义的。
但是 pynetbox 在创建时,要求把 parent 转换为 id,所以就需要先做一层查询。
同样的,cables 也可以这么做。
五、数字科技峰会
NetBox 的优点如下:
- 提供了一个灵活且高度可定制的数据模型,支持管理设备、IP 地址、机架等多个基础设施元素,且易于扩展
- API 功能非常完善,几乎可以做所有的 Web 能操作的配置
- 开源且免费
- 用户页面比较直观,例如机柜立面图
- IPAM 功能比较好用,可以跟踪和管理 IP 地址空间,避免 IP 地址冲突
- 可以管理设备端口与线缆,解决使用 Excel 表时无法管理端口表的问题
缺点如下:
- 功能集中在基础设施和网络相关的,如果已有其他的 CMDB,在使用上会有割裂的情况,需要做一定的开发
- 在大规模环境中,部署和维护 NetBox 可能比较复杂,特别是在高可用性或多集群的场景下
总的来说,NetBox 还是一个很强大的功能,适合网络工程师或基础架构工程师进行机柜、设备、IP 地址、网络拓扑的管理,如果能对其进行深入开发,还是可以把数据中心的设备理的很清楚的。