Fisco Bcos 2.11.0配置console控制台2.10.0及部署调用智能合约

Fisco Bcos 2.11.0配置console控制台2.10.0及部署调用智能合约

文章目录

  • [Fisco Bcos 2.11.0配置console控制台2.10.0及部署调用智能合约](#Fisco Bcos 2.11.0配置console控制台2.10.0及部署调用智能合约)

前言

  • Fisco Bcos Console命令行交互控制台,是FISCO BCOS 2.0重要的交互式客户端工具,拥有丰富的命令,能够在连接Fisco Bcos区块链节点后,实现查询区块链信息和状态部署和调用智能合约管理区块链节点等功能。

  • Console2.6版本之后基于Java SDK实现(java JDK版本适配,请查看版本适配),请自行检查JAVA JDK版本或进行安装。

  • Console控制台的配置和使用,基于Fisco Bcos区块链网络搭建及成功运行之后。搭建区块链网络请查看博客:

    Fisco Bcos 2.11.0通过网络和本地二进制文件搭建单机节点联盟链网络(搭建你的第一个区块链网络)

  • console 2.11.0 目前正处于Pre-release版本,所以本篇博客将在ubuntu系统中,使用Java 14进行Console控制台v2.10.0版本的配置及使用

版本适配

  • FISCO-BCOS支持Java版本的SDK,并且大量的示例、周边项目都是基于JavaSDK,下列版本是官方已经验证的JDK版本:
JDK 推荐版本
OracleJDK 1.8.0_141、1.8.0_202、11.0.2、14.0.2、15.0.2
OpenJDK 11.0.2、14.0.2、15.0.2
  • Fisco Bcos 2.x版本仅可部署console1.x和2.x版本的控制台,请检查并确定Fisco Bcos区块链的版本是否为2.x版本

一、启动FIsco Bcos区块链网络

shell 复制代码
bash nodes/127.0.0.1/start_all.sh

首先,进入fisco目录,执行上面的指令,启动区块链网络

如果没有搭建区块链网络请查看此博客文章:Fisco Bcos 2.11.0通过网络和本地二进制文件搭建单机节点联盟链网络(搭建你的第一个区块链网络)

如果已启动网络则会提示node is running

二、获取控制台文件

下载地址1:(国内用户推荐使用这个地址)

shell 复制代码
curl -#LO https://gitee.com/FISCO-BCOS/console/raw/master-2.0/tools/download_console.sh

下载地址2:

shell 复制代码
curl -#LO https://github.com/FISCO-BCOS/console/releases/download/v2.9.2/download_console.sh

三、配置控制台

3.1 执行download_console.sh脚本

bash 复制代码
bash download_console.sh

执行完成后会增加console压缩包和console两个文件

接下来的操作都在console文件中进行


3.2 拷贝控制台配置文件

bash 复制代码
cd console
cp -n conf/config-example.toml conf/config.toml

3.3 修改控制台配置文件(如果channel端口发生变化)

  • 如果是按照作者专栏中的博客进行搭建的区块链网络,或者搭建区块链网络时采用的节点默认端口号,则跳过这一步
  • 如果在搭建区块链网络节点时,channel端口没有采用默认的20200端口,请进入config.toml中修改端口
shell 复制代码
cd conf
vim config.toml

3.4 配置控制台证书

shell 复制代码
cp -r ../nodes/127.0.0.1/sdk/* ./conf/

四、启动控制台

shell 复制代码
bash start.sh

如果想要退出控制台,请在控制台内输入quitexit

五、使用控制台部署调用智能合约

接下来的操作都在console控制台中进行,所以请保证控制台处于启动状态

5.1 查看内置合约

为了方便用户快速体验,Fisco Bcos官方在控制台中已经内置了一个HelloWorld,位于控制台目录下contracts/solidity/HelloWorld.sol,大家可以直接部署

合约具体内容:

javascript 复制代码
pragma solidity ^0.4.24;

contract HelloWorld {
    string name;

    function HelloWorld() {
        name = "Hello, World!";
    }

    function get()constant returns(string) {
        return name;
    }

    function set(string n) {
        name = n;
    }
}

简要分析合约:

HelloWorld合约提供两个接口,分别是get()set(),用于获取/设置合约变量name

5.2 部署Hello World合约

deploy HelloWorld

复制好 contract address 地址(每个人的地址都不一样):后面调用合约需要用到

5.3调用合约方法

  • 调用合约get方法

    call HelloWorld 0x5c3754edd1835ce0f26300e24cadeead17adb77d get

合约的返回值为Hello,World!

  • 调用合约set方法

    call HelloWorld 0x5c3754edd1835ce0f26300e24cadeead17adb77d set "Hi,FISCO BCOS"

返回状态:成功

这时候可以再次调用get方法,会发现此时合约的返回值已经发生了改变为Hi,FISCO BCOS

进阶知识点

查看当前区块链的块高命令

getBlockNumber

调用合约的get接口,并不会更改账本的状态

调用合约的set接口,会在账本中存储一个新的值,再此查看区块链的当前块高,会发现块高会增加,表示已出块,账本状态已更改


相关推荐
Swift社区3 小时前
【分布式日志篇】从工具选型到实战部署:全面解析日志采集与管理路径
人工智能·spring boot·分布式
指尖下的技术4 小时前
Kafka面试题----Kafka消息是采用Pull模式,还是Push模式
分布式·kafka
黑客老李5 小时前
区块链 智能合约安全 | 回滚攻击
服务器·数据仓库·hive·hadoop·区块链·php·智能合约
码至终章6 小时前
kafka常用目录文件解析
java·分布式·后端·kafka·mq
小马爱打代码6 小时前
Kafka-常见的问题解答
分布式·kafka
柴郡猫^O^6 小时前
OSCP - Proving Grounds - Quackerjack
安全·网络安全·安全性测试
峰子20127 小时前
B站评论系统的多级存储架构
开发语言·数据库·分布式·后端·golang·tidb
weisian1517 小时前
消息队列篇--原理篇--Pulsar和Kafka对比分析
分布式·kafka
无锡布里渊8 小时前
分布式光纤应变监测是一种高精度、分布式的监测技术
分布式·温度监测·分布式光纤测温·厘米级·火灾预警·线型感温火灾监测·分布式光纤应变
40岁的系统架构师8 小时前
15 分布式锁和分布式session
分布式·系统架构