当前位置: 首页 > 工具软件 > NetBox > 使用案例 >

基于centos7 部署 NetBox3

蒋乐意
2023-12-01

环境:

        Centos7  2c4g  50G

依赖、版本:

        PostgreSQL database  > v10
        Redis > v4.0
        NetBox components > v3
        Python 3.8 

1) install PostgreSQL 10

centos7 自带的PG数据库是9.2,而只有9.4才开始支持JSONB。

yum install https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm -y

yum install postgresql10-contrib postgresql10-server -y 



psql -V        # 查看版本号,验证安装是否成功

初始化数据库并设置开机启动:

/usr/pgsql-10/bin/postgresql-10-setup initdb        # 初始化数据库

sudo systemctl start postgresql-10        # 启动pgsql

sudo systemctl enable postgresql-10.service        # 添加开机启动

 

登陆pgsql并创建账户:

sudo -u postgres psql        # 创建 netbox 相关数据库信息:



CREATE DATABASE netbox;

CREATE USER netbox WITH PASSWORD '39tprXhrnELC';

GRANT ALL PRIVILEGES ON DATABASE netbox TO netbox;

列出所有用户:\du

退出: \q

 验证:

psql --username netbox --password --host localhost netbox



Password for user netbox:

psql (12.5 (Ubuntu 12.5-0ubuntu0.20.04.1))

SSL connection (protocol: TLSv1.3, cipher: TLS_AES_256_GCM_SHA384, bits: 256, compression: off)

Type "help" for help.



netbox=> \conninfo

You are connected to database "netbox" as user "netbox" on host "localhost" (address "127.0.0.1") at port "5432".

SSL connection (protocol: TLSv1.3, cipher: TLS_AES_256_GCM_SHA384, bits: 256, compression: off)

netbox=> \q

 最后修改vi /var/lib/pgsql/10/data/pg_hba.conf

将 ident 修改为 md5 或者 trust,如下:

# TYPE  DATABASE        USER            ADDRESS                 METHOD  
                                                                        
# "local" is for Unix domain socket connections only                    
local   all             all                                     trust   
# IPv4 local connections:                                               
host    all             all             127.0.0.1/32            trust   
# IPv6 local connections:                                               
host    all             all             ::1/128                 trust   
# Allow replication connections from localhost, by a user with the      
# replication privilege.                                                
local   replication     all                                     trust   
host    replication     all             127.0.0.1/32            trust   
host    replication     all             ::1/128                 trust   

重要: 更改完配置后,一定要重启pgsql

                 systemctl restart postgresql-10

2)Install Redis

CentOS 7 yum 默认安装的版本是3.2。

这里使用 Remi 的软件源,官网地址:http://rpms.famillecollet.com/。安装最新的 Redis :

​
yum install -y http://rpms.famillecollet.com/enterprise/remi-release-7.rpm 

yum --enablerepo=remi install redis -y

redis-server -v        # 确认 redis 版本

​

3)install Python3.8

yum install -y centos-release-scl        # 仓库注册

yum install -y rh-python38 which         # 安装python3.8



# 创建软连接

ln -s /opt/rh/rh-python38/root/usr/bin/python3 /usr/bin/python3

ln -s  /opt/rh/rh-python38/root/usr/bin/pip3 /usr/bin/pip3



python -V        # 确认版本

4)Install NetBox components

安装环境依赖:

yum install -y gcc libxml2-devel libxslt-devel libffi-devel libpq-devel openssl-devel redhat-rpm-config

源码安装:

​
wget https://github.com/netbox-community/netbox/archive/refs/tags/v3.1.7.tar.gz

tar -zxvf v3.1.7.tar.gz

mv netbox-3.1.7 && cd /opt

ln -s /opt/netbox-3.1.7 /opt/netbox

​

创建NetBox系统用户:

sudo groupadd --system netbox

sudo adduser --system -g netbox netbox

sudo chown --recursive netbox /opt/netbox/netbox/media/

配置:

1、cp配置文件

cd /opt/netbox/netbox/netbox/

sudo cp configuration.example.py configuration.py

2、打开 configuration.py 以开始配置 NetBox。NetBox 提供了许多配置参数,但新安装只需要以下四个:

ALLOWED_HOSTS = ['*']



DATABASE = {

    'NAME': 'netbox',               # Database name

    'USER': 'netbox',               # PostgreSQL username

    'PASSWORD': 'J5brHrAXFLQSif0K', # PostgreSQL password

    'HOST': 'localhost',            # Database server

    'PORT': '',                     # Database port (leave blank for default)

    'CONN_MAX_AGE': 300,            # Max database connection age (seconds)

}

3、redis 使用默认参数

REDIS = {

    'tasks': {

        'HOST': 'localhost',      # Redis server

        'PORT': 6379,             # Redis port

        'PASSWORD': '',           # Redis password (optional)

        'DATABASE': 0,            # Database ID

        'SSL': False,             # Use SSL (optional)

    },

    'caching': {

        'HOST': 'localhost',

        'PORT': 6379,

        'PASSWORD': '',

        'DATABASE': 1,            # Unique ID for second database

        'SSL': False,

    }

}

4、SECRET_KEY

cd  /opt/netbox/netbox/

python3 generate_secret_key.py


# 将 key 复制到 configuration.py 的

SECRET_KEY = 'a%X$8=!JyjMFXt19=CO2FHJehsp^S$t0i*9r5ALL$ZUho)*wDk'

运行升级脚本:

# 配置好 NetBox 后,将运行打包的升级脚本 ( upgrade.sh) 来执行以下操作:

    # 创建 Python 虚拟环境
    # 安装所有必需的 Python 包
    # 运行数据库架构迁移
    # 在本地构建文档(供离线使用)
    # 聚合磁盘上的静态资源文件

sudo /opt/netbox/upgrade.sh


# 如果默认的版本较低,可以使用环境变量来运行脚本:

sudo PYTHON=/usr/bin/python3.8 /opt/netbox/upgrade.sh

创建超级用户:

NetBox 没有默认账户,需要创建一个超级用户(管理帐户)才能登录 NetBox。

进入虚拟环境:

source /opt/netbox/venv/bin/activate

(venv) [root@localhost netbox]# cd /opt/netbox/netbox

(venv) [root@localhost netbox]# python3 manage.py createsuperuser

启用定时任务来清理过期会话:

调用此命令的 shell 脚本包含在contrib/netbox-housekeeping.sh. 它可以复制或链接到您系统的每日 cron 任务目录,或直接包含在 crontab 中。(如果将 NetBox 安装到非标准路径,请务必先更新此脚本中的系统路径。)

sudo ln -s /opt/netbox/contrib/netbox-housekeeping.sh /etc/cron.daily/netbox-housekeeping

测试验证:

python3 manage.py runserver 0.0.0.0:8000 --insecure

此时浏览器如果无法访问 请关闭 防火墙:

systemctl stop firewalld

systemctl disable firewalld

或者放行端口:

firewall-cmd --zone=public --add-port=8000/tcp --permanent
firewall-cmd --reload

pg_dump 备份 NetBox3的数据:

pg_dump --username netbox --password --host localhost netbox > netbox.sql

引用:

        Installing NetBox - NetBox Documentation
        https://netbox.readthedocs.io/en/stable/installation/

 类似资料: