以太坊账户所有交易查询_交易所对接以太坊钱包服务设计与实现

交易所钱包服务是加密货币交易所系统中的重要组成部分,它负责与各种不同的区块链的交互,实现用户地址生成、充值与提现等功能。本文以对接以太坊区块链的钱包服务为例,介绍交易所系统平台中钱包管理服务的设计与实现。

以太坊账户所有交易查询_交易所对接以太坊钱包服务设计与实现_第1张图片

交易所系统中钱包服务是一个非常重要的组件,它的主要功能包括:

  • 生成以太坊充值地址
  • 当监听地址发生新交易时获取通知
  • 广播签名交易
  • 处理ERC20代币的充值
  • 在区块链中部署新的合约并操作合约方法

如果希望快速掌握区块链应用的开发,推荐汇智网的区块链应用开发系列教程, 内容涵盖比特币、以太坊、eos、超级账本fabric和tendermint等多种区块链,以及 java、go、nodejs、python、php、dart等多种开发语言。

1、开发与运行环境概述

在我们继续之前,首先要满足以下环境要求:

  • Docker: Docker已经成为新应用开发的必备工具,它使得应用的构建、分享与部署都极其简单。
  • Docker Compose:我们使用Docker Compose来管理所有的服务,以便轻松地进行扩展。

其他的需求都由Docker镜像来满足,我们不需要安装其他任何东西了,只需要写一个简单的Docker Compos配置文档 —— docker-compose.yml:

version: '3'services: ganache: image: trufflesuite/ganache-cli command: -m redis: image: redis:alpine ports: - "6379:6379" command: redis-server --appendonly yes volumes: - redis:/data zookeeper: image: wurstmeister/zookeeper ports: - "2181:2181" kafka: image: wurstmeister/kafka ports: - "9092:9092" environment: KAFKA_ADVERTISED_HOST_NAME: 127.0.0.1 KAFKA_CREATE_TOPICS: "command:1:1,address.created:1:1,transaction:1:1,errors:1:1" KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181volumes: redis: 

只要运行docker-compose up -d就可以轻松地启动服务,这个命令会自动从Docker中心下载必要的镜像,然后启动。下面让我们看看都有哪些服务。

1.1 Ganache-cli

如果没有接入以太坊区块链的节点,我们的钱包服务就不会有什么用。在开发期我们不需要下载整个以太坊区块链,因此只要使用Ganache仿真器即可。使用Ganache的好处是开发效率高,因为出块极快。不过在生产环境中就需要使用像Geth这样的节点软件来接入以太坊主网了。

1.2 Redis

我们需要数据库来保存我们创建的地址,并且监听这些地址相关的交易。Redis是一个很出色的内存键/值数据库,非常适合我们的应用场景。

在这个教程中,我们将使用Redis数据库来保存我们为地址生成的私钥,但是在生产服务器上应当使用更安全的硬件设施来保护这些私钥。

1.3 Kafka/Zookeeper

Apache Kafka在交易所架构中扮演着核心的角色,它负责接收所有服务的消息并分发给订阅这些消息的节点。

对于以太坊钱包服务而言,我们将使用以下这些主题进行通信:

  • command
  • address.created
  • transaction
  • errors

Apache Kafka服务器可以独立地进行扩展,为我们的服务提供了一个分布式的消息处理集群。

2、开发语言选择

就我个人而言,是非常喜欢Elixir的,因为可以用它写出极其可靠的分布式应用,而且代码也很容易理解和维护。但是考虑到以太坊的生态,Elixir就没有什么优势了。

对于以太坊开发而言最好的选择还是使用Node.js/Javascript。因为有很多你可以直接就用的组件。因此我们的以太坊钱包服务最终决定使用Node.js开发。

3、初始开发环境搭建

首先运行npm init命令来创建默认的node包:

~/exchange-hubwiz/eth-wallet$ npm init

然后我们可以添加一些钱包服务要用到的node依赖包,执行如下命令:

~/exhcange-hubwiz/eth-wallet$ npm install --save web3 redis kafka-node ethereumjs-tx bluebird

前三个依赖包的作用容易理解:

  • web3:通过websocket连接到Ganache或其他以太坊节点
  • redis:连接到Redis服务器以便保存或提取数据
  • kafka-node:接入Zookeeper,获取Kafka访问端结点,生产或消费Kafka消息

最后的两个依赖包有助于让我们的代码更容易理解,并且可以利用async/await的异步编程模式的优势。

接下来,我们将利用这些node包连接Redis、以太坊和Kafka服务器。

4、连接服务器

4.1 连接Redis服务器

连接Redis非常简单,创建一个redis.js文件,然后编写如下代码:

// load configurationconst config = require('../../config')const redis = require('redis')const bluebird = require('bluebird')// promisify the redis client using bluebirdbluebird.promisifyAll(redis.RedisClient.prototype);bluebird.promisifyAll(redis.Multi.prototype);// create a new redis client and connect to the redis instanceconst client = redis.createClient(config.redis_port, config.redis_host);// if an error occurs, print it to the consoleclient.on('error', function (err) { console.error("[REDIS] Error encountered

你可能感兴趣的:(以太坊账户所有交易查询)