6.8 KiB
Apêndice 2: Compilando Bitcoin da Fonte
Este curso presume o uso de um script para criar um ambiente Bitcoin, seja usando o Bitcoin Standup do Linode de acordo com o especificado na seção §2.1, ou por algum outro meio de acordo com a seção §2.2. No entanto, podemos querer compilar o Bitcoin manualmente.
Isso tem os seguintes benefícios:
- Sempre estará atualizado com a versão mais recente. Mas atenção! Estar sempre atualizado não é necessário para o Bitcoin Core, pois o software é sempre compatível com versões anteriores, o que significa que uma versão antiga do Bitcoin Core ainda poderá participar da rede Bitcoin, embora possamos não ter os recursos mais recentes. Devemos sempre verificar os recursos de uma nova versão antes de atualizarmos.
- Não precisaremos depender de binários do Bitcoin Core pré-compilados. Isso requer menos confiança. Mesmo que os mantenedores do Bitcoin Core façam um ótimo trabalho em manter a integridade do código, algumas etapas do código-fonte são removidas de um binário pré-compilado. Quando compilamos a partir do código-fonte, o código pode ser inspecionado antes da compilação.
- Podemos personalizar a construção, fazendo coisas como desabilitar a carteira ou a GUI.
Preparando Nosso Ambiente
Este tutorial usa o sistema operacional Debian 10.4.kv0 em uma arquitetura amd64 (computadores de 64 bits), mas podemos usar este tutorial em qualquer sistema baseado no Debian (por exemplo, Ubuntu, Mint, etc). Para outros sistemas Linux, podemos adaptar as etapas a seguir com o gerenciador de pacotes do sistema.
Podemos ter pouca ou nenhuma familiaridade com a linha de comando, desde que tenhamos vontade de aprender. O terminal é o nosso aliado mais poderoso, e não algo a ser temido. Podemos simplesmente copiar e colar os seguintes comandos para compilar o Bitcoin. Um comando com um "$" é um comando do usuário normal e um com um "#" é um comando de super usuário/root.
Se o nosso usuário não estiver na lista dos super usuários, podemos o seguinte:
$ su root
<escreva a senha root>
# apt-get install sudo
# usermod -aG sudo <nome do usuário>
# reboot
Instalando o Bitcoin
Etapa 1: Atualizando Nosso Sistema
Primeiro, vamos atualizar o sistema usando:
$ sudo apt-get update
Etapa 2: Instalando o Git e as Dependências
Vamos instalar o git
, que permitirá que baixemos o código-fonte, e o build-essential
, que compila o código:
$ sudo apt-get install git build-essential -y
Depois, vamos instalar as dependências restantes:
$ sudo apt-get install libtool autotools-dev automake pkg-config bsdmainutils python3 libssl-dev libevent-dev libboost-system-dev libboost-filesystem-dev libboost-chrono-dev libboost-test-dev libboost-thread-dev libminiupnpc-dev libzmq3-dev libqt5gui5 libqt5core5a libqt5dbus5 qttools5-dev qttools5-dev-tools libprotobuf-dev protobuf-compiler ccache -y
Etapa 3: Baixando o Código-Fonte
Assim que as dependências forem instaladas, baixamos o repositório (repo) que contém o código-fonte do Bitcoin no github:
$ git clone https://github.com/bitcoin/bitcoin.git
Vamos verificar o conteúdo do repo:
$ ls bitcoin
Devemos corresponder aproximadamente ao seguinte conteúdo:
Etapa 4: Instalando o Berkley DB v4.8
- Vamos entrar no diretório
contrib
:$ cd bitcoin/contrib/
; - Vamos executar o seguinte comando:
$ ./install_db4.sh `pwd`
.
Depois de fazer o download, veremos o seguinte retorno. Devemos observar bem este retorno, porque o usaremos para configurar o bitcoin durante o build:
Etapa 5: Compilando o Bitcoin Core
É recomendado que compilemos a partir de um branch com tag, que é mais estável, a menos que queiramos experimentar as últimas novidades do desenvolvimento do bitcoin. Vamos executar o seguinte comando para obter a lista de tags, ordenada a partir das mais recentes:
$ git tag -n | sort -V
Em seguida, vamos escolha uma tag, por exemplo a v0.20.0
:
$ git checkout <TAG>
Depois de selecionar um ramo da tag, vamos executar o seguinte, dentro do diretório bitcoin
. O <PATH-TO>
deve ser o retorno do script install_db4.sh
.
$ ./autogen.sh
$ export BDB_PREFIX='<PATH-TO>/db4'
$ ./configure BDB_LIBS="-L${BDB_PREFIX}/lib -ldb_cxx-4.8" BDB_CFLAGS="-I${BDB_PREFIX}/include"
$ make # build bitcoin core
Etapa 6: Testando o Build
Se quisermos verificar nossa compilação (o que é uma boa ideia), podemos executar os seguintes testes:
$ make check
irá executar os Testes de Unidade (unit tests), que devem retornarPASS
;$ test/functional/test_runner.py --extended
executará os testes funcionais estendidos. Podemos retirar a sinalização--extended
se quisermos pular alguns testes. Isso vai demorar um pouco.
Etapa 7: Executando ou Instalando o Bitcoin Core
Agora que compilamos o Bitcoin Core a partir da fonte, podemos começar a usá-lo ou instalá-lo.
Executando o Bitcoin Core sem Instalar
Para executar o Bitcoin Core:
$ src/qt/bitcoin-qt
para iniciar a GUI;
$ src/bitcoind
para executar bitcoin na linha de comando.
Instalando o Bitcoin Core
Para instalar:
$ sudo make install
irá instalar o Bitcoin Core globalmente. Uma vez instalado, podemos executar o bitcoin de qualquer lugar usando a linha de comando, assim como qualquer outro software, como: $ bitcoin-qt
para a GUI ou bitcoind
e então bitcoin-cli
para a linha de comando.
Finalizando Nosso Sistema
Ao compilar Bitcoin a partir da fonte, aumentamos a confiança que temos em nossa configuração. No entanto, estamos muito aquém de toda a segurança adicional fornecida por uma configuração Bitcoin Standup. Para resolver isso, podemos percorrer todo o Linode Stackscript e executar passo a passo todos os comandos. O único lugar que precisamos ter cuidado é na Etapa 6, que instala o Bitcoin, pulando o ponto onde já verificamos os binários e continando a partir daí.
Resumo: Compilando Bitcoin da Fonte
Se quisermos aumentar a segurança da instalação do Bitcoin a partir da fonte, agora sabemos fazê-lo. Felizmente, também passamos pelo Linode Stackscript para configurar um servidor mais seguro.
O Que Vem Depois?
Se estávamos no processo de criação de um node Bitcoin para usar neste curso, devemos continuar com o Capítulo 3: Compreendendo Nossa Configuração do Bitcoin.
Se estivermos lendo os apêndices, vamos continuar com o Apêndice 3: Usando o Bitcoin Regtest.