您正在查看: Surou 发布的文章

EOS 支持 sql_db_plugin及连接测试

更新sql_db_plugin代码

git clone https://github.com/superoneio/eos_sql_db_plugin
cp -rv eos_sql_db_plugin/sql_db_plugin/* /home/surou/Documents/github/eos/plugins/sql_db_plugin

对比了以下几个维护的sql_db_plugin版本代码

开启sql_db_plugin编译支持

  1. 打开eos/plugins/CMakeLists.txt
    取消add_subdirectory(sql_db_plugin)前面的#注释
  2. 打开 eos/programs/nodeos/CMakeLists.txt
    // 取消下面代码前的注释,如果无注释,则忽略此步骤。
    if(TARGET sql_db_plugin)
     target_link_libraries( nodeos PRIVATE -Wl,${whole_archive_flag} sql_db_plugin -Wl,${no_whole_archive_flag} )
    endif()

    重新编译EOS

    ./eosio_build.sh
    cd build
    sudo make install

    编译完成后,执行

    nodeos --help | grep "sql_db-uri"

    如果输出如下内容,证明编译成功。

    –sql_db-uri arg Sql DB URI connection string If not

Mysql 8.0 安装

  • 参考 Ubuntu 安装MySql 8.0
  • 接下来我们安装 soci。soci 是 C++ 连接 MySQL 的 Library。Ubuntu 可以快速安装,命令如下:
    sudo apt-get -y install libsoci-dev
  • 安装 mysql-client
    sudo apt-get -y install mysql-client
    sudo apt-get install libmysqlclient-dev

配置Eos数据库

  • 进入mysql
    mysql -p
  • 创建数据库以及分配账号
    CREATE DATABASE eos DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
    GRANT ALL PRIVILEGES ON eos.* TO 你的账户名@'%' IDENTIFIED BY '你的密码';
    GRANT ALL PRIVILEGES ON eos.* TO 你的账户名@'127.0.0.1' IDENTIFIED BY '你的密码';
  • 查看数据库
    mysql > show databases;

  • 导入数据库(eos.db)
    mysql > use eos;  //切换到eos 数据库
    mysql > source eos_sql_db_plugin/sql_db_plugin/eos.db; //导入数据库

    执行数据同步

    nodeos --sql_db-uri="mysql://db=eos user=root host=127.0.0.1 password='数据库密码'" --sql_db-block-start=0  --delete-all-blocks

常见问题

  • ERROR 1273 (HY000): Unknown collation: 'utf8mb4_0900_ai_ci'
    MySql 8.0才支持的默认字符集
  • 查看Ubuntu版本
    cat /etc/issue

参考链接

EOS 合约代码中的print 输出到终端

修改~/.local/share/eosio/nodeos/config/config.ini

contracts-console = true

安装EOS 数据获取API Server EOSTracker-API

获取源代码

git clone https://github.com/EOSEssentials/EOSTracker-API.git

开始编译

cd EOSTracker-API
composer install

开始运行

php bin/console server:run


常见问题

  • ubuntu add-apt-repository command not found解决方法
    apt-get install software-properties-common
  • Ubuntu PHP升级到最新版本
    add-apt-repository ppa:ondrej/php
    apt-get update
    apt-get upgrade php
  • The requested PHP extension ext-apcu * is missing from your system. Install or enable PHP's apcu extension
    apt-get install php7.2-apcu //修改为当前版本  php -v
  • The requested PHP extension ext-intl * is missing from your system. Install or enable PHP's intl extension
    apt-get install php7.2-intl //修改为当前版本  php -v
  • The requested PHP extension ext-mbstring * is missing from your system. Install or enable PHP's mbstring extension
    apt-get install php7.2-mbstring //修改为本地版本  php -v
  • The requested PHP extension ext-redis * is missing from your system. Install or enable PHP's redis extension
    apt-get install php7.2-redis //修改为本地版本  php -v
  • Installation request for symfony/symfony v3.4.11 -> satisfiable by symfony/symfony[v3.4.11].
    symfony/symfony v3.4.11 requires ext-xml * -> the requested PHP extension xml is missing from your system.
       apt-get install php7.2-xml //修改为本地版本 PHP -v

EOSIO各版本含义

  • Dawn = Alpha
  • V1.. = Beta
  • EOS Mainnet 版本 = Stable

Alpha:是内部测试版,一般不向外部发布,会有很多Bug.一般只有测试人员使用。Beta:也是测试版,这个阶段的版本会一直加入新的功能。在Alpha版之后推出。Stable:稳定版;来自预览版本释出使用与改善而修正完成。

--replay-blockchain does not work

try --hard-replay-blockchain
参考:github