从源代码编译
您可以在此处下载预构建的二进制文件。
如果您仍然想自己编译源代码,请按照以下说明操作。
这是一个简化的快速构建指南。
如果您是为生产而不是家庭使用而构建,最好使用自动构建脚本。
通用
该软件可能在大多数Linux系统上都能正确编译和工作。它应该适用于macOS甚至Windows。
1) 在GitHub库 https://github.com/ton-blockchain/ton/ 下载TON区块链源代码的最新版本:
git clone --recurse-submodules https://github.com/ton-blockchain/ton.git
2) 安装最新版本的:
make
cmake
版本 3.0.2 或更高g++
或clang
(或适用于您的操作系统的另一种C++14兼容编译器)。OpenSSL(包括C头文件)版本 1.1.1 或更高
build-essential
,zlib1g-dev
,gperf
,libreadline-dev
,ccache
,libmicrohttpd-dev
,pkg-config
,libsodium-dev
,libsecp256k1-dev
在Ubuntu上:
apt update
sudo apt install build-essential cmake clang openssl libssl-dev zlib1g-dev gperf libreadline-dev ccache libmicrohttpd-dev pkg-config libsodium-dev libsecp256k1-dev
3) 假设您已将源代码树获取到目录~/ton
,其中~
是您的主目录,并且您已创建一个空目录~/ton-build
:
mkdir ton-build
然后在Linux或MacOS的终端中运行以下命令:
cd ton-build
export CC=clang
export CXX=clang++
cmake -DCMAKE_BUILD_TYPE=Release ../ton && cmake --build . -j$(nproc)
在MacOS Intel上进行下一步之前,我们可能需要使用brew
安装openssl@3
,或者只是链接该库:
brew install openssl@3 ninja libmicrohttpd pkg-config
然后需要检查/usr/local/opt
:
ls /usr/local/opt
找到openssl@3
库并导出本地变量:
export OPENSSL_ROOT_DIR=/usr/local/opt/openssl@3
如果您在内存较小的计算机上编译(例如,1GB),请不要忘记创建交换分区。
下载全局配置
对于像轻客户端这样的工具,您需要下载全局网络配置。
从 https://ton-blockchain.github.io/global.config.json 下载主网的最新配置文件:
wget https://ton-blockchain.github.io/global.config.json
或从 https://ton-blockchain.github.io/testnet-global.config.json 下载测试网的配置文件:
wget https://ton-blockchain.github.io/testnet-global.config.json
轻客户端
cmake --build . --target lite-client
使用配置运行轻客户端:
./lite-client/lite-client -C global.config.json
如果一切安装成功,轻客户端将连接到一个特殊的服务器(TON区块链网络的完整节点)并向服务器发送一些查询。如果您向客户端指示一个可写的“数据库”目录作为额外参数,它将下载并保存与最新的主链块相对应的块和状态:
./lite-client/lite-client -C global.config.json -D ~/ton-db-dir
通过在轻客户端中输入help
可以获得基本帮助信息。输入quit
或按Ctrl-C
退出。
FunC
要从源代码构建FunC编译器,请执行上面描述的通用部分,然后:
cmake --build . --target func
要编译FunC智能合约:
func -o output.fif -SPA source0.fc source1.fc ...
Fift
要从源代码构建Fift编译器,请执行上面描述的通用部分,然后:
cmake --build . --target fift
要运行Fift脚本:
fift -s script.fif script_param0 script_param1 ..
Tonlib-cli
要构建tonlib-cli,请执行通用部分,下载配置,然后执行:
cmake --build . --target tonlib-cli
使用配置运行tonlib-cli:
./tonlib/tonlib-cli -C global.config.json
通过在tonlib-cli中输入help
可以获得基本帮助信息。输入quit
或按Ctrl-C
退出。
RLDP-HTTP-Proxy
要构建rldp-http-proxy,请执行通用部分,下载配置,然后执行:
cmake --build . --target rldp-http-proxy
代理二进制文件将位于:
rldp-http-proxy/rldp-http-proxy
generate-random-id
要构建generate-random-id,请执行通用部分,然后执行:
cmake --build . --target generate-random-id
二进制文件将位于:
utils/generate-random-id
storage-daemon
要构建storage-daemon和storage-daemon-cli,请执行通用部分,然后执行:
cmake --build . --target storage-daemon storage-daemon-cli
二进制文件将位于:
storage/storage-daemon/
编译旧版本的TON
TON版本发布:https://github.com/ton-blockchain/ton/tags
git clone https://github.com/ton-blockchain/ton.git
cd ton
# git checkout <TAG> 例如 checkout func-0.2.0
git checkout func-0.2.0
git submodule update --init --recursive
cd ..
mkdir ton-build
cd ton-build
cmake ../ton
# 构建 func 0.2.0
cmake --build . --target func
在Apple M1上编译旧版本:
TON从2022年6月11日开始支持Apple M1(添加apple m1支持 (#401)提交)。
要在Apple M1上编译旧版本的TON修订版:
将RocksDb子模块更新到6.27.3
cd ton/third-party/rocksdb/
git checkout fcf3d75f3f022a6a55ff1222d6b06f8518d38c7c用https://github.com/ton-blockchain/ton/blob/c00302ced4bc4bf1ee0efd672e7c91e457652430/CMakeLists.txt 替换根目录的
CMakeLists.txt