😆 开发自运维平台 😶 后端
devEops
Author: YoLoveLife.com
该项目为devEops的后端部分 前端部分请关注
运维体系解决方案(正在成长中)
前后段分离啦!告别之前的Jinja2
django模型 & rest-framework
travis & django TestCase
如果你关注:自动化运维、运维资源管理等内容
如果你关注:django开发、rest-framework等内容
求求你们
关于我开发中遇到的问题 我会写在issues当中供有需要的朋友
这些问题都是在查询了诸多资料并亲身尝试大量解决方案
您可以在issues中搜索helper查看我写的相关问题 我写的很用心
如果未找到您关注的问题或者您对我的项目有建议请在issues和我讨论
Contents
介绍
本开发自运维平台致力于IT资源信息的整合与自动化运维,通过服务、应用配置的信息整合来运维提供帮助。
devEops正在不断成长
- 所有运维操作都基于信息整合的正确性和一致性(资产信息管理)
💾 - 对接VMware|Aliyun自动拉取信息入库资产
📊 提供各类信息统计图表(资产|运维)等- 基于Ansile的运维元操作|任务的定义
- 基于WebSocket以及SSHProxy的工单操作
- 基于Django自带auth认证体系的资产与权限关联
- 域名管理与解析信息查询与刷新
- 详细权限操作,区分开发人员以及运维人员
平台一览
💪 登陆界面
💪 仪表盘界面
并且每周提供可供保存的静态页面的报告 有!但是很丑
💪 资产管理
应用组可定义架构图 关联跳板机以及密钥
应用组可全局添加参数 该参数会注入运维操作中的变量中
主机可以根据任意信息进行检索
根据VMware|ALIYUN API可进行详细信息(监控|配置)获取查看
💪 域名管理
基于树结构的域名管理
💪 密钥管理
基于服务器端直接生成的ssh-rsa密钥 私钥将会直接加密存储入数据库
只有当您做运维操作|SSH连接的时候才会解析并且使用
💪 QR-Code
基于Google-Authority的二次验证
💪 元操作及任务
基于Ansible的数据模型 将用户的Ansible直接存储入数据库中
当用户使用任务直接从CMDB中导出需要执行的主机列表以及参数列表
选择元操作所涉及的主机范围
选择某个应用组下的若干个元操作组成一个任务
💪 工单系统
用户根据自身权限可以发布工单(涉及任务)进行执行
选择工单后用户可以进行执行
如何安装
devEops依赖于python3.5、诸多python第三方模块、mysql数据库、redis缓存
以下操作环境已经拥有python3.5、mysql数据库、redis缓存
$ cd path/to/project/folder/
#安装部分依赖
yum install openssl-devel python3-devel openldap-devel
#安装python第三方库
$ pip install -r requirements.txt
#修改SSH的连接属性
$ vim /etc/ssh/ssh_config **注意是ssh_config而非sshd_config**
$ StrictHostKeyChecking no # 关闭指纹识别
$ :wq
#连接本地资源并创建数据表结构
$ vim deveops/conf.py # 里面包含了所有连接数据以及定时任务 请填写您需要的数据内容
$ python manage.py makemigrations
$ python manage.py migrate
$ # 删除表结构中的外键 减少运行过程中的锁争用问题、减少死锁概率、数据解耦
$ select concat("alter table ",table_schema,".",table_name, " drop foreign key ",CONSTRAINT_NAME,";") from INFORMATION_SCHEMA.KEY_COLUMN_USAGE where table_schema='deveops_v3' and REFERENCED_TABLE_NAME is not null into outfile '/tmp/fk_1.sql';
#启动服务
$ python manage.py runserver &
#默认启动在8000端口 你可能需要一个nginx做Web服务器
请务必配置一下Nginx代理来限制project/media下的访问权限 否则重要信息泄露的问题