问题:

假如有A、B、C、D....等机器,机器A为Ansible服务器机器B、C、D...等为Ansible管理的节点服务器,A机器与其他机器都不在同一个网络,也就是A机器必须添加VPN之后才能与其他机器通信,我要上传文件夹到节点服务器;
 
普通的上传文件方法是用Ansible的copy模块把放在files里的文件上传上去,这个昨天部署的时候,4台并发,打包上传,用了42分钟,平时手动拷贝一下分把钟的事情,这样就让自动部署失去意义了
name: put the latest api to server
copy: src=api.tar.gz dest=/usr/local/tomcat/webapps/
 
传慢的原因分析:(我自己这么想的)
1:Ansible是通过VPN连接上去的,上传速度慢
2:Ansible文件上传本身速度就慢
 
解决办法:
我先手动上传到一台B机器,然后由B机器用scp的形式分发给C、D、E....等机器
 
解决过程遇到的问题:
也就是Ansible要把写好的scp拷贝脚本在B机器上执行,然后就动手干,先把文件夹手动上传到B机器的/home/lile目录下,先做单台测试:
---
 - hosts: B机器
   remote_user: lile
   sudo: yes
 
   tasks:
    - name: from B机器 put the api to other node
      shell: scp -r -P 34110 /home/lile/api lile@C机器:/home/lile/
 
这里执行的结果就是,一直卡着不动,然后在B机器上去查看ps -ef|grep scp 是可以看得到Ansible在B机器上执行scp脚本的一些东西,比如:
他卡在那里,那我就在B机器上自己手动执行这几条命令,看行不行,能不能执行成功,因为ansible的原理是把脚本拷贝在远程节点的tmp下,然后执行吗,既然他卡着了,肯定有问题,那我手动执行一下,问题就找到了,执行tmp的那个脚本的时候,提示要输入密码,那么怎么解决scp不需要密码呢,那就是把自己的公钥拷过去,也就是ssh-copy-id -i B机器的id_rsa.pub C机器,这样B机器拷贝东西过去就不用密码了,再来执行一遍这个yml,还是卡着,这又是为啥呢,我按照前面的办法,手动执行他传过来的脚本,是可以成功scp过去的,后来想了一想,因为ansible是用普通用户执行的,用了sudo,sudo加scp是必须得要输入密码的,那我怎么把sudo这个东西去掉呢,反过来看了一下yml,sudo用了yes,那么我把这一句去掉就可以了,但是其他的还是的要sudo才能行,就直能把这个拷贝的yml做一个单独的执行过程了。
 
 
最后的那个模型大概就是这样:
 
---
 - hosts: B机器
   remote_user: lile
 
   tasks:
    - name: from B机器 put the api to other node
      shell: scp -r -P 34110 /home/lile/api lile@{{ item }}:/home/lile/
      with_items:
         - C机器
         - D机器
         - E机器
         - F机器
         ......

 

解决ansible上传速度慢的问题的更多相关文章

  1. 关于主机FTP连接不上,无法列出目录,列表错误,上传速度慢,掉速的解决办法

    FTP是一种文件传输协议,它支持两种模式: 一种方式叫做Standard (也就是 Active,主动方式), 一种是 Passive (也就是PASV,被动方式). Standard模式 FTP的客 ...

  2. 【安富莱专题教程第6期】SEGGER的J-Scope波形上位机软件,RTT模式波形上传速度可狂飙到500KB/S左右

    说明:1.在实际项目中,很多时候,我们需要将传感器或者ADC的数值以波形的形式显示.通常的解决办法是用串口上位机,USB接口上位机或者MDK的逻辑分析仪功能,使用这三种方式都比较繁琐.本期专题为大家讲 ...

  3. 解决phpmyadmin上传文件大小限制的配置方法

    解决phpmyadmin上传文件大小限制的配置方法 phpmyadmin导入SQL文件时涉及到phpmyadmin上传文件大小限制问题,默认phpmyadmin上传文件大小为2M,如果想要phpmya ...

  4. 解决nginx上传模块nginx_upload_module传递GET参数

    解决nginx上传模块nginx_upload_module传递GET参数的方法总结 最近用户反映我们的系统只能上传50M大小的文件, 希望能够支持上传更大的文件. 很显然PHP无法轻易实现大文件上传 ...

  5. 解决phpmyadmin上传文件大小限制的配置方法(转)

    phpmyadmin导入SQL文件时涉及到phpmyadmin上传文件大小限制问题,默认phpmyadmin上传文件大小为2M,如果想要 phpmyadmin上传超过2M大文件,就需要修改phpmya ...

  6. 我是如何让minio client上传速度提高几十倍的

    minio java client 使用okhttp作为底层的http实现,在产品包里面局域网上传文件的速度一直只有400~800KB/s,经过一天排查发现是-Djava.compile=none禁用 ...

  7. js 文件异步上传 显示进度条 显示上传速度 预览文件

    通常文件异步提交有几个关键 1.支持拖拽放入文件.2.限制文件格式.3.预览图片文件.4.上传进度,速度等,上传途中取消上传.5.数据与文件同时上传 现在开始笔记: 需要一个最基础的元素<inp ...

  8. 解决wordpress上传文件出现http错误问题

    解决wordpress上传文件出现http错误问题 问题现象 今天上传约1.4m大小的gif文件到wordpress的媒体库时失败,提示http错误. 原因 由于之前一直上传图片都是可以的,所以推测最 ...

  9. zt对于C#中的FileUpload解决文件上传大小限制的问题设置

    对于C#中的FileUpload解决文件上传大小限制的问题设置 您可能没意识到,但对于可以使用该技术上载的文件的大小存在限制.默认情况下,使用 FileUpload 控件上载到服务器的文件最大为 4M ...

随机推荐

  1. java笔记 -- 数学函数与常量

    Math类中, 包含了各种数学函数 不用在数学方法名和常量名前添加前缀Math., 只要在源文件的顶部加上这行代码: import static java.lang.Math.*; (静态导入) 例: ...

  2. 随机森林和GBDT

    1. 随机森林 Random Forest(随机森林)是Bagging的扩展变体,它在以决策树 为基学习器构建Bagging集成的基础上,进一步在决策树的训练过程中引入了随机特征选择,因此可以概括RF ...

  3. 【分布式搜索引擎】Elasticsearch中的基本概念

    一.Elasticsearch中的基本概念 以下概念基于这个例子:存储员工数据,每个文档代表一个员工 1)索引(index)  在Elasticsearch中存储数据的行为就叫做索引(indexing ...

  4. LeetCode--038--报数(java)

    报数序列是一个整数序列,按照其中的整数的顺序进行报数,得到下一个数.其前五项如下: 1. 1 2. 11 3. 21 4. 1211 5. 111221 1 被读作  "one 1" ...

  5. 『Python CoolBook:Collections』数据结构和算法_collections.deque队列&yield应用

    一.collections.deque队列 deque(maxlen=N)构造函数会新建一个固定大小的队列.当新的元素加入并且这个队列已满的时候,最老的元素会自动被移除掉. 如果你不设置最大队列大小, ...

  6. Pyhon中运算符的使用

    1. a & b python中的&延续了C/C++的含义,表示位运算. 例如 3 & 4:3&5:6&7 3 & 4 = (011)2 & ( ...

  7. layer中每次用到都要查来查去的功能

    1.关闭当前弹出层 var index = parent.layer.getFrameIndex(window.name); setTimeout(function(){parent.layer.cl ...

  8. Python装饰器基础及运行时间

    一.装饰器基础 装饰器是可调用的对象,其参数是另一个函数(被装饰的函数).装饰器可能会处理被装饰的函数,然后把他返回,或者将其替换成另一个函数或可调用对象. eg:decorate装饰器 @decor ...

  9. python笔记8-列表list操作、多维数组

    #!/usr/bin/python #python里面有个这个话,代表在linux下运行的时候#去哪个目录下找python的解释器,在windows上运行不用写# coding:utf-8# __*_ ...

  10. 1) 嵌套的 div ,或者 ul ol .li 阻止冒泡 ,特别是 对应onclick="test(event)" 通过传递event 阻止 冒泡. cancelBubble , stopPropagation

    1 .html 结构: <ul class="ul_2 hide" data-first="5"> <li class="li_2& ...