AutoOps 是一款基于 2.0 版本django开发的,主要面向linux运维工程师使用,管理linux资产信息,Mysql数据库,批量执行命令、脚本,获取流量图,web ssh管理,技术文档等功能。
欢迎大家测试使用,有问题可反馈。
-
地址:
http://42.62.55.58:8003/
账号admin
密码1qaz.2wsx
-
后台地址
http://42.62.55.58:8003/admin
账号admin
密码1qaz.2wsx
-
博客:
http://hequan.blog.51cto.com/
-
github:
https://github.com/hequan2017/autoops/
-
码云:
https://gitee.com/hequan2020/autoops
-
1.6 Mysql数据库操作: 自动审核 + 执行 (目前只适用于Mysql)
-
1.5.1 Mysql数据库操作自动审核(预览版), 需要按照script/install_Inception.sh的步骤,先安装Inception。
-
1.5 后台更新为xadmin, 原有系统自带的admin保留,更名为oldadmin.
- 目前 xadmin兼容有问题。 看不见task里面的任务名字。 想要添加,格式为tasks.task.XXX。 具体名字可去 tasks/task.py 里面查找 或自定义。例如: tasks.task.clean_history_host_monitor.
- xadmin 不兼容 面对对象权限 插件guardian。 如果想设置 面向 对象的权限,请登陆 /oldadmin 进行设置。
-
1.4.1 更新django 为2.0。 如果想用django1.11版本,请看git 标记 v1.4-dj1.11
-
1.4 增加上传下载功能
-
1.3 新增 技术文档 板块。
-
1.2 权限管理完善。 增加附件上传下载功能。
-
1.1.5 新增 权限管理。 根据后台用户组,区分不同权限。如:在后台先建一个 测试机 组,把普通用户加入到此组。在前端添加资产时,在产品线中会出现测试机 。 测试机组下的用户 只管管理测试机产品线的资产。
-
1.1 新增 平台登录记录、web登录记录、密码修改等功能。
-
asset资产
- api
http://42.62.55.58:8003/asset/api/asset.html
- 自动获取服务器信息
- 全部导出
- CPU 内存 流量图
- api
-
names 用户(预留模块)
-
tasks任务
- 命令行
- 工具
- shell
- python
- yml
-
webssh 登陆 (用复制粘贴的时候,会显示二份,但实际只有一个,不影响使用,请忽略。)
-
library 技术文档 (真正运维人员的管理平台,自带技术文档,有问题不用再去别的地方找)
- DjangoUeditor 富文本编辑器
-
数据库自动审核-- 命令执行
- Inception
-
后台管理
- Python 3.6.2
- Django 2.0
- Python 2.7 (用来启动 supervisor)
- 开发环境部署:
1. 下载,安装基本环境,安装目录为/opt下,如是其他目录,请修改supervisor.conf中的相应设置即可。
cd /opt
yum install git sshpass -y
git clone git@github.com:hequan2017/autoops.git
cd autoops/
pip3 install -r requirements.txt
pip3 install git+git://github.com/sshwsfc/xadmin.git@django2
添加的资产 里面 请执行 yum install ipmitool dmidecode -y
以获取更多信息
2. 安装其他组件
-
执行
srcipt/install_redis.sh
-
安装
script/install_webssh.sh
, 需要修改的内容见脚本内,如果不需要webssh,可暂时不用安装。 -
安装
script/install_inception.sh
, 需要修改的内容见脚本内,如果不需要 数据库自动审核,可暂时不用安装。 -
安装
supervisor
pip2 install supervisor
echo_supervisord_conf > /etc/supervisord.conf
mkdir /etc/supervisord.d/
vim /etc/supervisord.conf
[include]
files = /etc/supervisord.d/*.conf
[inet_http_server]
port=0.0.0.0:9001
username=user
password=123
- 配置文件
cp /opt/autoops/script/supervisor.conf /etc/supervisord.d/
- 关于数据库 请修改
autops/settings
文件, 如果没有mysql,请选择上面那种,注释下面的。如果有,则可以启用mysql,设置相关连接地址。 关于mysql安装方法,可参考我的博客http://hequan.blog.51cto.com/5701886/1982428
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'autoops',
'USER': 'root',
'PASSWORD': '123456',
'HOST': '192.168.10.24',
'PORT': '3306',
}
}
- 修改settings 自定义参数
DEBUG = True ## 实际生产环境实用,请关闭 False
BROKER_URL = 'redis://127.0.0.1:6379/0' ##Redis地址
Webssh_ip = "42.62.6.54" ##WebSSH 软件的 访问IP
Inception_ip = '127.0.0.1' ## 此为 Inception 软件地址 需要设置
Inception_port = '6669' ## 此为 Inception 软件端口号
- 初始化数据库(可删除文件夹的 db.sqlite3, 如不想删除,请忽略下面3个命令)
python manage.py makemigrations
python manage.py migrate
python manage.py createsuperuser 创建管理员
-
启动supervisor进程管理
/usr/bin/python2.7 /usr/bin/supervisord -c /etc/supervisord.conf
加到linux 开机启动里面chmod +x /etc/rc.d/rc.local
把上面的命令放到这个文件里面 -
启动: 统一用supervisor 管理进程, 打开 0.0.0.0:9001 账号user 密码123 进入进程管理界面,管理uwsgi,redis,webssh,celery,Inception 等启动关闭。 此方法不涉及到nginx。
-
登陆后台,设置定时获取主机图,设置数据中心、组。
- 如果想在windows 下的 pycharm打开,请注释
asset/views.py
第20行,tasks/views.py
12 13 行。(因为ansible不好安装在windows 下环境)
- 如果想在生产环境部署、启动, 用nginx去处理。 可以参考
http://hequan.blog.51cto.com/5701886/1982769
, 请把supervisor.conf
中 关于uwsgi的部分删除掉, 用以下方式控制UWSGI的启动 关闭.
uwsgi --ini /opt/autoops/script/uwsgi.ini # 启动uwsgi配置 也可以把这个命令写到开机的文件里面
uwsgi --stop /opt/autoops/script/uwsgi.pid # 关闭uwsgi
uwsgi --reload /opt/autoops/script/uwsgi.pid #重新加载
nginx 配置文件修改如下
root /opt/autoops;
location / {
include uwsgi_params;
uwsgi_connect_timeout 30;
uwsgi_pass unix:/opt/autoops/script/uwsgi.sock;
}
location /static/ {
alias /opt/autoops/static/;
index index.html index.htm;
}
- 何全