Agent(方式)

1:服务器每台都需要安装Agent 达到采集速度快,简单;造成性能损耗
获取每台服务器的资产并有返回值:v=subprocess.getoutput('dir')或者ipconfig
返回给api api在进行入库 (api 1.url 2.指定发送数据格式 3.并有返回值给客户端)
2:应用场景:服务较多的公司  
客户端:

import subprocess
v1=subprocess.getoutput('ipconfig')
# print(v1)
value1=v1[20:30] #采集到一套资产 v2=subprocess.getoutput('dir') #采集到另外一条命令
# print(v2)
value2=v2[0:5] #连接到数据库,写入到数据库 数据往url上面发送
url="http://127.0.0.1:8000/asset.html"
import requests response=requests.post(url,data={'k1':value1,'k2':value2}) #数据发送到指定url上 发送完数据有返回值,收到url给返回的信息
print(response.text)
服务端 API:
from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^asset.html$',views.asset),
] from django.shortcuts import render,HttpResponse # Create your views here. def asset(request): #接收用户发来的消息
if request.method == "POST":
print(request.POST)
#并写入数据库
return HttpResponse('1002')
else:
return HttpResponse('1001')
#

    

Paramiko(ssh方式)

通过远程执行一条命令 导入paramiko模块
每个服务器都需要安装SSH远程
流程:中控机去服务器采集信息,采集完的信息返回给中控机 然后中控机把信息又返回给api,api收到消息并返回给中控机
采集的资产信息放在中控机(paramiko模块)v=subprocess.getoutget('ipconfig') 拿到的是中控机的采集信息
中控机在把信息返回给api,api在进行入库
优点:无Agent 缺点:网络慢
应用场景:服务器较少的公司  
############## Paramiko ,中控机放一份 #############
"""
- 远程连接服务器,执行命令,获取结果
- 将结果发送API
"""
import paramiko
#创建SSH对象
ssh=paramiko.SSHClient()
#允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
#连接服务器
ssh.connect(hostname='192.168.24.129',port=22,username='root',password='') #执行命令
stdin,stdout,stderr = ssh.exec_command('ls') #表示是要去连接,连接上执行命令 #获取命令结果
result = stdout.read() #关闭连接
ssh.close() #并拿到结果
value=result[0:10]
print(value)
import requests url = "http://127.0.0.1:8000/asset.html"
response=requests.post(url,data={'k1':value,'k2':'v2'})
print(response.text)

ssh远程连接

from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^asset.html$',views.asset),
] from django.shortcuts import render,HttpResponse # Create your views here. def asset(request): #接收用户发来的消息
if request.method == "POST":
print(request.POST)
#并写入数据库
return HttpResponse('')
else:
return HttpResponse('')
#

API

SaltStack

1. 安装和配置

"""
1. 安装salt-master
yum install salt-master
2. 修改配置文件:vim /etc/salt/master
interface: 0.0.0.0 # 表示Master的IP 本地ip
3. 启动
service salt-master restart (切记 一定关防火墙 systemctl stop firewalld)
"""

master

"""
1. 安装salt-minion
yum install salt-minion 2. 修改配置文件 vim /etc/salt/minion
master: 10.211.55.4 # master的地址

master:
- 10.211.55.4
- 10.211.55.5
random_master: True id: c2.salt.com # 客户端在salt-master中显示的唯一ID
3. 启动
service salt-minion restart 切记 一定关防火墙 systemctl stop firewalld) """

minion

2. 授权

在master里面输入
salt -key -L 查看已授权和未授权
salt -key -A 手动授权
salt-key -r salve_id # 拒绝指定id的salve
salt-key -d salve_id # 删除指定id的salve

master

3. 执行命令

在master服务器上对salve进行远程操作

salt 'c2.salt.com' cmd.run  'ifconfig'
salt ‘*’ cmd.fun 'ls'

基于shell命令

import salt.client
local = salt.client.LocalClient()
result = local.cmd('c2.salt.com', 'cmd.run', ['ifconfig'])

基于Salt的API

CMDB资产采集的更多相关文章

  1. CMDB资产采集方案

    CMDB资产采集方案 CMDB 资产采集的方案总共有四种 Agent SSH类 Saltstack Puttet 方案设计,从性能上考虑 下面前三种是用Python开发的,目标是兼容三种采集方式的软件 ...

  2. CMDB资产采集笔记

    一.资产采集四种方式 1. Agent方式 API:Django接收数据并入库 程序:放置在每台服务器 应用场景:针对服务器较多的公司 步骤一: #执行本地命令的库 import subprocess ...

  3. CMDB资产采集的四种方式

    转 https://www.cnblogs.com/guotianbao/p/7703921.html 资产采集的概念 资产采集的四种方式:Agent.SSH.saltstack.puppet 资产采 ...

  4. CMDB资产采集方式

    一:Agent方式 原理:在每台服务器装上agent客户端程序,定时向数据库发送指定的资产信息. 优点:速度快. 缺点:服务器上需要多装一个软件 import subprocess import re ...

  5. CMDB02/ 单例模式、资产采集参考命令、日志处理

    CMDB02/单例模式.资产采集参考命令.日志处理 目录 CMDB02/单例模式.资产采集参考命令.日志处理 1. 单例模式 1.1 多例模式 1.2 单例模式 1.2.1 单例模式/错误 1.2.2 ...

  6. CMDB服务器管理系统【s5day91】:资产采集相关问题

    资产采集唯一标识和允许临时修改主机名 class AgentClient(BaseClient): def exec(self): obj = PluginManager() server_dict ...

  7. CMDB学习之八,完成所有资产采集信息的收集

    #!/usr/bin/env python # -*- coding:utf-8 -*- import traceback from .base import BasePlugin from lib. ...

  8. Python之CMDB资产管理系统

    最近正好在给公司做CMDB资产管理系统,现在做的也差不多了,现在回头吧思路整理下. CMDB介绍 CMDB --Configuration Management Database 配置管理数据库, C ...

  9. CMDB03 /今日未采集的资产、资产入库、资产变更记录、资产采集

    CMDB03 /今日未采集的资产.资产入库.资产变更记录.资产采集 目录 CMDB03 /今日未采集的资产.资产入库.资产变更记录.资产采集 1. 获取今日未采集的服务器 2. server资产入库以 ...

随机推荐

  1. 戴尔R720xd服务器系统安装

    型号:R720xd 开启服务器,Ctrl+R进入raid配置 配置完raid后F2对硬盘进行格式化 保存并重启 F11进入BIOS选项设置U盘启动 选择U盘启动 开始进行系统安装!

  2. Unity3d底层数据传递分析

    WeTest 导读 这篇文章主要分析了在Mono框架下,非托管堆.运行时.托管堆如何关联,以及通过哪些方式调用.内存方面,介绍了什么是封送,以及类和结构体的关系和区别. 一.托管交互(Interop) ...

  3. 排序算法Java实现(希尔排序)

    算法描述:先将待排序序列的数组元素分成多个子序列,使得每个子序列的元素个数相对较少,然后对各个子序列分别进行直接插入排序,待整个待排序序列“基本有序”后,再对所有元素进行一次直接插入排序. packa ...

  4. linux-2.6.18源码分析笔记---信号

    一.相关数据结构及其位置(大致浏览即可,介绍流程时再来仔细看) 1.1 进程描述符struct task_struct所在目录:include\linux\sched.h 关注task_struct中 ...

  5. 【BootStrap】 布局组件 I

    BootStrap布局组件 I 除了在原生的HTML基础上进行了外观和类别上的改进,BS还包装了很多组件进库中,设计网页时我们可以方便地调用这些组件.下面来简略地介绍一下各种各样的组件 ■ 字体图标 ...

  6. CAS简介和无锁队列的实现

    Q:CAS的实现 A:gcc提供了两个函数 bool __sync_bool_compare_and_swap (type *ptr, type oldval, type newval, ...)// ...

  7. [poj1094]Sorting It All Out_拓扑排序

    Sorting It All Out poj-1094 题目大意:给出一些字符串之间的大小关系,问能否得到一个唯一的字符串序列,满足权值随下标递增. 注释:最多26个字母,均为大写. 想法:显然,很容 ...

  8. Spring Boot + Freemarker多语言国际化的实现

    最近在写一些Web的东西,技术上采用了Spring Boot + Bootstrap + jQuery + Freemarker.过程中查了大量的资料,也感受到了前端技术的分裂,每种东西都有N种实现, ...

  9. php缩放gif和png图透明背景变成黑色的解决方法_php技巧

    工作中需要缩放一些gif图然后在去Imagecopymerge,可是发现使用了imagecreatetruecolor和imagecopyresampled后发现背景图不对,本来透明的背景图变成了黑色 ...

  10. 【Spring系列】自己手写一个 SpringMVC 框架

    参考文章 一.了解SpringMVC运行流程及九大组件 1.SpringMVC的运行流程 1)用户发送请求至前端控制器DispatcherServlet 2)DispatcherServlet收到请求 ...