Tether USDT 节点钱包的安装与使用-omni layer

1 什么是Omni Layer 

Omni Layer是一种通信协议,它使用比特币区块链实现智能合约,用户货币和分散式点对点交换等功能。 Omni Core是基于比特币核心代码库的快速,便携式Omni层实现。 这种实现不需要与Bitcoin Core无关的外部依赖关系,并且与其他比特币节点一样,它本身就是比特币网络。 它目前支持钱包模式,并可在三种平台上无缝使用:Windows,Linux和Mac OS。 Omni Layer扩展通过JSON-RPC接口公开。 

1.1 Omni Layer节点的安装

Tether的钱包是以bitcoin区块网络为基础的,在这个网络上面搭建了名为Omni Layer的共识网络,其主要的思想是对bitcoin的区块进行染色,写入需要存储的数据。

2.1 依赖环境。

预备事项
  • 安装过程中,所有的路径使用绝对路径。
  • 本次安装使用环境,Ubuntu 16.04 LTS。

环境依赖

必须依赖库

依赖库 目的 说明
libssl Crypto 随机数生成,椭圆曲线加密
libboost Utility 线程、数据结构
libevent Networking 独立于操作系统的异步网络

可选依赖

依赖库 目的 说明
miniupnpc UPnP Support 防火墙穿越支持
libdb4.8 Berkeley DB 钱包存储 (only needed when wallet enabled)
qt GUI GUI toolkit (only needed when GUI enabled)
protobuf Payments in GUI 支付协议中的数据交换格式(only needed when GUI enabled)
libqrencode QR codes in GUI 生成QR码(二维码)(only needed when GUI enabled)
univalue Utility JSON解析与生成 (bundled version will be used unless –with-system-univalue passed to configure)
libzmq3 ZMQ notification 生成zmq消息(ZMQ,ZeroMQ,消息队列)(requires ZMQ version >= 4.x)

内存要求

C++编译器比较消耗内存,官方建议编译Bitcoin Core时至少有1.5GB内存。对不能达到的系统,gcc 可以用附加的CXXFLAGS设置为节省内存:

./configure CXXFLAGS="--param ggc-min-expand=1 --param ggc-min-heapsize=32768"

编译基础环境安装

由于要用到apt安装,先确保自己的apt源可用,速度正常,运行 
apt-get update

编译环境

sudo apt-get install build-essential libtool autotools-dev automake pkg-config libssl-dev libevent-dev bsdmainutils

亲测结果:在阿里云的apt源下,应该很快安装完毕。

Boost库

在Ubuntu 14+和 Debian 7+系统中,有单个开发包的通用名字,所以可以只安装所需的安装包

sudo apt-get install libboost-system-dev libboost-filesystem-dev libboost-chrono-dev libboost-program-options-dev libboost-test-dev libboost-thread-dev

如果不成功,则可以安装所有boost 开发包。 
sudo apt-get install libboost-all-dev

在阿里云的apt源下面应该可以用第一种方法安装指定的开发包。

BerkeleyDB的安装

BitCoin钱包需要BerkeleyDB的支持,关于BerkeleyDB可以参考官网、 百科

[注意],BitCoin需要Berkeley DB 4.8版本来保持钱包的兼容性,官方Ubuntu和Debian提供的Berkeley DB是5.1+版本的,这个高版本会确定打破其兼容性;此处有两种选择,一是不需要保持兼容性,在编译时增加配置--with-incompatible-bdb即可,二是保持兼容性,安装Berkeley DB 4.8,需要添加PPA,关于PPA是Ubuntu中非官方的不稳定包的更新,使用的话需要小心,其减少可以参考此处,这个地方要用到的是这个地方的PPA来安装所需要的Berkeley DB 4.8here 。 
访问页面,按照其说明逐步添加,然后安装

  1.   sudo apt-get install software-properties-common
  2.   sudo add-apt-repository ppa:bitcoin/bitcoin
  3.   sudo apt-get update
  4.   sudo apt-get install libdb4.8-dev libdb4.8++-dev

安装包下载速度会比阿里云的慢一点,耐心等待。

可选项

  • libminiupnpc 
    sudo apt-get install libminiupnpc-dev
  • ZMQ denpendencies 
    sudo apt-get install libzmq3-dev

GUI依赖项 
如果需要编译bitcoin-qt,则需要安装qt开发环境,qt4和qt5都是可以的,如果两者都安装了,则默认使用qt5,也可以在配置时,使用--with-gui=qt4来进行选择使用qt4版本,或者使用--without-gui来选择不编译gui。

  • qt5的安装方法 
    sudo apt-get install libqt5gui5 libqt5core5a libqt5dbus5 qttools5-dev qttools5-dev-tools libprotobuf-dev protobuf-compiler
  • qt4的安装方法 
    sudo apt-get install libqt4-dev libprotobuf-dev protobuf-compiler
  • libqrencode 
    libqrendoce 是qr码(二维码)的支持模块,可选安装 
    sudo apt-get install libqrencode-dev

如果这些环境包被安装,则会被configure检测到,bitcoin-qt会默认编译生成。

编译生成

好像目前为止就可以编译撸起来了。。。。试一下, optional表示可选项,后面再集中解释吧。

  1.   ./autogen.sh
  2.   ./configure
  3.   make
  4.   make install # optional
  • /configure 
    check 了一堆东西,主要是检测你的基础环境是否安装到位了,不报错就OK。

  • make && make install 

2.2 源码编译

  1.   git clone https://github.com/OmniLayer/omnicore.git
  2.   cd omnicore/
  3.   ./autogen.sh
  4.   ./configure
  5.   make
  • 2.3 运行与区块同步

编译完成之后,在omnicore/src/会有omnicoredomnicore-cli等可执行文件。其来执行方式与bitcoin一样,需要一个名为bitcoin.conf的配置文件。启动命令如下所示:

./omnicored -conf=%PATH TO bitcon.conf% -datadir=%PATH TO DATA DIR% &

启动之后,可以在%datadir%/omnicore.log下面查看日志。

omni同步区块,并不需要把bitcoin区块全部下载,大致一天之内就能够同步完毕。之后,我们就可以使用omnicore-cli命令,或者通过RPC API对节点和钱包进行操作。

2.4 JSON-RPC API

omniJSON-RPC APIbitcoin的完全相同,使用的时候只是相当于将bitcoin的命令集进行了扩展。 
具体的JOSN-RPC API可以查询这里

二次开发过程中,可以使用原有的bitcoinJSON-RPC API包进行开发。例如,使用php-bitcoinrpc

 

启动的参数

 

Omni Core可以通过提供一个或多个可选的命令行参数进行配置:

$ omnicored -setting = value -setting = value

所有设置也可以通过bitcoin.conf

根据操作系统的不同,配置文件的默认位置为:

  • Unix系统: $HOME/.bitcoin/bitcoin.conf
  • Mac OS X: $HOME/Library/Application Support/Bitcoin/bitcoin.conf
  • 微软Windows: %APPDATA%/Bitcoin/bitcoin.conf

典型的bitcoin.conf可能包括:

  1.   server=1
  2.   rpcuser=omnicorerpc
  3.   rpcpassword=5hMTZI9iBGFqKxsWfOUF
  4.   rpcallowip=127.0.0.1
  5.   rpcport=8332
  6.   txindex=1
  7.   datacarriersize=80
  8.   logtimestamps=1
  9.   omnidebug=tally
  10.   omnidebug=packets
  11.   omnidebug=pending

可选设置

要运行和使用Omni Core,不需要显式配置。

有关一般配置和Bitcoin Core特定选项的更多信息,请参阅比特币wiki

常规选项:

名称 类型 默认 描述
startclean 布尔 0 清除启动时的所有持久性文件; 触发Omni事务的重新分析
omnitxcache 500000 输入事务高速缓存中事务的最大数量
omniprogressfrequency 30 以秒为单位的时间,之后报告初始扫描进度
omniseedblockfilter 布尔 1 在初始扫描期间设置跳过没有Omni事务的块
omnishowblockconsensushash 0 计算并记录指定块的一致性散列

日志选项:

名称 类型 默认 描述
omnilogfile omnicore.log 日志文件的路径(在默认情况下在数据目录中)
omnidebug 多串 "" 启用或禁用日志类别,可以"all""none"

交易选项:

名称 类型 默认 描述
autocommit 布尔 1 在创建交易时启用或禁用交易广播
datacarrier 布尔 1 如果禁用,有效载荷将嵌入multisig,而不是OP_RETURN脚本
datacarriersize 80 嵌入在OP_RETURN脚本中的有效载荷的最大字节大小

注意:选项-datacarrierdatacarriersize影响OP_RETURN脚本事务的全局中继策略。

RPC服务器选项:

名称 类型 默认 描述
rpcforceutf8 布尔 1 用RPC响应中的问号替换无效的UTF-8编码字符

用户界面选项:

名称 类型 默认 描述
disclaimer 布尔 0 在启动时明确显示QT免责声明
omniuiwalletscope 65535 最大。交易显示在交易和交易历史记录中

警报和激活选项:

名称 类型 默认 描述
overrideforcedshutdown 布尔 0 覆盖关机,由警报触发
omnialertallowsender 多串 "" 白名单警报的发件人,可以 "any"
omnialertignoresender 多串 "" 忽略警报的发件人
omniactivationallowsender 多串 "" 白名单激活发件人
omniactivationignoresender 多串 "" 忽略激活的发送者

注意:警报和激活相关选项会影响到共识,只能用于测试或特殊情况!

上一篇:《python数字货币量化交易》学习笔记 第一部分 数字货币介绍 1.1.7 Python一行代码自动交易数字货币


下一篇:Mybatis(四) 高级映射,一对一,一对多,多对多映射