diff options
Diffstat (limited to 'files/pt-br/learn/common_questions/what_is_a_web_server')
-rw-r--r-- | files/pt-br/learn/common_questions/what_is_a_web_server/index.html | 121 |
1 files changed, 121 insertions, 0 deletions
diff --git a/files/pt-br/learn/common_questions/what_is_a_web_server/index.html b/files/pt-br/learn/common_questions/what_is_a_web_server/index.html new file mode 100644 index 0000000000..f963103480 --- /dev/null +++ b/files/pt-br/learn/common_questions/what_is_a_web_server/index.html @@ -0,0 +1,121 @@ +--- +title: O que é um servidor web (web server)? +slug: Learn/Common_questions/o_que_e_um_web_server +tags: + - HTTP + - Infraestrutura + - Iniciante + - servidor web +translation_of: Learn/Common_questions/What_is_a_web_server +--- +<div class="summary"> +<p>Neste artigo vamos revisar o que são web servers, como eles funcionam, e por que eles são importantes.</p> +</div> + +<table class="learn-box standard-table"> + <tbody> + <tr> + <th scope="row">Pré-requisitos:</th> + <td>Você deve saber <a href="/pt-BR/docs/Learn/Common_questions/Como_a_internet_funciona">como a Internet funciona</a> e <a href="https://developer.mozilla.org/pt-BR/docs/Learn/Common_questions/Pages_sites_servers_and_search_engines">entender a diferença entre uma página web, um site, um servidor web e um mecanismo de busca</a>.</td> + </tr> + <tr> + <th scope="row">Objetivo:</th> + <td>Você irá aprender o que é um servidor web e compreender de modo geral como ele funciona.</td> + </tr> + </tbody> +</table> + +<h2 id="Sumário">Sumário</h2> + +<p>"Servidor web (<em>web server</em>)" pode referir ao hardware ou ao software, ou ambos trabalhando juntos.</p> + +<ol> + <li>Referente ao hardware, um servidor web é um computador que armazena arquivos que compõem os sites (por exemplo, documentos HTML, imagens, folhas de estilo, e arquivos JavaScript) e os entrega para o dispositivo do usuário final. Está conectado a Internet e pode ser acessado através do seu nome de domínio (DNS), como por exemplo <code>mozilla.org</code>.</li> + <li>Referente ao software, um servidor web inclui diversos componentes que controlam como os usuários acessam os arquivos hospedados (armazenados para disponibilização), no mínimo um <em>servidor HTTP. </em>Um servidor HTTP é um software que compreende {{Glossary("URL","URLs")}} (endereços web) e {{Glossary("HTTP")}} (o protocolo que seu navegador utiliza para visualizar páginas web.</li> +</ol> + +<p>Em um nível mais básico, o navegador fará uma requisição utilizando o protocolo HTTP sempre que necessitar de um um arquivo hospedado em um servidor web. Quando a requisição alcançar o servidor web correto (hardware), o <em>servidor HTTP </em>(software) enviará o documento requerido, também via HTTP.</p> + +<p><img alt="Basic representation of a client/server connection through HTTP" src="https://mdn.mozillademos.org/files/8659/web-server.svg" style="height: 200px; width: 600px;"></p> + +<p>Para publicar um website, é necessário ou um servidor web estático ou um dinâmico.</p> + +<p>Um <strong>servidor web estático</strong> consiste em um computador (hardware) com um servidor HTTP (software). É chamado "estático" porque o servidor envia seus arquivos tal como foram criados e armazenados (hospedados) ao navegador.</p> + +<p>Um <strong>servidor web dinâmico</strong> consiste em um servidor web estático com software adicional, mais comumente um servidor de aplicações (<em>application server) </em>e um banco de dados (<em>database). </em>É chamado "dinâmico" porque o servidor de aplicações atualiza os arquivos hospedados antes de enviá-los ao navegador através do servidor HTTP.</p> + +<p>Por exemplo, para produzir as páginas finalizadas que você vê em seu navegador, o servidor de aplicações pode completar um modelo de página HTML (<em>HTML template</em>) com o conteúdo obtido de um banco de dados. Sites como o MDN ou a Wikipédia possuem vários milhares de páginas web, mas elas não são realmente documentos HTML, mas apenas alguns poucos <em>templates</em> HTML e uma gigantesca base de dados. Essa configuração agiliza e facilita o gerenciamento e a entrega do conteúdo.</p> + +<h2 id="Aprendizado_ativo">Aprendizado ativo</h2> + +<p><em>Ainda não há aprendizado ativo disponível. <a href="https://developer.mozilla.org/en-US/docs/MDN/Getting_started">Por favor, considere contribuir</a>.</em></p> + +<h2 id="Entrando_a_fundo">Entrando a fundo</h2> + +<p>Para carregar uma página <em>web</em>, como já foi dito, seu <em>browser</em> envia uma requisição ao servidor <em>web</em>, que busca pelo arquivo requisitado no seu próprio espaço de armazenamento. Ao encontrar o arquivo, o servidor <em>web</em> realiza a leitura, faz os processamentos necessários e o envia ao <em>browser</em>. Vamos olhar mais detalhamente para essas etapas.</p> + +<h3 id="Servindo_arquivos">Servindo arquivos</h3> + +<p>Um servidor <em>web</em> precisa primeiro armazenar os arquivos dos <em>websites</em>, como todos os documentos HTML e seus <em>assets</em>, que incluem imagens, páginas de estilo CSS, arquivos JavaScript, fontes e vídeos.</p> + +<p>Técnicamente, você pode servir todos esses arquivos em seu próprio computador. Mas, é muito mais conveniente armazená-los em um servidor web dedicado que</p> + +<ul> + <li>está sempre "vivo" e rodando</li> + <li>está sempre conectado à Internet</li> + <li>tem o mesmo endereço IP sempre (nem todos {{Glossary("ISP", "ISPs")}} fornecem um endereço IP fixo para linhas domésticas)</li> + <li>é mantido por um provedor de terceiros</li> +</ul> + +<p>Por todas essas razões, encontrar um bom provedor de servidores é a chave para criar seu próprio <em>website</em>. Pesquise pelos vários serviços oferecidos e escolha aquele que melhor se alinha às suas necessidades e ao bolso (os serviçoes variam em uma faixa desde zero até milhares de dólares por mês). Você pode encontrar mais detalhes <a href="https://developer.mozilla.org/en-US/Learn/How_much_does_it_cost#Hosting">nesse artigo</a>.</p> + +<p>Uma vez que você escolheu uma solução de servidores web, você só precisa <a href="/en-US/docs/Learn/Upload_files_to_a_web_server">fazer o <em>upload</em> dos seus arquivos para o servidor <em>web</em></a>.</p> + +<h3 id="Comunicando_através_do_HTTP">Comunicando através do HTTP</h3> + +<p>Segundo, um servidor web fornece suporte para {{Glossary("HTTP")}} (protocolo de transferência de hipertexto). Como o próprio nome indica, o HTTP especifica como transferir arquivos de hipertexto (ou seja, documentos vinculados da web) entre dois computadores.</p> + +<p>Um <em>protocolo </em>é um conjunto de regras para comunicação entre dois computadores. HTTP é um protocolo textual sem estado.</p> + +<dl> + <dt>Textual</dt> + <dd>Todos os comandos são de texto simples e legíveis por humanos.</dd> + <dt>Sem estado</dt> + <dd>Nem o servidor nem o cliente lembram de comunicações anteriores. Por exemplo, confiando apenas no HTTP, um servidor não consegue se lembrar de uma senha digitada ou da etapa em que você está em uma transação. Você precisa de um servidor de aplicativos para tarefas como essa. (Nós vamos cobrir esse tipo de tecnologia em mais artigos.)</dd> +</dl> + +<p>O HTTP fornece regras claras sobre como um cliente e um servidor se comunicam. Abordaremos o próprio HTTP em um artigo técnico mais adiante. Por enquanto, apenas fique atento a estas coisas:</p> + +<ul> + <li>Somente <em>clientes </em>podem fazer requisições HTTP, e somente para <em>servidores. </em>Servidores podem apenas<em> responder</em> a uma requisição HTTP dos <em>clientes</em>.</li> + <li>Quando fizer a requisição de um arquivo via HTTP, os clientes devem fornecer a {{Glossary("URL")}} do arquivo.</li> + <li>O servidor web <em>deve responder </em>todas as requisições HTTP, mesmo que seja com uma mensagem de erro.</li> +</ul> + +<p><a href="https://developer.mozilla.org/en-US/404"><img alt="The MDN 404 page as an example of such error page" src="https://mdn.mozillademos.org/files/8661/mdn-404.jpg" style="float: right; height: 300px; width: 300px;"></a>Em um servidor web, o servidor HTTP é responsável por processar e responder as requisições recebidas.</p> + +<ol> + <li>Ao receber uma requisição, um servidor HTTP primeiramente confirma se a URL requisitada corresponde ao arquivo existente.</li> + <li>Se confirmar, o servidor web envia o conteúdo do arquivo de volta ao navegador. Senão, o servidor de aplicações cria o arquivo necessário.</li> + <li>Se nenhum dos processos for possível, o servidor web retorna uma mensagem de erro ao navegador, mais conhecido como "404 Not Found". (Esse erro é tão comum que muitos desevolvedores web passam um bom tempo criando <a href="http://www.404notfound.fr/" rel="external">páginas de erro do 404</a>.)</li> +</ol> + +<h3 id="Conteúdo_estático_vs._dinâmico">Conteúdo estático vs. dinâmico</h3> + +<p>A grosso modo, um servidor pode fornecer tanto um conteúdo estático quanto dinâmico. "Estático" significa "da forma que está". Websites estáticos são os mais fáceis de configurar, então sugerimos que faça seu primeiro site estático.</p> + +<p>"Dinâmico" significa que o servidor processa o conteúdo ou o gera a partir de um banco de dados. Essa solução fornece mais flexibilidade, mas a arquitetura fica mais difícil de lidar, fazendo com que seja dramaticamente mais complexo desenvolver o website.</p> + +<p>Veja por exemplo a página na qual está lendo agora. No servidor web que a hospeda, há um servidor de aplicações que pega o conteúdo do artigo de um banco de dados, o formata, coloca dentro de um template HTML e lhe envia o resultado. Nesse caso, o servidor de aplicações é chamado de <a href="/en-US/docs/MDN/Kuma">Kuma</a> e é desevolvido em <a href="https://www.python.org/">Python</a> (usando o framework <a href="https://www.djangoproject.com/">Django</a> ). A equipe da Mozilla desenvolveu o Kuma devido a necessidades específicas do MDN, mas há muitas aplicações similares em muitas outras tecnologias..</p> + +<p>Existem tantos servidores de aplicações que é muito difícil sugerir algum em particular. Alguns servidores de aplicações atendem à categorias específicas de websites como blogs, wikis ou lojas virtuais. Outros, os chamados {{Glossary("CMS", "CMSs")}} (sistemas de gerenciamento de conteúdo), são mais genéricos. Se estiver desenvolvendo um website dinâmico, reserve um tempo para escolher uma ferramenta que atenda às suas necessidades. A menos que queria aprender sobre o desenvolvimento de um servidor web (que é uma área interessante por si só!), não há necessidade de criar seu próprio servidor de aplicação. Estará apenas reinventando a roda.</p> + +<h2 id="Próximos_passos">Próximos passos</h2> + +<p>Agora que está familiarizado com os servidores web, você pode:</p> + +<ul> + <li>ler sobre <a href="/en-US/docs/Learn/How_much_does_it_cost">quanto custa desenvolver para a web</a> (em inglês)</li> + <li>aprender mais sobre os <a href="/en-US/docs/Learn/What_software_do_I_need">vários softwares necessários para criar um site</a> (em inglês)</li> + <li>partir para a prática de <a href="/en-US/docs/Learn/Upload_files_to_a_web_server">como fazer o upload de arquivos em um servidor web</a> (em inglês).</li> +</ul> |