🇧🇷
Ethereum Developer Pack - PT
  • Ethereum Developer Pack - PT
  • Módulo 1
    • Introdução a Smart Contracts
      • Fundamentos de Blockchain
        • Histórico
        • Bitcoin
        • O que é Blockchain
        • Conceitos-chave em Blockchain
        • Como funciona a Blockchain
        • Tipos de Blockchain
        • Modelos de Consenso
      • A nova Internet
        • Web 3
        • Elementos Fundamentais
        • Impacto do Ethereum em Diversos Setores
      • Wallets
        • Componentes de uma wallet
        • Tipos de Wallet
        • Códigos Mnemônicos
      • Ethereum 101
        • Smart Contracts
        • Contas
          • Tipos de contas
          • Conteúdo das contas
        • Transações
          • Componentes
          • Ciclo de vida
        • Gás
        • Solidity
        • EVM
          • A máquina de estados
          • Opcodes
          • Como funciona a EVM
          • Clientes de execução
          • DApps
      • Blockchain Explorer
        • Funções de um blockchain explorer
        • Beneficios de utilizar um blockchain explorer
      • Remix
        • Características do Remix
        • Workspaces ou espaços de trabalho
        • Carregar e compilar um contrato
        • Implantar na máquina virtual do Remix (Remix VM)
        • Interagindo com funções
        • Deployar em uma rede pública
      • Crie seu primeiro Smart Contract
  • Módulo 2
    • Fundamentos de Solidity
      • Hello World
      • Tipos de Dados
      • Funções
      • Variáveis
        • Exercício 1
      • Operadores
        • Ejercicio 2
      • Constructor
        • Exercício 3
      • Convenções de nomenclatura
      • Tipos de armazenamento para variáveis
      • Estruturas de Controle
        • Exercício 4
      • Modificadores
      • Eventos
        • Exercício 5
      • Tipos de Referencia
        • Arrays
          • Exercício 6
        • Mappings
          • Exercício 7
        • Structs
          • Exercício 8
      • Address Payable
      • Como os contratos e funções recebem Ether.
      • Transferências de Ether
      • Conceitos Avançados
        • Codificação de ABI
        • Hashing
        • This
        • Herança
        • Abstract
        • Interface
        • Chamada entre contratos
        • EVM
        • ABI
        • Bytecode
        • Opcodes
  • Módulo 3
    • ERCs, Bibliotecas e Padrões de Desenvolvimento
      • Boas Práticas de Desenvolvimento
      • Padrões de Desenvolvimento
      • EIP & ERC
      • ERC-20
      • ERC-721
      • Open Zeppelin
      • Crie um Token ERC-20
      • Almacenamiento Descentralizado: IPFS
      • Crea un Token ERC-721
      • DeFi
  • Módulo 4
    • Kit de ferramentas para desenvolvimento na Ethereum
      • Requisitos para o módulo 4
        • Terminal
        • Git e Github
        • Node.js e npm
        • Visual Studio Code para Solidity
      • Toolkit
        • JSON-RPC
        • Ethers.js
          • Exercício
        • Hardhat
          • Implantação de um contrato no Hardhat
          • Implantação de um contrato em uma rede pública
        • Scaffold-ETH
          • Características do Scaffold-ETHCaracterísticas
          • Como instalar o Scaffold-ETH
  • Módulo 5
    • Segurança, Testes e Auditorias
      • Testes
        • Importância de realizar testes
        • Métodos para testar contratos inteligentes
          • Testes automatizados
          • Testes manuais
        • Conceitos importantes em testes
        • Ferramentas para testes
        • Testes com Hardhat
        • Recursos adicionais
      • Segurança
        • Uma mentalidade diferente de design
        • Principais vulnerabilidades em contratos inteligentes
          • Reentrancy attack (ataque de reentrada)
          • Replay attack (ataque de repetición)
          • Price Oracle Manipulation (Manipulación de Oráculos de Precios)
          • Missing Access Control (Pérdida de Control de Acceso)
          • Reward Manipulation (Manipulación de Recompensas)
          • Failure to Initialize (Falla al Inicializar)
          • Front-running
          • Invariant Breaks (Quebra de Invariantes)
          • Mishandling of ETH (Má gestão de ETH)
          • Denial of Service (DoS - Negação de Serviço)
          • Integer overflow and underflow (Overflow e Underflow de inteiros)
          • Phishing y Typosquatting
        • Recursos adicionais
      • Auditoria de smart contracts
        • Processo de Auditoria
        • Ferramentas
        • Como se preparar para uma auditoria
        • O teste Rekt
        • Desafios
        • Recursos adicionais
  • Contribuye
    • Kipu Explorer
Powered by GitBook
On this page
  1. Módulo 1
  2. Introdução a Smart Contracts
  3. Fundamentos de Blockchain

Como funciona a Blockchain

PreviousConceitos-chave em BlockchainNextTipos de Blockchain

Last updated 6 months ago

Para entender como funciona uma blockchain, utilizaremos como exemplo a primeira: o Bitcoin. Explicaremos de forma simplificada, mas destacando os principais elementos da blockchain.

Partimos do fato de que existe uma rede distribuída do tipo P2P de computadores (nós).

O conceito de rede P2P é fundamental para entender como funciona uma blockchain. Essa rede está permanentemente ativa e é responsável por operar o sistema do Bitcoin. Para isso, todos os nós executam o mesmo programa, que contém as regras de funcionamento da blockchain.

Vamos começar:

  1. Iris deseja enviar um bitcoin para Pepe. Para isso, Iris inicia uma transferência a partir de sua carteira digital para o endereço Bitcoin de Pepe. A transação registra os seguintes dados: endereço de origem, endereço de destino, valor da transferência e a taxa de transação, caso Iris esteja disposta a pagá-la.

  2. A transação é difundida pelos nós mais próximos até alcançar toda a rede P2P. Isso acontece simultaneamente com outras transações realizadas por outros usuários da rede.

  3. As transações acumulam-se em uma mempool, que é um arquivo onde os nós armazenam as transações que ainda não foram incorporadas na blockchain e, portanto, estão pendentes de validação.

  4. Os nós mineradores (computadores), que armazenam a blockchain completa, competem na criação de um novo bloco. Para isso, formam seu bloco candidato tomando transações da mempool (em média cerca de mil), adicionando um cabeçalho, que, entre outros dados, contém: o número do bloco (ou altura do bloco), o hash do último bloco criado, a hora de criação, um resumo das transações incluídas e um número dummy denominado nonce, que será usado para participar na prova de trabalho a ser realizada.

  5. Com seu bloco candidato formado, cada nó minerador participa de uma competição denominada prova de trabalho, que exige o máximo de sua capacidade de processamento, gerando hashes utilizando uma função como a SHA-256. A competição dura, em média, 10 minutos até que um nó minerador obtenha um hash correto. O nó minerador que encontrou a solução transmite seu bloco vencedor para todos os nós da rede para verificação.

  6. Os nós verificam se as transações estão corretas (por exemplo, se Iris possui bitcoins para transferir a Pepe e se Iris autorizou essa transferência utilizando sua chave privada) e se foi obtido um hash que atende aos requisitos da prova de trabalho. Se tudo estiver correto, o novo bloco é aceito e adicionado à blockchain. O nó vencedor recebe do sistema a recompensa em bitcoins definida naquele momento (atualmente 6,25 BTC) e as taxas incluídas nas transações de seu bloco.

  7. Os nós da rede removem de suas mempools as transações que já estão no novo bloco e voltam a trabalhar a partir do ponto 4. A transferência de Iris para Pepe já foi validada pela rede e registrada para sempre na blockchain.

Aqui está um vídeo que resume o processo descrito acima: