Pro Node - Js para

Fazer download em pdf ou txt
Fazer download em pdf ou txt
Você está na página 1de 32

Colin J.

Ihrig

Pro Node.js para


Desenvolvedores
Tradução:
Angelo Giuseppe Meira Costa (angico)
 

   

 
    


 © 


   
       !"     © #      $
&  

' 
(  )    
  '   * 
    "  
)   '  
, ,   )    -  ) .    /    
 
)    0'
 "13
 

   0&,

 
   5 &,

  
  6  7


 
  ,  $& 8
9
  : ;
 & 
89
 6 <

5*
       )        
  '  &
   , 

)
)   
 


 )
   )  , )  

 

  
  
=13      ))  
 
 
 )
)
        

"
)
 
 
 
 )  > =
'
&@ 

) 13  
 
 
 "13A , 

)  1 ))
/
  ) 

*) $

 !"#$% 

 


  
@ < B $& C#

C  ) )13


DE> 
7!(BFGHHIFFII66001642


 ' " )
)  *+,-. 
 /*/-0 
 12)3425642
 716811265,,,19: 716811265,;3,

5 " "<")#)0


===)")#)02,96+
Sobre o Autor

Colin Ihrig tem feito experimentos com o JavaScript por prazer e por dinheiro
por mais de 15 anos. Atualmente, ele é engenheiro em tempo integral com o Node.
js, bem como escritor e evangelista do JavaScript, nas horas vagas. Colin recebeu
seu bacharelado em Engenharia e mestrado em Engenharia da Computação da
Universidade de Pittsburgh, em 2005 e 2008, respectivamente. Colin pode ser
alcançado através de sua página web pessoal, em http://www.cjihrig.com.
Sobre o Revisor Técnico
Andy Olsen é consultor/treinador freelance residente no Reino Unido, e tem
trabalhado em sistemas distribuídos há 20 anos. Andy começou a trabalhar em C, em
meados da década de 1980, mas pode muito bem ter sido em meados da década de
1880, pois parece há muito tempo. Andy migrou para o C++, para o Java, e para o
.NET conforme os tempos e as modas mudavam, e é atualmente mantido ocupado
(demais?) em sistemas baseados na web, tanto do lado cliente quanto do lado servidor.
Andy mora no litoral de Swansea e curte correr, cafeterias e observar os cisnes.
Agradecimentos
Eu gostaria de agradecer a todos os que ajudaram a tornar este livro possível.
Agradecimentos especiais a Mark Powers e Ewan Buckingham, da equipe editorial da
Apress. Também gostaria de agradecer ao revisor técnico, Andy Olsen, por seu valioso
feedback. É claro que muitos agradecimentos vão para meus amigos e minha família.
Introdução
Desde sua criação, em 2009, o Node.js evoluiu até a poderosa e crescentemente
popular estrutura de desenvolvimento assíncrono, usada para a criação de aplicativos
JavaScript altamente escalonáveis. Empresas respeitadas como a Dow Jones, a
LinkedIn e a Walmart estão entre as muitas organizações que têm visto o potencial
do Node e o tem adotado em seus negócios.

O Pro Node.js para Desenvolvedores oferece um guia abrangente para essa


excitante e jovem tecnologia. Você vai ser apresentado ao Node num nível alto, antes
de mergulhar profundamente nos conceitos chaves e APIs que são o lastro de sua
operação. Montando em cima de suas habilidades de JavaScript existentes, você vai
aprender a usar o Node.js para construir aplicativos baseados tanto em web quanto
em rede, para lidar com várias fontes de dados, capturar e gerar eventos, gerar e
controlar processos filhos e muito mais.

Depois que tiver dominado essas habilidades, você vai receber conhecimentos
mais avançados de engenharia de software, que vão dar ao seu código um nível
profissional. Você vai aprender a criar facilmente módulos de código reutilizáveis, a
depurar e testar seus aplicativos rápida e eficientemente e a escalonar seu código desde
um único segmento até a nuvem, conforme aumente a demanda pelo seu aplicativo.
Sumário

Capítulo 1
Começando ..........................................................................................1
O Modelo de Execução do Node ...................................................................... 2

Instalando o Node ........................................................................................... 3


Instalando Através de Gerenciadores de Pacotes ......................................................4
Construindo a Partir do Fonte ................................................................................4
Passos Finais da Instalação ......................................................................................5

O Laço Ler-Avaliar-Imprimir.............................................................................. 6
Funcionalidades do REPL ......................................................................................7
Comandos do REPL...............................................................................................7

Executando Programas Node ......................................................................... 10

Resumo ......................................................................................................... 10

Capítulo 2
O Sistema de Módulos de Node ........................................................11
Instalando Pacotes......................................................................................... 11
Instalando de URLs ..............................................................................................13
Localizações de Pacotes .........................................................................................14
Pacotes Globais.....................................................................................................14
Ligando Pacotes ....................................................................................................15
Removendo Ligações de Pacotes ...........................................................................15
Atualizando Pacotes ..............................................................................................16
Desinstalando Pacotes...........................................................................................16

A função require() .......................................................................................... 16


XII JPro Node.js para Desenvolvedores 

Módulos Centrais .................................................................................................17


Módulos de Arquivos............................................................................................17
Processamento de Extensões de Arquivo ...............................................................18
Resolvendo a Localização de um Módulo .............................................................19
Cacheamento de Módulos ....................................................................................20

O arquivo package.json ................................................................................. 20


Descrição e Palavras-Chave ...................................................................................21
Autor e Contribuintes ..........................................................................................22
O Ponto de Entrada Principal ...............................................................................22
O Ajuste preferGlobal ..........................................................................................23
Dependências .......................................................................................................23
Dependências de Desenvolvimento ......................................................................24
Dependências Opcionais ......................................................................................24
Engines.................................................................................................................25
Scripts ..................................................................................................................25
Campos Adicionais ...............................................................................................26
Gerando um Arquivo package.json .......................................................................27

Um exemplo completo ................................................................................... 29

Autoria de Módulos ....................................................................................... 31


O Objeto module .................................................................................................31
Publicando no npm ..............................................................................................33

Resumo ......................................................................................................... 33

Capítulo 3
O Modelo de Programação do Node .................................................35
Programação Assíncrona................................................................................ 36
O Inferno da Rechamada......................................................................................37

Tratamento de Exceções................................................................................. 39
Domínios ............................................................................................................41
Conexão Explícita ................................................................................................42

O módulo async............................................................................................. 44
Executando em Série ............................................................................................44
Tratando Erros......................................................................................................47
Execução em Paralelo............................................................................................48
Limitando o Paralelismo .......................................................................................49
O Modelo Cascata ................................................................................................50
Sumário JXIII

O Modelo de Fila .................................................................................................51


Métodos e Propriedades Adicionais de Filas ..........................................................52
Métodos de Repetição ..........................................................................................53
Variações de Repetição .........................................................................................53
Funcionalidades Adicionais de async.....................................................................54

Resumo ......................................................................................................... 54

Capítulo 4
Eventos e Temporizadores .................................................................55
Emissores de Eventos ........................................................................55
Escutando Eventos ...............................................................................................56
Escutadores de Eventos de Instante .......................................................................57
Inspecionando Escutadores de Eventos .................................................................57
O evento newListener ...........................................................................................59
Removendo Tratadores de Eventos ........................................................................60
Detectando Potenciais Vazamentos de Memória ...................................................61
Herdando de Emissores de Eventos.......................................................................61
Usando Eventos para Evitar o Inferno da Rechamada ...........................................63

Temporizadores e Agendamento.................................................................... 65
Intervalos..............................................................................................................65
Os Métodos ref() e unref() ....................................................................................66
Imediatas ..............................................................................................................66
Dividindo Tarefas de Execução Demorada ............................................................67
Agendamento com process.nextTick() ..................................................................68
Implementando Funções Assíncronas de Rechamada ............................................69
Mantendo Comportamento Consistente ..............................................................70

Resumo ......................................................................................................... 72

Capítulo 5
A Interface de Linha de Comandos ...................................................73
Argumentos de Linha de Comandos .............................................................. 73
Processando Valores de Argumentos .....................................................................74
Argumentos de Linha de Comandos no Commander ...........................................76
Ajuda Gerada Automaticamente ...........................................................................77
XIV JPro Node.js para Desenvolvedores 

Os Fluxos Padrões.......................................................................................... 78
A Entrada Padrão .................................................................................................78
A Saída Padrão .....................................................................................................82
Outras Funções de Impressão ...............................................................................85
O Erro Padrão ......................................................................................................88
A Interface TTY ...................................................................................................90
Determinando o Tamanho do Terminal ................................................................91
Eventos de Sinais ..................................................................................................92
Variáveis Ambientais do Usuário...........................................................................93

Resumo ......................................................................................................... 94

Capítulo 6
O sistema de arquivos .......................................................................95
Caminhos Relevantes..................................................................................... 95
O Diretório Atual de Trabalho..............................................................................96
Mudando o Diretório Atual de Trabalho...............................................................96
Localizando o Executável Node .....................................................................................97

O Módulo path ........................................................................................................... 97


Diferenças Entre Plataformas ................................................................................97
Extraindo Componentes do Caminho ..................................................................99
Normalização de Caminhos ................................................................................100
Resolvendo um Caminho Relativo entre Diretórios ............................................101

O módulo fs .............................................................................................................. 101


Determinando se um Arquivo Existe ..................................................................102
Recuperando Estatísticas de Arquivos .................................................................102
Outras Variações de stat() .......................................................................................105
Abrindo Arquivos ...............................................................................................105
Lendo Dados de Arquivos ..................................................................................106
Os Métodos  e 
 ..........................................................107
Escrevendo Dados Em Arquivos .........................................................................108
Os Métodos  e 
 .....................................................109
Fechando Arquivos .............................................................................................109
Renomeando Arquivos .......................................................................................110
Excluindo Arquivos ............................................................................................111
Criando Diretórios .............................................................................................111
Lendo o Conteúdo de um Diretório ...................................................................112
Removendo Diretórios .......................................................................................112
Vigiando Arquivos ..............................................................................................115

Resumo ....................................................................................................... 116


Sumário JXV

Capítulo 7
Fluxos ..............................................................................................117
Que são Fluxos?........................................................................................... 117

Trabalhando com Fluxos .............................................................................. 117

Fluxos de Leitura ......................................................................................... 118


Eventos data .................................................................................................................118
O Evento   ................................................................................................................118
O Evento 
 ...........................................................................................................119
Eventos error ..............................................................................................................120
Controlando Fluxos de Leitura ...........................................................................120
Fluxos de Escrita.................................................................................................120
O Método write() .....................................................................................................120
O Método   ..........................................................................................................121
O Evento  ...........................................................................................................122
O Evento  
 ...........................................................................................................122
Os Eventos 
 e error ........................................................................................122
Um Exemplo de Fluxo de Escrita........................................................................122

Pipes ........................................................................................................... 123


O Método pipe() .......................................................................................................124
De Volta ao Exemplo do Fluxo de Escrita ...........................................................125

Fluxos de Arquivos ...................................................................................... 125


 ....................................................................................126
O Evento  de  ...............................................................................127
O Argumento 
...............................................................................................128
 ..................................................................................129
O Evento  de  .............................................................................130
A Propriedade  
 ...................................................................................131

Compressão usando o Módulo  ..................................................................... 131


Deflate/Inflate e DeflateRaw/InflateRaw.............................................................133
Métodos de Conveniência ..................................................................................133

Resumo ....................................................................................................... 134


XVI JPro Node.js para Desenvolvedores 

Capítulo 8
Dados binários.................................................................................135
Visão Geral de Dados Binários ..................................................................... 135
Terminação.........................................................................................................137
Determinando a Terminação ..............................................................................138
A Especificação de Matriz Tipificada...................................................................138
Arraybuffers ........................................................................................................139
Vistas de a  ....................................................................................142
Observação Sobre Dimensionamento de Vistas...................................................145
Informação do Construtor ..................................................................................145
Criando uma Vista Vazia ....................................................................................146
Criando uma Vista a Partir de Valores de Dados .................................................146
Criando uma Vista a Partir de Outra ..................................................................146
Propriedades das Vistas .......................................................................................147
Os Buffers de Node ............................................................................................150
O Construtor de  ...................................................................................151
Métodos de Transformação em String .................................................................152
Escrevendo Dados Numéricos ............................................................................155
Lendo Dados Numéricos ....................................................................................156
Compatibilidade com Matrizes Tipificadas .........................................................158

Resumo ....................................................................................................... 159

Capítulo 9
Executando código ..........................................................................161
O módulo  

.................................................................................161
  .................................................................................................................161
  ........................................................................................................163

  ...............................................................................................................165
A Opção stdio .................................................................................................166
A Classe   

.......................................................................... 167
O Evento error ...................................................................................... 168
O Evento exit ........................................................................................ 168
O Evento 
 ...................................................................................... 169
A Propriedade pid.................................................................................... 169
! ....................................................................................................... 169
fork() ....................................................................................................... 170

  ....................................................................................................... 171

   ........................................................................................... 173
Sumário JXVII

O Módulo " ....................................................................................................173


 # $
  ............................................................................... 174
 # %  ................................................................................. 176
 #   ....................................................................................... 178
  ....................................................................................... 179

Resumo ....................................................................................................... 180

Capítulo 10
Programação para Redes .................................................................181
Soquetes ..................................................................................................... 181

Programação Cliente-Servidor...................................................................... 183

O Protocolo de Controle de Transmissão ...................................................... 184


Criando um Servidor TCP .................................................................................185
Escutando Conexões...........................................................................................185
address() .............................................................................................................187
Variações de 
  .....................................................................................187
Tratando Conexões .............................................................................................189
Encerrando o Servidor ........................................................................................189
ref()e unref() .......................................................................................................190
Eventos error ...................................................................................................190
Criando um Cliente TCP ...................................................................................191
A Classe & !.............................................................................. 193
Endereços Locais e Remotos ...............................................................................194
Fechando um Soquete ........................................................................................194
Expiração............................................................................................................195
Soquetes, Servidores e Processos Filhos ...............................................................196

O Protocolo de Datagrama de Usuário ......................................................... 197


Criando Soquetes UDP ......................................................................................197
Ligando-se a uma Porta ......................................................................................198
Recebendo Dados ...............................................................................................198
Enviando Dados .................................................................................................199

O Sistema de Nomes de Domínio................................................................. 200


Fazendo Buscas ...................................................................................................200

" .......................................................................................................201
Buscas Inversas ...................................................................................................203
Detectando um Endereço IP Válido....................................................................203

Resumo ....................................................................................................... 204


XVIII JPro Node.js para Desenvolvedores 

Capítulo 11
HTTP ................................................................................................205
Um Servidor Básico...................................................................................... 205

Anatomia de uma requisição HTTP .............................................................. 206


Métodos de Requisição .......................................................................................207
Cabeçalhos de Requisição ...................................................................................208
Códigos de Resposta ...........................................................................................209
Cabeçalhos de Resposta ......................................................................................211

Trabalhando com cookies ............................................................................ 214

Middleware ................................................................................................. 216

Connect ....................................................................................................... 217

Emitindo requisições HTTP ........................................................................... 219


Dados de Formulários ........................................................................................222
Objetos Aninhados .............................................................................................224
O módulo '
 ..........................................................................................225
Cookies em '
 ........................................................................................227

HTTPS .......................................................................................................... 228

Resumo ....................................................................................................... 231

Capítulo 12
A estrutura Express..........................................................................233
Rotas do Express ......................................................................................... 233
Parâmetros de Rota .............................................................................................235

Criando um Aplicativo Express ..................................................................... 237


Examinando o Aplicativo Esqueleto....................................................................238

Gabaritagem ............................................................................................... 242

O Express-Validator .................................................................................... 244


REST ............................................................................................................ 246
Sumário JXIX

Uma API RESTful de Exemplo ..........................................................................246


Testando a API ...................................................................................................250

Resumo ....................................................................................................... 252

Capítulo 13
A Web em Tempo Real .....................................................................253
A API de WebSockets ................................................................................... 254
Abrindo um WebSocket .....................................................................................254
Fechando WebSockets ........................................................................................255
Verificando o Estado de um WebSocket..............................................................256
O evento  ...................................................................................................257
O evento 

* ............................................................................................257
O evento 
.................................................................................................258
O evento error.................................................................................................258
Enviando Dados .................................................................................................259

WebSockets no Node ................................................................................... 259


Um cliente de WebSockets .................................................................................260
Um cliente HTML .............................................................................................261
Examinando a Conexão WebSocket....................................................................263

Socket.IO ..................................................................................................... 263


Criando um Servidor  !&#+ .....................................................................264
Criando um Cliente  !&#+.......................................................................265
 !&#+ e Express ........................................................................................266

Resumo ....................................................................................................... 266

Capítulo 14
Bases de dados ................................................................................267
Bases de Dados Relacionais ......................................................................... 267

O MySQL ..................................................................................................... 270


Conectando-se ao MySQL .................................................................................270
Agrupamento de Conexões .................................................................................271
Fechando uma Conexão .....................................................................................273
Executando Consultas ........................................................................................274
XX JPro Node.js para Desenvolvedores 

Bases de Dados NoSQL ................................................................................ 276


O MongoDB ......................................................................................................277
Conectando-se com o MongoDB .......................................................................277
Esquemas ...........................................................................................................278
Modelos .............................................................................................................279
Inserindo Dados .................................................................................................280
Consultando Dados ............................................................................................281
Métodos Construtores de Consultas ...................................................................282
Atualizando Dados .............................................................................................284
Excluindo Dados ................................................................................................285
Resumo ....................................................................................................... 286

Capítulo 15
Registrando, Depurando e Testando ...............................................287
Registrando ................................................................................................. 287
O Módulo 
 ..........................................................................................288
Transportes .........................................................................................................289
Criando Novos Registradores..............................................................................291

Depurando .................................................................................................. 292


O módulo ,
  ...........................................................................294

Testando...................................................................................................... 296
O Módulo assert ............................................................................................296
O Método throws()........................................................................................298
O Método 
%$ ...........................................................................299
O Método ifError() ......................................................................................300
A Estrutura de Testes Mocha ..............................................................................300
Rodando o Mocha ..............................................................................................300
Criando Testes ....................................................................................................301
Criando Suítes de Testes .....................................................................................301
Testando Código Assíncrono ..............................................................................302
Definindo uma Falha ..........................................................................................302
Ganchos de Testes...............................................................................................303
Desativando Testes..............................................................................................305
Rodando uma única Suíte de Testes ....................................................................305
Resumo ....................................................................................................... 306
Sumário JXXI

Capítulo 16
Escalonamento de aplicativos .........................................................307
O Módulo 
 ..........................................................................................308
O Método fork() ............................................................................................309
Mudando o Comportamento Omissivo de fork() ...........................................310
O Método 
   ............................................................................311
O Objeto workers ..........................................................................................313
A Classe ! ..............................................................................................314

Escalonando entre Máquinas ....................................................................... 315


O , .................................................................................................315
O nginx ....................................................................................................... 317

Escalonando na Nuvem ............................................................................... 321


A Nodejitsu ........................................................................................................321
A Heroku ...........................................................................................................323
Resumo ....................................................................................................... 324

Apêndice A
A Notação de Objeto JavaScript ......................................................325
Tipos de Dados Suportados ......................................................................... 325
Números ...........................................................................................................326
Strings ................................................................................................................326
Booleanos ...........................................................................................................327
Matrizes..............................................................................................................327
Objetos...............................................................................................................327
null.....................................................................................................................328
Tipos de Dados não Suportados .........................................................................328

Funções para o Trabalho com JSON.............................................................. 328


JSON.stringify() .................................................................................................328
O Método -+% ........................................................................................328
O Argumento  ...................................................................................329
A Forma de Matriz de   ......................................................................331
O Argumento
  .........................................................................................331

JSON.parse() ................................................................................................ 332


O Argumento reviver().................................................................................333
Resumo ....................................................................................................... 334

Índice ...............................................................................................335
CAPÍTULO 1

Começando
O JavaScript foi chamado, inicialmente, de Mocha, quando foi desenvolvido na
Netscape, em 1995, por Brendan Eich. Em setembro de 1995, liberações beta do
Netscape Navigator 2.0 saíram com o Mocha, que foi rebatizado como LiveScript.
Por volta de dezembro de 1995, o LiveScript, depois de ser novamente rebatizado,
tornou-se o JavaScript, seu nome atual. Ainda por esse tempo, a Netscape estava
trabalhando com a Sun, a empresa responsável pela criação da linguagem de
programação Java. A escolha do nome JavaScript causou muita especulação. Muitas
pessoas pensaram que a Netscape estava tentando pegar carona no nome Java, uma
palavra quente, na época. Infelizmente, a escolha do nome causou muita confusão, já
que muitos supuseram que as duas linguagens estavam de alguma forma relacionadas.
Na realidade, elas tinham muito pouco em comum.

A despeito da confusão, o JavaScript se tornou uma linguagem de script do lado


cliente de muito sucesso. Em resposta ao sucesso do JavaScript, a Microsoft criou
sua própria implementação chamada JScript e a liberou com o Internet Explorer 3.0
em agosto de 1996. Em novembro de 1996, a Netscape submeteu o JavaScript para
padronização pela Ecma International, uma organização internacional de padrões.
Em junho de 1997, o JavaScript se tornou o padrão ECMA-262.

Ao longo dos anos, o JavaScript permaneceu o verdadeiro padrão para


desenvolvimento do lado cliente. No entanto, no espaço do servidor, a história foi
completamente diferente. Em sua maior parte, o âmbito do servidor pertencia a
linguagens como o PHP e o Java. Uma série de projetos implementou o JavaScript
como linguagem de servidor, mas nenhum deles teve sucesso, em particular. Dois
obstáculos principais impediram a ampla adoção do JavaScript no servidor. O primeiro
foi a reputação do JavaScript que era muito visto como linguagem de brincadeira,
conveniente apenas para amadores. O segundo foi o precário desempenho do
JavaScript, em comparação com o de algumas outras linguagens.

Contudo, o JavaScript tinha um grande trunfo em seu favor. A Web estava


passando por um crescimento sem precedentes e a guerra dos navegadores estava se
acirrando. Como única linguagem suportada por todos os principais navegadores, os
engenhos de JavaScript começaram a receber a atenção do Google, da Apple e de outras
empresas. Toda aquela atenção levou a melhoramentos imensos no desempenho do
JavaScript . De repente, o JavaScript não era mais o retardatário.
2 JPro Node.js para Desenvolvedores 

A comunidade de desenvolvimento percebeu o recente poder do JavaScript


e começou a criar aplicações interessantes. Em 2009, Ryan Dahl criou o Node.js,
uma estrutura primariamente usada para criar servidores altamente escalonáveis para
aplicações web. O Node.js, ou simplesmente Node, é escrito em C++ e em JavaScript.
Para impulsionar o Node, Dahl conectou a força do motor V8 de JavaScript do Google
(V8 é o engenho dentro do Google Chrome, o navegador mais popular existente).
Usando o V8, os desenvolvedores podem escrever aplicativos completamente maduros
– aplicativos que normalmente seriam escritos numa linguagem como o C ou o Java.
Assim, com a invenção do Node, o JavaScript enfim se tornou uma linguagem de
confiança do lado servidor.

O Modelo de Execução do Node


Além da velocidade, o Node apresenta um modelo de execução não convencional.
Para entender como o Node é diferente, devemos compará-lo com o Apache, o popular
servidor web da pilha de software Linux, Apache, MySQL e PHP (LAMP). Primeiro,
o Apache processa apenas requisições HTTP, deixando que a lógica do aplicativo
seja implementada numa linguagem tal como o PHP ou o Java. O Node remove
uma camada da complexidade, combinando a lógica do servidor e do aplicativo num
só lugar. Alguns desenvolvedores criticaram esse modelo, por eliminar a tradicional
separação de foco empregada na pilha LAMP. Porém, essa abordagem também enseja
ao Node uma flexibilidade sem precedentes como servidor.

O Node também difere de muitos outros servidores no uso de concorrência.


Um servidor como o Apache mantém um grupo de segmentos para tratamento de
conexões de clientes. Essa abordagem carece de escalabilidade, porque segmentos
são bastante intensivos no uso de recursos. Além disso, um servidor ocupado,
rapidamente consome todos os segmentos disponíveis; como resultado, mais
segmentos, que são dispendiosos para se criar e eliminar, são iniciados. O Node, por
outro lado, é executado num único segmento. Embora isso possa parecer uma má
ideia, na prática, funciona bem, por causa da maneira como a maioria dos aplicativos
de servidor funciona. Normalmente, um servidor recebe a requisição de um cliente, e
depois realiza alguma operação de E/S de alta latência, como a leitura de um arquivo
ou uma consulta à base de dados. Durante esse período, o servidor fica bloqueado,
esperando que a operação de E/S seja completada. Em vez de ficar desocupado, o
servidor poderia estar tratando mais requisições ou fazendo outra tarefa útil.

Em servidores tradicionais, é aceitável que um segmento não faça nada durante


o bloqueio de uma operação de E/S. Entretanto, o Node só tem um segmento, e
bloqueá-lo faz com que todo o servidor pare. Para minorar este problema, o Node usa
quase que exclusivamente E/S sem bloqueio. Por exemplo, se o Node precisar realizar
uma consulta a uma base de dados, ele simplesmente emite a consulta e passa a
processar alguma outra coisa. Quando a consulta finalmente retorna, ela dispara uma
função de rechamada assíncrona que é responsável por processar o resultado dessa
consulta. Um exemplo desse processo em pseudocódigo é mostrado na listagem 1-1.
Capítulo 1 - Começando J3

Listagem 1-1. Exemplo em pseudocódigo de consulta não bloqueadora a uma base


de dados
".
'./.0121$.3.+4.56.


&' 
'7.  

.8.
::. 

..

; 6.
::..*.. 
7.."..


O modelo de execução assíncrono e não bloqueador do Node oferece soluções de


servidor extremamente escalonáveis, com o mínimo de sobrecarga. Muitas empresas
importantes, incluindo a Microsoft, o LinkedIn, o Yahoo! e a gigante de vendas
Walmart, tomaram conhecimento do Node e começaram a implementar projetos
com ele. Por exemplo, o LinkedIn migrou toda sua pilha móvel para o Node e “passou
de 15 servidores rodando com 15 instâncias (servidores virtuais) em cada máquina
física, para apenas quatro instâncias que podem tratar o dobro do tráfego”. O Node
também recebeu significativo reconhecimento da mídia, tal como a conquista do
Prêmio de Tecnologia do Ano 2012, da InfoWorld.

Instalando o Node
O primeiro passo para começar com o Node é a instalação. Esta seção vai ajudar
você a aprontar o Node em sua máquina Ubuntu, OS X ou Windows. A maneira
mais simples de instalar o Node é através do botão Install (instalar) na página base do
Node, <:: =
&*, mostrada na figura 1-1. Isso vai baixar os binários ou
o instalador apropriado para seu sistema operacional.

Figura 1-1. Instalando o Node a partir da página base do projeto


4 JPro Node.js para Desenvolvedores 

Você também pode navegar pelos binários, instaladores e pelo código fonte de
todas as plataformas em <:: =
&*: . Usuários do Windows
muito provavelmente vão querer baixar o Windows Installer (arquivo &
),
enquanto os usuários do Mac devem optar pelo Mac OS X Installer (arquivo &!*).
Usuários do Linux e do SunOS podem baixar binários, mas provavelmente é mais
simples usar um gerenciador de pacotes.

Instalando Através de Gerenciadores de Pacotes


Para instruções sobre a instalação do Node através do gerenciador de pacotes do
seu sistema operacional, vá para a página https://github.com/joyent/node/wiki/Installing-
Node.js-via-package-manager. Essa página contém instruções para o Windows, o OS X e
o Linux. Mais uma vez, os usuários do Windows e do Mac devem usar os instaladores
discutidos anteriormente. No que diz respeito ao Linux, há instruções disponíveis
para Gentoo, Debian, Linux Mint, Ubuntu, openSUSE, SLE, Red Hat, Fedora,
Arch Linux, FreeBSD e OpenBSD.

Usuários do Ubuntu podem instalar o Node e todo o software necessário usando


os comandos do Advanced Packaging Tool (APT) mostrados na listagem 1-2. Esses
passos também instalam o npm, o software de gerenciamento de pacotes do Node
(visto no capítulo 2).

Listagem 1-2. Instalando o Node com o gerenciador de pacotes do Ubuntu.


>.
.,*.
.  ,
,
.  .*??.!.
>.
.,,
 .< 
,: &=
.
>.
.,*..
>.
.,*.
. =
. .

Se o comando ,,
 falhar, instale o pacote
,

,  usando o comando mostrado na listagem 1-3.

Listagem 1-3. Instalando o pacote


,
, 
>.
.,*.
.
,
,  .

Construindo a Partir do Fonte


Se você quiser contribuir com o núcleo C++ do Node, ou simplesmente
experimentar sua funcionalidade, vai precisar compilar o código fonte do projeto.
Você pode obter esse código fonte a partir da página de download ou do repositório
do projeto no GitHub, 
<::*& :=  : . Uma vez que o
código tenha sido baixado, extraia-o do arquivo, se for o caso. Antes de construir
o Node, usuários do Ubuntu precisam instalar o Python e outras ferramentas de
construção; use o comando mostrado na listagem 1-4. Quando da instalação do
Python, certifique-se de instalar a versão 2.7, não a mais nova, Python 3.
Capítulo 1 - Começando J5

Listagem 1-4. Instalando pacotes de software de pré-requisito, no Ubuntu


>.
.,*.
.  ,
,
.  .*??.!.

Usuários do Ubuntu e do OS X podem construir o Node emitindo os comandos


mostrados na listagem 1-5, a partir do diretório do código fonte. Note que o caminho
completo para o diretório do código fonte não deve conter nenhum espaço.

Listagem 1-5. Instalando o Node a partir do fonte no Ubuntu e no OS X


&:  *.
!.

.!.
.

No Windows, você precisa instalar o Visual C++ e o Python 2.7 para construir
o Node. O Visual C++ pode ser baixado gratuitamente da Microsoft com o Visual
Studio Express. O Python também está disponível de graça, em &  &*:.
Para compilar o Node, emita o comando mostrado na listagem 1-6.

Listagem 1-6. Instalando o Node a partir do fonte no Windows


@." &.
.

Passos Finais da Instalação


A despeito da rota de instalação de sua escolha, a esta altura o Node já deve estar
pronto para o uso. Para verificar se tudo está corretamente configurado, abra uma
nova janela de terminal e rode o executável  (veja a listagem 1-7). O sinalizador
," faz com que o Node apresente a versão instalada e depois termine. Neste exemplo,
a versão 0.10.18 do Node está instalada.

Listagem 1-7. Verificando a versão do Node a partir da linha de comandos


>. .,".
"A&BA&BC.

Você também deve verificar se o  está instalado (veja a listagem 1-8).

Listagem 1-8. Verificando a versão do  a partir da linha de comandos


>. .,".
B&D&C.

Uma última nota a respeito da instalação: é provável que você precise instalar
o Python e um compilador C++ em sua máquina, mesmo que não tenha instalado
o Node a partir do fonte. Fazer isso assegura que módulos nativos escritos em C++
podem ser compilados e executados com sua instalação do Node. No Windows, isso
envolve a instalação do compilador Visual C++ da Microsoft (veja a seção anterior,
“Construindo a partir do fonte”). Para qualquer outro sistema operacional, a base da
construção deve incluir o compilador necessário.
6 JPro Node.js para Desenvolvedores 

O Laço Ler-Avaliar-Imprimir
O Node oferece um shell interativo, conhecido como laço Ler-Avaliar-Imprimir,
ou REPL (da sigla em inglês, Read-Eval-Print-Loop). O REPL lê entrada do usuário,
avalia essa entrada como código JavaScript, imprime o resultado e depois espera por
mais entradas. O REPL é útil para depuração e para experimentação de pequenos
fragmentos de código JavaScript. Para iniciar o REPL, inicie o Node sem nenhum
argumento de linha de comando. Daí, você vê o prompt de comandos do REPL, o
caractere >. A partir do prompt, comece a entrar código JavaScript arbitrário.

A listagem 1-9 mostra como iniciar o REPL e entrar código. Neste exemplo,
uma variável chamada foo é criada com o valor string “+G7. H”. Na terceira
linha o REPL imprime “  ”, porque a sentença de declaração da variável
não retorna nenhum valor. Em seguida, a sentença 6 faz com que o valor de foo
seja inspecionado. Como era de se esperar, o REPL retorna a string “+G7. H”.
Por fim, o valor de foo é impresso no terminal usando-se a função 
&
* . Depois de foo ser impresso, o REPL exibe novamente “  ”, porque

&* não retorna nenhum valor.

Listagem 1-9. Iniciando o REPL e entrando código JavaScript


>. .
@."../.0+G7. H56
  .
@.6.
I+G7. HJ.
@. 
&* 6.
+G7. H.
  .

Você também pode inserir expressões multilinhas no REPL. Por exemplo, um


laço for introduzido no REPL na listagem 1-10. As reticências (&&&) são usadas
pelo REPL para indicar uma expressão multilinhas em andamento. Note que &&& são
exibidas pelo REPL e não digitadas pelo usuário.

Listagem 1-10. Um exemplo de execução de uma expressão multilinhas no REPL


@.."../.A6..K.D6.?? .8.
&&&. 
&* 6.
&&&.;.
0
B.
2
  .
Capítulo 1 - Começando J7

Funcionalidades do REPL
O REPL tem uma série de funcionalidades que aumenta a usabilidade, das quais a
mais útil é a capacidade de se navegar pelos comandos previamente emitidos, usando-
se as teclas de setas para cima e para baixo. Para finalizar qualquer comando e voltar
ao prompt em branco, digite  ?. Pressionar  ? duas vezes a partir
de uma linha em branco faz com que o REPL seja encerrado. Você pode sair do
REPL a qualquer momento, pressionando  ?O. Você pode usar a tecla $
para ver uma lista de possíveis completamentos para o comando atual. Se só houver
uma opção possível, o Node a insere automaticamente. A lista inclui palavras-chave,
funções e variáveis. Por exemplo, a listagem 1-11 mostra as opções de completamento
quando um t é introduzido no prompt.

Listagem 1-11. Opções de autocompletamento mostradas pela digitação de um t


seguido de um $.
> t

.. . . . . . 
 ... 
. .  . . 2  *
 *.

O REPL também oferece uma variável especial,  (sublinha), que sempre contém
o resultado da última expressão. A listagem 1-12 mostra vários exemplos de uso de
. Primeiro, uma matriz de strings é criada, fazendo com que  referencie a matriz.
O método pop() é então usado para remover o último elemento da matriz baz. Por
fim, o comprimento de baz é acessado, fazendo com que  se torne D.

Listagem 1-12. Exemplos de uso da variável 


@.P057.057.05Q.
P.IJ7.IJ7.IJ.Q.
@.& 6.
IJ.
@.& *.
D.
@..
D.

Comandos do REPL
.help
O comando & exibe todos os comandos disponíveis no REPL. A listagem
1-13 mostra a saída da execução do comando &.

Listagem 1-13. Saída do comando & do REPL


@.&.
&!.
. .*.
 !7.
.*
. ..
8 JPro Node.js para Desenvolvedores 

& .R
..&!.
&.1...
&...
.
&.2.-.... ..1 2.


 .
&
"."..".  
. .
.1 2.


 ....

.exit
O comando & termina o REPL. Este comando é equivalente ao
pressionamento de  ?O.

.break
O comando &!, usado para abortar uma expressão multilinhas, é útil se você
cometer um erro ou simplesmente optar por não completar a expressão. A listagem
1-14 mostra um exemplo de uso do comando &! para terminar um laço for
antes de completá-lo. Note que o prompt normal > é mostrado após o comando
&!.

Listagem 1-14. Terminando uma expressão multilinhas usando o comando


&!

@.."../.A6..K.BA6.?? .8.
&&&.&!.
>

.save nome_do_arquivo
O comando &
" salva a sessão atual do REPL no arquivo especificado em
'". Se o arquivo não existir, ele é criado. Se ele existir, ele é
sobreposto. Os comandos do REPL e as saídas não são salvos. A listagem 1-15 mostra
um exemplo de uso do comando &
". Nesse exemplo, a sessão atual é salva no
arquivo ,
&=
. O conteúdo resultante de ,
&=
é mostrado na
listagem 1-16. Note que o arquivo não contém o prompt do REPL, nem saídas, nem
o comando &
".

Listagem 1-15. Salvando a sessão atual do REPL usando o comando &


"
@."../.PB7.S7.DQ6.
  .
@.&1   " .8.
&&&. 
&*" 6.
&&&.; 6.
B.
2
D.
  .
Capítulo 1 - Começando J9

@.&
".,
&=
.


 .
".<,
&=
.

Listagem 1-16. O conteúdo de ,


&=
gerado pelo comando &
"
"../.PB7.S7.DQ6.
&1   " .8.

&*" 6.
; 6.

.load nome_do_arquivo
O comando & executa o arquivo JavaScript especificado em 
'". O arquivo é executado como se cada linha fosse digitada diretamente no
REPL. A listagem 1-17 mostra a saída do carregamento do arquivo ,
&=

da listagem 1-16.

Listagem 1-17. O resultado da execução de ,


&=
, usando-se o comando
&
@.&.,
&=
.
@."../.PB7.S7.DQ6.
  .
@.&1   " .8.
&&&. 
&*" 6.
&&&.; 6.
B.
2
D.
  .

.clear
Similar a &!, &  pode ser usado para encerrar expressões multilinhas.
&  também é usado para reiniciar o objeto de contexto do REPL. Neste
momento, você não precisa entender os detalhes, mas a listagem 1-18 mostra um
programa Node que incorpora um REPL. Em outras palavras, ao rodar esse programa,
invoca-se, na verdade, uma instância do REPL. Além disso, você pode definir um
ambiente de execução personalizado para o REPL. Nesse caso, o REPL incorporado
tem uma variável definida, foo, que guarda a string “+G7.1 2”. Chamar & 
de dentro do REPL incorporado reseta o contexto e exclui foo.

Listagem 1-18. Embutindo um REPL dentro de outro programa Node


"../.'05 6.

&
8; &  &./.0+G7.1 256.
10 JPro Node.js para Desenvolvedores 

Executando Programas Node


Embora o ambiente REPL seja útil, ele raramente é usado em sistemas de produção.
Em vez disso, os programas são escritos como um ou mais arquivos JavaScript e depois
interpretados pelo Node. O programa Node mais simples é mostrado na listagem
1-19. O exemplo simplesmente imprime a string “+G7. H” no console.

Listagem 1-19. Código fonte para o programa Node Olá, mundo!



&*T+G7. HU 6.

Copie o código da listagem 1-19 para um novo arquivo e salve-o como ola.js. Em
seguida, abra uma janela de terminal e execute-o (veja a listagem 1-20). Note que o
Node não exige que você especifique a extensão .js. Se o arquivo de entrada não for
encontrado e nenhuma extensão for fornecida, o Node tenta adicionar as extensões .js,
.json, e .node. O Node interpreta arquivos .js como código fonte JavaScript e arquivos
com extensão .json como arquivos de Notação de Objeto JavaScript (JSON, na sigla
em inglês). Arquivos com extensão .node são tratados como módulos complementares
compilados.

Listagem 1-20. Executando um programa Node a partir da linha de comandos


>. .&=
.

J Nota O JSON é um texto plano padrão para intercâmbio de dados. Este livro
considera que o leitor está familiarizado com o JSON. No entanto, se você precisar de
uma introdução ou de uma revisão, o JSON é abordado no apêndice A.

Resumo
Parabéns! Você deu os primeiros passos em direção ao desenvolvimento de
aplicativos Node. Esse capítulo ofereceu uma introdução de alto nível do Node, e
guiou você pelo processo de instalação. Você até escreveu algum código Node usando
o REPL. O resto deste livro se ergue sobre esse capítulo, cobrindo os aspectos mais
importantes do desenvolvimento em Node. O Node é melhor conhecido pela criação
de servidores web escalonáveis. Então, é claro que essa funcionalidade é abordada.
Porém, você também vai aprender muito mais, incluindo a programação para sistema
de arquivos, o fluxo de dados, o escalonamento de aplicativos e o sistema de módulos
do Node.

Você também pode gostar