标签:唯一约束 好的 环境 ima 项目 实现 记录 dem -o
堡垒机介绍很多人觉得,堡垒机就是跳板机,这是不全面的。跳板功能只是堡垒机所具备的功能的其中一项。堡垒机还有以下两个至关重要的功能:
号称没有好的开源项目,因为底层的SSH还是通过paramiko模块的长链接的ssh实现的。但是这个和原生的ssh比还是不太稳定,不太好用。不适合生产环境。要好用还是得去改原生的ssh,但是我们不会,我们只会改python。总之这章就是实现一个堡垒机的功能,真要做个好用的以后再说吧。
比较有名的大概是这个:jumpserver - 开源跳板机
虽然上面说了,用这个模块不稳定,但是我们也没办法,毕竟只会这个。
paramiko之前已经学习过了,不过当时用的都是短连接。即:连接一次,执行一条命令,返回结果,断开。这里我们要用长连接。
长连接的代码在demos文件夹下的demo.py这个文件里,另外还要用到interactive.py这个文件。安装模块的时候不安装这个demos文件夹,所以我们去github上下下来:
https://github.com/paramiko/paramiko/tree/master/demos
利用demo.py程序,我们可以进行ssh的长连接。下面的开发都是基于这个程序为基础,在这个程序的基础上,修改该程序的源码添加上记录用户输入的代码,并写入数据库。于是审计管理便实现了。
任何人只能通过堡垒机登录设备,堡垒机可以链接管理所有的设备:
还需要确保用户一登录堡垒机就进入你的程序,并且不能退出(一退出就退出整个堡垒机),就是只能在你的做的shell下运行,不能进入原生的shell。可以通过设置环境变量实现:
环境变量保存在这里: ~/.bashrc
,修改文件在最后加上这句: python3 /etc/myJunpServer.py
直接运行你的程序。首次设置完成后如果要让它立刻生效,可以执行这个命令:source .bashrc
加载最新的配置。
主机表:
id | 主机名 | IP | 端口号 |
---|---|---|---|
自增id | 注释名称 | 字符串类型 | 数值类型,默认22 |
主机认证表(和主机表多对多关联):
id | 名称 | 用户名 | 密码 |
---|---|---|---|
自增id | 注释名称 | 用户名 | 明文的字符串 |
主机群组表(和主机表+主机认证表多对多关联):
之前的结合表都是结合2张表,这里要结合3张表。
因为,不同的群组里可能包含相同的机器,但是不同群组中同一台机器对应的权限可能不同。
id | 群组名 | 备注 |
---|---|---|
自增id | 唯一 | 备注信息 |
堡垒机账号表(和主机表多对多关联,和主机群组表多对多关联):
id | 用户名 | 密码 |
---|---|---|
自增id | 唯一约束 | 加密存储 |
审计日志记录表:
id | 时间 | 用户id | 主机id | 操作消息 |
---|---|---|---|---|
自增id | 操作时间 | 关联账号表的id | 关联主机表的id | 操作内容 |
大概就是这么个表结构
标签:唯一约束 好的 环境 ima 项目 实现 记录 dem -o
原文地址:http://blog.51cto.com/steed/2066244