bitcoin: 使用gitian编译并发布

in bitcoin •  7 years ago 

免责声明: 本人省略了很多细节

gitian 是什么

我们开发软件都希望更多的人使用,一款软件可能会兼容很多的操作平台,例如 Windows ,MacOs, 众多的Linux版本,甚至还有ARM, Bitcoin也是如此.
bitcoin做为一款开源软件,有众多的贡献者,为了保证能在各个系统中能编译出安全稳定的版本, Bitcoin Core设计了 Gitian.
Gitian不是一个主流的解决方案,基本就是Bitcoin Core在用.

官网: https://www.gitian.org/
代码: https://github.com/devrandom/gitian-builder

Gitian的原理

Gitian使用现成的虚拟化技术,模拟ubuntu系统,在同一个系统中编译不同系统平台的软件, 即交叉编译.
用虚拟化的系统,在一个封闭的操作系统中,重新安装bitcoin的依赖组件,重新编译, 排除安全 /软件依赖等问题, 发布一个稳定的软件. 目前Gitian支持3种虚拟化:

  1. Linux的LXC技术
    如果你了解Docker, 很可能听说过LXC.

  2. QEMU

  3. Vagrant

重点介绍LXC.


如何在ubuntu系统上使用Gitian

安装依赖

sudo apt-get install -y git apache2 apt-cacher-ng python-vm-builder ruby lxc

配置网络环境

先切换成root用户 sudo -i, 在执行以下shell,

echo '#!/bin/sh -e' > /etc/rc.local
echo 'brctl addbr br0' >> /etc/rc.local
echo 'ifconfig br0 10.0.3.2/24 up' >> /etc/rc.local
echo 'iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE' >> /etc/rc.local
echo 'echo 1 > /proc/sys/net/ipv4/ip_forward' >> /etc/rc.local
echo 'exit 0' >> /etc/rc.local

得到的 /etc/rc.local内容如下:

#!/bin/sh -e
brctl addbr br0
ifconfig br0 10.0.3.2/24 up
iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
echo 1 > /proc/sys/net/ipv4/ip_forward

exit 0

执行 sudo /etc/rc.local, 使之生效, 不要忘了这个步骤.

下载gitian源码

git clone https://github.com/devrandom/gitian-builder.git
git clone https://github.com/bitcoin/bitcoin.git
# 放在同一级目录下 

下载编译bitcoin需要的类库

cd gitian-builder
make -C ../bitcoin/depends download SOURCES_PATH=`pwd`/cache/common #将类库下载到 cache/common

生成个虚拟环境

cd gitian-builder

./bin/make-base-vm --lxc --arch amd64 --suite trusty
# 使用lxc 生成一个64位的trusty版本的ubuntu系统
# 生成 base-trusty-amd64文件

导入环境变量

export USE_LXC=1 # gitian用哪种技术方案
export GITIAN_HOST_IP=10.0.3.2 # 宿主机IP
export LXC_GUEST_IP=10.0.3.5 # 虚拟机IP

export PATH="$PATH":~/gitian-builder/libexec

编译 终于最后一步了

URL=https://github.com/bitcoin/bitcoin.git #自定义变量, 编译哪个项目
COMMIT=master # 自定义变量,编译哪个分支

./bin/gbuild --num-make 4 --commit bitcoin=${COMMIT} --url bitcoin=${URL}    ../bitcoin/contrib/gitian-descriptors/gitian-linux.yml

# 注意 COMMIT URL
# --num-make 4 启动4个进程
# contrib/gitian-descriptors/gitian-linux.yml 记录了如何在linux下编译
# 还有 gitian-osx.yml gitian-win.yml

整个过程比较漫长, 最后在 build/out 得到编译的版本.

编译window版本, 就要执行gitian-win.yml, Macos亦然

./bin/gbuild --num-make 4 --commit bitcoin=${COMMIT} --url bitcoin=${URL} ../bitcoin/contrib/gitian-descriptors/gitian-win.yml

在使用gitian编译mac平台时需要把 MacOSX10.11.sdk 放到目录gitian-builder/inputs, bitcoin core 把这个库放到了https://bitcoincore.org/depends-sources/sdks/MacOSX10.11.sdk.tar.gz .

发布的版本列表:

├── linux
│   ├── bitcoin-0.15.0-aarch64-linux-gnu-debug.tar.gz
│   ├── bitcoin-0.15.0-aarch64-linux-gnu.tar.gz
│   ├── bitcoin-0.15.0-arm-linux-gnueabihf-debug.tar.gz
│   ├── bitcoin-0.15.0-arm-linux-gnueabihf.tar.gz
│   ├── bitcoin-0.15.0-i686-pc-linux-gnu-debug.tar.gz
│   ├── bitcoin-0.15.0-i686-pc-linux-gnu.tar.gz
│   ├── bitcoin-0.15.0-x86_64-linux-gnu-debug.tar.gz
│   ├── bitcoin-0.15.0-x86_64-linux-gnu.tar.gz
│   └── src
│       └── bitcoin-0.15.0.tar.gz
├── mac
│   ├── bitcoin-0.15.0-osx64.tar.gz
│   ├── bitcoin-0.15.0-osx-unsigned.dmg
│   ├── bitcoin-0.15.0-osx-unsigned.tar.gz
│   └── src
│       └── bitcoin-0.15.0.tar.gz
└── win
    ├── bitcoin-0.15.0-win32-debug.zip
    ├── bitcoin-0.15.0-win32-setup-unsigned.exe
    ├── bitcoin-0.15.0-win32.zip
    ├── bitcoin-0.15.0-win64-debug.zip
    ├── bitcoin-0.15.0-win64-setup-unsigned.exe
    ├── bitcoin-0.15.0-win64.zip
    ├── bitcoin-0.15.0-win-unsigned.tar.gz
    └── src
        └── bitcoin-0.15.0.tar.gz

PS: 有的做法是先在物理机安装个 virtualbox , 先虚拟个Debian8, 在Debian8里执行gitian, 这么做太麻烦了. 略过不表


参考:

https://www.ibm.com/developerworks/cn/linux/l-lxc-containers/
https://linuxcontainers.org/
https://segmentfault.com/a/1190000000264347

https://github.com/bitcoin/bitcoin/blob/master/doc/release-process.md bitcoin发布流程
https://github.com/bitcoin-core/docs/blob/master/gitian-building.md 创建Gitian环境

Authors get paid when people like you upvote their post.
If you enjoyed what you read here, create your account today and start earning FREE STEEM!