1、服务器端收到的数据和客户端的数据不一样

print(request.post)

少发了,还是少取了,说明根本没有把数据全发过来

print(request.body)

1、只把字典的key给我发过来的

答:这是正常的,这种方式去提交的时候,伪造的是from表单的提交

2、你发数据向后台发点什么?

只可能存字符串,不可能存在字典

2、post是怎样把请求发到后台的

要发怎么发?把字典转换成字符串,必须这么发,因为后台它只认识这种请求头,根据这种结构进行解析

username: 'xxx'
username: '123'
hobby: [1,2,3,4]
hobby: {} $ajax({
url: 'xx',
data:{
k1: 1,
k2: "xx"
k2: [1,2,3,4],
k2: JSON.stringfy({'kk1':'xxx'}),
} }) #Form表单提交和默认提交 + request.post(data='xxx')
#k1=1&k2=xx, content-type: annotation/x-www-form-urlencoded
后台: request.POST,
- annotation/x-www-form-urlencoded
- 根据这种结构解析: k1=1&k2=xx #定义请求头:
$ajax({
url: 'xx',
headers:{'content-type':'application/json'},
data: JSON.stringfy({k1':1,k2:"xx",k2: [1,2,3,4],}),
}) #"{k1':1,k2:"xx",k2: [1,2,3,4],}", content-type: application/json 后台: request.POST,
- annotation/x-www-form-urlencoded
- 根据这种结构解析: k1=1&k2=xx
request.body 

具体代码

class BaseClient(object):
def __init__(self):
self.api = settings.API def post_server_info(self,server_dict):
# requests.post(self.api,data=server_dict) # 1. k=v&k=v, 2. content-type: application/x-www-form-urlencoded
response = requests.post(self.api,json=server_dict) # 1. 字典序列化;2. 带请求头 content-type: application/json def exec(self):
raise NotImplementedError('必须实现exec方法')

3、线程池

1、引子:

如果是100台每台等2分钟,ssh是串行要等200分钟

2、代码如下:

from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor
import time def task(arg1,arg2):
print(arg1,arg2)
time.sleep(1) pool = ProcessPoolExecutor(20) for i in range(100):
pool.submit(task,i,i)

3、关于线程池的说明:

1、刚开始我们不知道多少个池子,我就默认创建20个
2、现在他没有执行,当我们用的时候边用边执行

4、进程池

from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor
import time def task(arg1,arg2):
print(arg1,arg2)
time.sleep(1) pool = ThreadPoolExecutor(20) for i in range(100):
pool.submit(task,i,i)

小结:

1、python2默认没有线程池,只有进程池,python3就有

2、通过一行代码给它改成进程池

3、不要用python2以前里有进程池,很麻烦

CMDB服务器管理系统【s5day89】:采集资产之汇报信息的更多相关文章

  1. CMDB服务器管理系统【s5day88】:采集资产之Agent、SSH和Salt模式讲解

    在对获取资产信息时,简述有四种方案. 1.Agent  (基于shell命令实现) 原理图 Agent方式,可以将服务器上面的Agent程序作定时任务,定时将资产信息提交到指定API录入数据库 优点: ...

  2. CMDB服务器管理系统【s5day87】:需求讨论-设计思路

    自动化运维平台愿景和服务器管理系统背景 服务器管理系统 管理后台示例 需求和设计 为什么开发服务器管理系统? 背景: 原来是用Excel维护服务器资产,samb服务[多个运维人员手动维护] 搭建运维自 ...

  3. CMDB服务器管理系统【s5day91】:如何实现允许临时修改主机名

    一.sn号唯一 & 如何实现允许临时修改主机名 1.物理机 1.sn,物理机唯一 2.后台管理: 买服务器,清单:SN号,硬盘,内存... 作业:python 读取excel,xldt 3.资 ...

  4. CMDB服务器管理系统【s5day92】:服务器管理回顾

    一.服务器管理回顾 1.requests 发送: requests.post(url='',data=,json=) requests.get() Django接受: request.POST, co ...

  5. CMDB服务器管理系统【s5day89】:采集资产之整合资产

    1.业务逻辑单独写 1.代码目录结构 2.client.py from src.plugins import PluginManager class BaseClient(object): def p ...

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

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

  7. CMDB服务器管理系统【s5day89】:部分数据表结构-资产入库思路

    1.用django的app作为统一调用库的好处 1.创建repository app截图如下: 2.好处如下: 1.app的本质就是一个文件夹 2.以后所有的app调用数据就只去repository调 ...

  8. CMDB服务器管理系统【s5day88】:采集资产-文件配置(一)

    django中间件工作原理 整体流程: 在接受一个Http请求之前的准备 启动一个支持WSGI网关协议的服务器监听端口等待外界的Http请求,比如Django自带的开发者服务器或者uWSGI服务器. ...

  9. CMDB服务器管理系统【s5day88】:采集资产-文件配置(二)

    上节疑问: 1.老师我们已经写到global_settings里了,为什么还要写到__init__.py setting 这的作用是为了:整合起两个的组合global_settings和setting ...

随机推荐

  1. spring boot 扫描不到自定义Controller

    使用springboot启动类配置扫描的两种注解配置方式: 1.@Controller   @EnableAutoConfiguration   @ComponentScan 2.@SpringBoo ...

  2. Linix基本命令

    基本命令关机:shutdown -h halt init 0 poweroff重启:shutdown -r reboot init 6pwd:查看工作目录ls:查看指定目录的内容-l:列表显示-a:显 ...

  3. Windows的GDI映射方式,逻辑坐标,设备坐标的理解

    最近在学Win32的编程,看的是<Windows程序设计第5版>一书,这本书是台湾人翻译的,有些译法和大陆不一样,书中还有一些错误的地方,很多时候需要中英文对照阅读,下载请点击 https ...

  4. (原创)超详细一步一步在eclipse中配置Struts2环境,无基础也能看懂

    (原创)超详细一步一步在eclipse中配置Struts2环境,无基础也能看懂 1. 在官网https://struts.apache.org下载Struts2,建议下载2.3系列版本.从图中可以看出 ...

  5. [经验总结] 从其它sheet页引用数据生成图表时没有图例的解决办法

    1.先给出一个在有数据区域的sheet页中生成的图表,比较全,图表和图例全部都有,如下图: 2.但是如果在其它 sheet页中引用该有数据的sheet数据时并生成图表,生成的图表只有图表区域显示,图例 ...

  6. springMVC DispatcherServlet类关系图

  7. 修改json对象的每一个值

    function fun1(obj){ var names={}; /*for in 可以用于数组或者对象*/ for(var name in obj){ names[name] = obj[name ...

  8. MySQL之表相关操作

    一 存储引擎介绍 存储引擎即表类型,mysql根据不同的表类型会有不同的处理机制 详见:http://www.cnblogs.com/linhaifeng/articles/7213670.html ...

  9. 【Topcoder 1643】PossibleOrders

    题意:给一些等价关系,问把所有的数按照大小排序的种类数. 思路:首先并查集维护等价类,然后设有\(n\)个等价类. 那么就可以\(dp\)了. 考虑\(dp(i)\)表示还剩下\(i\)个等价类,答案 ...

  10. 深入理解Fabric环境搭建的详细过程

    博主之前的文章都是教大家怎么快速的搭建一个Fabric的环境,但是其中大量的工作都隐藏到了官方的脚本中,并不方便大家深入理解其中的过程,所以博主这里就将其中的过程一步步分解,方便大家! 前面的准备工作 ...