bitcoin: 使用gitian编译并发布
免责声明: 本人省略了很多细节
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种虚拟化:
重点介绍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环境