nodejs ssh2 基本功能的封装

2019-03-21 14:49:10

参考地址  nodejs ssh2 基本功能的封装


封装nodejs的基本功能,封装为一个类,实现的功能能够如下:


对于反复连接断开1000次,测试运行无错,也没有内存泄露

对于运行shell命令,测试在一次连接中运行8000+条命令,无错

对于上传下载文件夹,上传下载一个文件夹中包含800+的文件夹,共7000+文件无问题

在单连接测试下,运行状况良好,多连接同时运行测试时,当同时连接数量超过20台机器,会问题有的机器连接不上的问题,不过对于单连接和控制连接数来说封装的功能已经足够了

封装代码的下载链接(不要积分的) 

1.连接远程linux主机


/**

* 描述:连接远程机器

* 参数:server,远程机器凭证;

*       then,回调函数

*/

ssh2.connect(server, then) 

1

2

3

4

5

6

2.断开远程主机


/**

* 描述:断开远程连接

* 参数:then,回调函数

*/

ssh2.disconnect(then)

1

2

3

4

5

3.执行shell命令


/**

* 描述:执行shell命令

* 参数:cmd,要执行的命令;

*       then,回调函数

* 回调:then(err, data):data 运行命令之后的返回信息

*/

ssh2.exec(cmd, then)

1

2

3

4

5

6

7

4.上传文件


/**

* 描述:上传文件

* 参数:localPath,本地路径

*       remotePath,远程路径

*       then,回调函数

* 回调:then(err, result)

*/

ssh2.uploadFile(localPath, remotePath, then)

1

2

3

4

5

6

7

8

5.下载文件


/**

* 描述:下载文件

* 参数:localPath,本地路径

*       remotePath,远程路径

*       then,回调函数

* 回调:then(err, result)

*/

ssh2.downloadFile(remotePath, localPath, then)

1

2

3

4

5

6

7

8

6.创建目录


/**

 * 描述:创建目录

 * 参数: remoteDir 远程路径;

 *      then 回调函数

 * 回调:then(err, date) : data创建目录之后返回的信息

 */

ssh2.mkdir(remoteDir, then)

1

2

3

4

5

6

7

7.删除目录


/**

 *  描述:删除目录

 *  参数:remoteDir 远程路径

 *       then 回调函数

 *  回调:then(err, date) : data 留下的接口,无任何返回数据

 */

ssh2.rmdir(remoteDir, then)

1

2

3

4

5

6

7

9.上传文件夹


/**

* 描述:上传文件到远程linux机器

* 参数: remotePath 远程路径;

*       localDir 本地路径,

*       then 回调函数

* 回调:then(err)

*/

ssh2.uploadDir(localDir, remoteDir, then)


10.下载文件夹


/**

* 描述:下载目录到本地

* 参数: remotePath 远程路径;

*       localDir 本地路径,

*       then 回调函数

* 回调:then(err)

*/

ssh2.downloadDir(remoteDir, localDir, then)



  • 2019-11-28 11:00:35

    Vue子组件调用父组件的方法

    下面有三种方法,我自己重点推荐第一种,毕竟这种简单粗暴好用好理解,不过这个有一个弊端,再组件嵌套组件的时候,尤其是用第三方组件里面调用自己的子组件的时候,其实已经是孙子组件了,这个时候就要parent.parent。。。。,这样就不好了,我们就得考虑其他方法了,具体怎么判断是父组件,还是爷爷组件,我会单独出一篇文章讲述。

  • 2019-11-29 13:04:47

    计算一个多边形的重心点坐标(准确版)

    在之前的 《如何判断一个多边形是否合法》 一文中有提到,用无人机规划飞行路线前,往往需要框选一个多边形的区域。 而在地图控件上显示这个多边形区域时,往往会遇到这样一个需求:需要把所要测绘的多边形区域移动到地图中心。 实现这个需求的基本思路就是:获取到多边形区域的重心点坐标,然后利用地图控件的 setCenter方法,就可以把地图的显示中心移动到多边形区域重心了。那么问题来了,如何求出一个多边形的重心点坐标呢?

  • 2019-11-29 13:06:27

    如何判断一个多边形是否合法

    利用无人机对一片区域进行测绘前,我们会先在地图上框选一个区域,然后再规划飞行的路线,而需要测绘的这片区域往往是一个多边形。在 MeshKit 中,我们加入了多边形区域的编辑功能,其中就涉及判断用户所编辑出来的多边形是否合法的问题。

  • 2019-11-29 13:47:22

    百度地图做电子围栏总结

    在地图上画出围栏,设置围栏信息后保存,生成围栏列表。全选时,地图视野可看到全部的围栏区域,单独勾选会调整地图视野到当前勾选的围栏。围栏区域的中心点要显示围栏名称。

  • 2019-11-29 13:50:29

    图片连接处出现白线

    block导致,只要父元素设置font-size:0或者设置img display: block; 便可。但是我设置了没有用,这条线不是所有的机型都有,而且页面滚动之后又消失,我琢磨半天,各种尝试,发现把图片高度减少(增加)1px就解决了。因为我们的项目是用postcss-px-to-viewport,我每张图片都是设置高度的,应该是数值转换出现偏差。

  • 2019-11-29 13:54:07

    粗略计算多边形中心点(并不是很准确,但简单好用)

    也是再做栅栏系统,搜索如何获取多边形中心点的问题上,发现了这个,简单易于理解,但是并不是特变准确,但也不影响使用。 后来发现了新的算法,并且百度地图也提供相应的api。 具体内容我写在了前面的文章,大家可以找一下。

  • 2019-11-29 14:20:38

    vue,vuthis.$parent算法

    由于组件嵌套,其实vue parent的位置也改变了,我们可以通过下面的图片,来看一下,parent到底什么哪一层