appium是啥

  • 时间:
  • 浏览:1015
  • 来源:成都艾邦软件开发

pip是啥

pip 是 Python 包管理工具该工具提供了对Python 包的查找、下载、安装、卸载的功能。

推荐《Python教程》

目前如果你在 python.org 下载最新版本的安装包则是已经自带了该工具。

Python 2.7.9 或 Python 3.4 以上版本都自带 pip 工具。

pip 官网/project/pip/

你可以通过以下命令来判断是否已安装

pip --version

如果你还未安装则可以使用以下方法来安装

$ curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py # 下载安装脚本$ sudo python get-pip.py# 运行安装脚本

注意用哪个版本的 Python 运行安装脚本pip 就被关联到哪个版本如果是 Python3 则执行以下命令

$ sudo python3 get-pip.py# 运行安装脚本。

一般情况 pip 对应的是 Python 2.7pip3 对应的是 Python 3.x。

部分 Linux 发行版可直接用包管理器安装 pip如 Debian 和 Ubuntu

sudo apt-get install python-pip

相关免费资料分享点击即可免费观看~

1、数据分析_地震–Python实战之地震预测

.cn/live/5020_2148.html?s96806

2、数据分析_选股–Python项目实战智能选股股票

.cn/live/5020_2158.html?s96806

3、旅游数据分析–掌握Python工具全国上榜名吃尽在手中

.cn/live/5020_2154.html?s96806

142244252 学习资料交流群想要和志同道合的朋友一起学习大家互相分享自己的学习资料和作品欢迎感兴趣的朋友共同学习共同进步每天还会有免费的公开课程

简介

如果您听说过 Node或者阅读过一些文章宣称 Node 是多么多么的棒那么您可能会想“Node 究竟是什么东西” 即便是在参阅 Node 的主页之后您甚至可能还是 不明白 Node 为何物Node 肯定不适合每个程序员但它可能是某些程序员一直苦苦追寻的东西。

为试图解释什么是 Node.js本文将简要介绍一些背景信息它要解决的问题它如何工作如何运行一个简单应用程序最后Node 在什么情况下是一个好的解决方案。本文不涉及如何编写一个复杂的 Node 应用程序也不是一份全面的 Node 教程。阅读本文应该有助于您决定是否应该继续学习 Node以便将其用于您的业务。

Node 旨在解决什么问题

Node 公开宣称的目标是 “旨在提供一种简单的构建可伸缩网络程序的方法”。当前的服务器程序有什么问题我们来做个数学题。在 Java™ 和 PHP 这类语言中每个连接都会生成一个新线程每个新线程可能需要 2 MB 的配套内存。在一个拥有 8 GB RAM 的系统上理论上最大的并发连接数量是 4,000 个用户。随着您的客户群的增长如果希望您的 Web 应用程序支持更多用户那么您必须添加更多服务器。当然这会增加服务器成本、流量成本和人工成本等成本。除这些成本上升外还有一个潜在技术问题即用户可能针对每个请求使用不同的服务器因此任何共享资源都必须在所有服务器之间共享。鉴于上述所有原因整个 Web 应用程序架构包括流量、处理器速度和内存速度中的瓶颈是服务器能够处理的并发连接的最大数量。

Node 解决这个问题的方法是更改连接到服务器的方式。每个连接发射一个在 Node 引擎的进程中运行的事件而不是为每个连接生成一个新的 OS 线程并为其分配一些配套内存。Node 声称它绝不会死锁因为它根本不允许使用锁它不会直接阻塞 I/O 调用。Node 还宣称运行它的服务器能支持数万个并发连接。

现在您有了一个能处理数万个并发连接的程序那么您能通过 Node 实际构建什么呢如果您有一个 Web 应用程序需要处理这么多连接那将是一件很 “恐怖” 的事那是一种 “如果您有这个问题那么它根本不是问题” 的问题。在回答上面的问题之前我们先看看 Node 的工作原理以及它的设计运行方式。

Node 肯定不是什么

没错Node 是一个服务器程序。但是基础 Node 产品肯定 像 Apache 或 Tomcat。本质上那些服务器 “安装就绪型” 服 务器产品支持立即部署应用程序。通过这些产品您可以在一分钟内启动并运行一个服务器。Node 肯定不是这种产品。Apache 能通过添加一个 PHP 模块来允许开发人员创建动态 Web 页添加一个 SSL 模块来实现安全连接与此类似Node 也有模块概念允许向 Node 内核添加模块。实际上可供选择的用于 Node 的模块有数百个之多社区在创建、发布和更新模块方面非常活跃一天甚至可以处理数十个模块。本文后面将讨论 Node 的整个模块部分。

Node 如何工作

Node 本身运行 V8 JavaScript。等等服务器上的 JavaScript没错您没有看错。对于只在客户机上使用 JavaScript 的程序员而言服务器端 JavaScript 可能是一个新概念但这个概念本身并非遥不可及因此为何不能在服务器上使用客户机上使用的编程语言

什么是 V8V8 JavaScript 引擎是 Google 用于其 Chrome 浏览器的底层 JavaScript 引擎。很少有人考虑 JavaScript 在客户机上实际做了些什么实际上JavaScript 引擎负责解释并执行代码。Google 使用 V8 创建了一个用 C 编写的超快解释器该解释器拥有另一个独特特征您可以下载该引擎并将其嵌入任何 应用程序。V8 JavaScript 引擎并不仅限于在一个浏览器中运行。因此Node 实际上会使用 Google 编写的 V8 JavaScript 引擎并将其重建为可在服务器上使用。太完美了既然已经有一个不错的解决方案可用为何还要创建一种新语言呢

事件驱动编程

许多程序员接受的教育使他们认为面向对象编程是完美的编程设计这使得他们对其他编程方法不屑一顾。Node 使用了一个所谓的事件驱动编程模型。

清单 1. 客户端上使用 jQuery 的事件驱动编程

1

2

3

4

5

6

7

8

9

// jQuery code on the client-side showing how Event-Driven programming works

// When a button is pressed, an Event occurs - deal with it

// directly right here in an anonymous function, where all the

// necessary variables are present and can be referenced directly

$(#myButton).click(function(){

if ($(#myTextField).val() ! $(this).val())

alert(Field must match button text);

});

实际上服务器端和客户端没有任何区别。没错这没有按钮点击操作也没有向文本字段键入的操作但在一个更高的层面上事件正在 发生。一个连接被建立这是一个事件数据通过连接进行接收这也是一个事件数据通过连接停止这还是一个事件

为什么这种设置类型对 Node 很理想JavaScript 是一种很棒的事件驱动编程语言因为它允许使用匿名函数和闭包更重要的是任何写过代码的人都熟悉它的语法。事件发生时调用的回调函数可以在捕获事件处进行编写。这样可以使代码容易编写和维护没有复杂的面向对象框架没有接口没有过度设计的可能性。只需监听事件编写一个回调函数其他事情都可以交给系统处理

示例 Node 应用程序

最后我们来看一些代码让我们将讨论过的所有内容汇总起来从而创建我们的第一个 Node 应用程序。我们已经知道Node 对于处理高流量应用程序很理想所以我们将创建一个非常简单的 Web 应用程序一个为实现最快速度而构建的应用程序。下面是 “老板” 交代的关于我们的样例应用程序的具体要求创建一个随机数字生成器 RESTful API。这个应用程序应该接受一个输入一个名为 “number” 的参数。然后应用程序返回一个介于 0 和该参数之间的随机数字并将生成的数字返回给调用者。由于 “老板” 希望该应用程序成为一个广泛流行的应用程序因此它应该能处理 50,000 个并发用户。我们来看看以下代码

清单 2. Node 随机数字生成器

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

// these modules need to be imported in order to use them.

// Node has several modules.  They are like any #include

// or import statement in other languages

var http require(http);

var url require(url);

// The most important line in any Node file.  This function

// does the actual process of creating the server.  Technically,

// Node tells the underlying operating system that whenever a

// connection is made, this particular callback function should be

// executed.  Since were creating a web service with REST API,

// we want an HTTP server, which requires the http variable

// we created in the lines above.

// Finally, you can see that the callback method receives a request

// and response object automatically.  This should be familiar

// to any PHP or Java programmer.

http.createServer(function(request, response) {

// The response needs to handle all the headers, and the return codes

// These types of things are handled automatically in server programs

// like Apache and Tomcat, but Node requires everything to be done yourself

response.writeHead(200, {Content-Type: text/plain});

// Here is some unique-looking code.  This is how Node retrives

// parameters passed in from client requests.  The url module

// handles all these functions.  The parse function

// deconstructs the URL, and places the query key-values in the

// query object.  We can find the value for the number key

// by referencing it directly - the beauty of JavaScript.

var params url.parse(request.url, true).query;

var input params.number;

// These are the generic JavaScript methods that will create

// our random number that gets passed back to the caller

var numInput new Number(input);

var numOutput new Number(Math.random() * numInput).toFixed(0);

 

// Write the random number to response

response.write(numOutput);

 

// Node requires us to explicitly end this connection.  This is because

// Node allows you to keep a connection open and pass data back and forth,

// though that advanced topic isnt discussed in this article.

response.end();

   // When we create the server, we have to explicitly connect the HTTP server to

   // a port.  Standard HTTP port is 80, so well connect it to that one.

}).listen(80);

// Output a String to the console once the server starts up, letting us know everything

// starts up correctly

console.log(Random Number Generator Running...);

启动应用程序

将上面的代码放入一个名为 “random.js” 的文件中。现在要启动这个应用程序并运行它以便创建 HTTP 服务器并监听端口 80 上的连接只需在您的命令提示中输入以下命令% node random.js。下面是服务器已经启动并运行时看起来的样子

1

2

rootubuntu:/home/moila/ws/mike# node random.js

Random Number Generator Running...

访问应用程序

应用程序已经启动并运行。Node 正在监听所有连接我们来测试一下。由于我们创建了一个简单的 RESTful API所以可以使用 Web 浏览器来访问这个应用程序。键入以下地址确保您已完成了上面的步骤http://localhost/?number27。

您的浏览器窗口将更改到一个介于 0 到 27 之间的随机数字。单击浏览器上的 “重新载入” 按钮您会得到另一个随机数字。就是这样这就是您的第一个 Node 应用程序

Node 对什么有好处

到此为止您可能能够回答 “Node 是什么” 这个问题了但您可能还有一个问题“Node 有什么用途” 这是一个需要提出的重要问题因为肯定有些东西能受益于 Node。

它对什么有好处

正如您此前所看到的Node 非常适合以下情况在响应客户端之前您预计可能有很高的流量但所需的服务器端逻辑和处理不一定很多。Node 表现出众的典型示例包括

  • RESTful API

    提供 RESTful API 的 Web 服务接收几个参数解析它们组合一个响应并返回一个响应通常是较少的文本给用户。这是适合 Node 的理想情况因为您可以构建它来处理数万条连接。它仍然不需要大量逻辑它本质上只是从某个数据库中查找一些值并将它们组成一个响应。由于响应是少量文本入站请求也是少量的文本因此流量不高一台机器甚至也可以处理最繁忙的公司的 API 需求。

  • Twitter 队列

    想像一下像 Twitter 这样的公司它必须接收 tweets 并将其写入数据库。实际上每秒几乎有数千条 tweet 达到数据库不可能及时处理高峰时段所需的写入数量。Node 成为这个问题的解决方案的重要一环。如您所见Node 能处理数万条入站 tweet。它能快速而又轻松地将它们写入一个内存排队机制例如 memcached另一个单独进程可以从那里将它们写入数据库。Node 在这里的角色是迅速收集 tweet并将这个信息传递给另一个负责写入的进程。想象一下另一种设计常规 PHP 服务器会自己尝试处理对数据库本身的写入每个 tweet 都会在写入数据库时导致一个短暂的延迟因为数据库调用正在阻塞通道。由于数据库延迟一台这样设计的机器每秒可能只能处理 2000 条入站 tweet。每秒处理 100 万条 tweet 则需要 500 个服务器。相反Node 能处理每个连接而不会阻塞通道从而能够捕获尽可能多的 tweets。一个能处理 50,000 条 tweet 的 Node 机器仅需 20 台服务器即可。

  • 电子游戏统计数据

    如果您在线玩过《使命召唤》这款游戏当您查看游戏统计数据时就会立即意识到一个问题要生成那种级别的统计数据必须跟踪海量信息。这样如果有数百万玩家同时在线玩游戏而且他们处于游戏中的不同位置那么很快就会生成海量信息。Node 是这种场景的一种很好的解决方案因为它能采集游戏生成的数据对数据进行最少的合并然后对数据进行排队以便将它们写入数据库。使用整个服务器来跟踪玩家在游戏中发射了多少子弹看起来很愚蠢如果您使用 Apache 这样的服务器可能会 有一些有用的限制但相反如果您专门使用一个服务器来跟踪一个游戏的所有统计数据就像使用运行 Node 的服务器所做的那样那看起来似乎是一种明智之举。

Node 模块

尽管不是本文最初计划讨论的主题但应广大读者要求本文已经扩展为包含一个 Node Modules 和 Node Package Manager 简介。正如已经习惯使用 Apache 的开发人员那样您也可以通过安装模块来扩展 Node 的功能。但是可用于 Node 的模块极大地 增强了这个产品那些模块非常有用将使用 Node 的开发人员通常会安装几个模块。因此模块也就变得越来越重要甚至成为整个产品的一个关键部分。

在 “参考资料” 部分我提供了一个指向模块页面的链接该页面列示了所有可用模块。为了展示模块能够提供的可能性我在数十个可用模块中包含了以下几个模块一个用于编写动态创建的页面比如 PHP一个用于简化 MySQL 使用一个用于帮助使用 WebSockets还有一个用来协助文本和参数解析的模块。我不会详细介绍这些模块这是因为这篇概述文章旨在帮助您了解 Node 并确定是否需要深入学习再次重申如果需要那么您肯定有机会用到这些可用模块。

另外Node 的一个特性是 Node Package Module这是一个内置功能用于安装和管理 Node 模块。它自动处理依赖项因此您可以确定您想要安装的任何模块都将正确安装并包含必要的依赖项。它还支持将您自己的模块发布到 Node 社区假如您选择加入社区并编写自己的模块的话。您可以将 NPM 视为一种允许轻松扩展 Node 功能的方法不必担心这会破坏您的 Node 安装。同样如果您选择深入学习 Node那么 NPM 将是您的 Node 解决方案的一个重要组成部分。

结束语

阅读本文之后您在本文开头遇到的问题 “Node.js 究竟是什么东西?” 应该已经得到了解答您应该能通过几个清晰简洁的句子回答这个问题。如果这样那么您已经走到了许多程序员的前面。我和许多人都谈论过 Node但他们对 Node 究竟用于做什么一直很迷惑。可以理解他们具有的是 Apache 的思维方式认为服务器就是一个应用程序将 HTML 文件放入其中一切就会正常运转。由于大多数程序员都熟悉 Apache 及其用途因此描述 Node 的最简单方法就是将它与 Apache 进行比较。Node 是一个程序能够完成 Apache 能够完成的所有任务借助一些模块而且作为一个可以将其作为基础进行构建的可扩展 JavaScript 平台Node 还能完成更多的任务。

从本文可以看出Node 完成了它提供高度可伸缩服务器的目标。它使用了 Google 的一个非常快速的 JavaScript 引擎即 V8 引擎。它使用一个事件驱动设计来保持代码最小且易于阅读。所有这些因素促成了 Node 的理想目标即编写一个高度可伸缩的解决方案变得比较容易。

与理解 Node  什么同样重要的是理解它不是 什么。Node 并不只是 Apache 的一个替代品它旨在使 PHP Web 应用程序更容易伸缩。事实远非如此。尽管 Node 还处于初始阶段但它发展得非常迅速社区参与度非常高社区成员创建了大量优秀模块一年之内这个不断发展的产品就有可能出现在您的企业中。