APP技术开发:I3570980718
consensus: # 共识类型(0-SOLO,1-TBFT,3-HOTSTUFF,4-RAFT,5-DPoS,10-POW) type: 4 nodes: - org_id: "wx-org1.chainmaker.org"
合约交易是指买卖双方对约定未来某个时间按指定价格接收一定数量的某种资产的协议进行交易,合约交易的买卖对象是由交易所统一制定的标准化合约,交易所规定了其商品种类,交易时间,数量等标准化信息。合约代表了买卖双方所拥有的权利和义务。
用户界面是交易的脸面,在很大程度上也决定了用户的体验感。确保以简约的方式构建用户友好且直观的界面,以提供令人惊喜的交易体验,使用户更容易执行交易订单。另外我们使用前后台分离,数据库分离,保护数据安全与系统安全
Web3.0是互联网的新未来,旨在成为一个更加自主、更加智能和更加开放的互联网,它是一个去中心化的网络,包含由区块链等分布式账本技术提供的上一代互联网应用程序和服务。它的使命是分散数据,让计算机拥有人类的智能,并以此来分析和解释信息。也就是说,在Web3.0中,用户所创造的数字内容,所有权明确为用户所有,由用户控制,其所创造的价值,根据用户与他人签订的协议进行分配。在这种体系之下,这些数字内容就不再是简单的数据了,而是数字资产,因为它的权利得到了资产级别的保障。Web3.0将彻底改变社会的数字经济生产关系,使得每一名Web3.0的参与者都将成为新的生产关系的构建者,并且同时拥有自己独立的数
SYSTEM_CONTRACT_DPOS_STAKE: 由于stake合约地址是由合约名通过sha256计算后base58编码得到的,为固定值;但base58的值可读、可写不便,容易配置出错,因此,对于stake合约的地址配置为合约名;链启动后可以通过该命令查询stake合约地址
共识模块主要由几个组件组成,世代epoch、提案消息缓存服务msgcache、共识消息处理引擎engine、共识消息验证器verifier、提案消息存储服务forest、投票处理器voter、共识活性服务pacemaker、wal存储wal、节点间共识信息同步服务compensator、各模块相互配合实现maxbft流水线共识算法
// Proposal defined a consesensus proposal which can // be gossiped to other node and can be serilized // for persistent store. message Proposal {
Raft算法是目前使用最广泛的非拜占庭容错类共识算法。 Raft算法主要依靠投票机制和日志复制机制来实现节点间的共识。节点通过投票选出一个leader,由leader负责处理所有请求,再将请求以日志的方式复制到其他节点。
package main//sdk代码中,有且仅有一个main()方法func main(){//main()方法中,下面的代码为必须代码,不建议修改main()方法当中的代码//其中,TestContract为用户实现合约的具体名称err:=sandbox.Start(new(FactContract))if err!=nil{log.Fatal(err)}}
在spv/scripts目录,运行start.sh脚本,将会调用spv/build/release/bin目录中的start.sh脚本,启动SPV轻节点。
在区块链上交换的好处在于交易所并不持有使用者大量的加密货币,所有的加密货币会储存在区块链上使用者的钱包或智能合约控管。本来需要信任中心化的交易所,现在仅需要信任区块链以及智能合约即可。而用于交易所的智能合约大多会公开源码让所有人可以确认这份合约的细节。
What is a centralized exchange: In a centralized exchange, users deposit their digital assets in the exchange, which centrally keeps and controls them. When users trade, they will submit trading instructions to the Exchange, which will match the transactions and inform users of the results after
The development technology of digital currency exchange is a decentralized consensus mechanism to maintain a complete,distributed and tamper proof ledger database.It enables participants in the blockchain to achieve a unified ledger system without establishing trust relationships.
智能合约代码编写: contract Students { struct StudentInfo { uint32 _studentId; bytes32 _studentName; } mapping (uint32 => StudentInfo) private _studentMapping; function addStudent(uint32 studentId, bytes32 studentName) public returns(bool){ //TODO: } }
core偏核心逻辑,单个swap的逻辑。periphery偏外围服务,一个个swap的基础上构建服务。单个swap,两种代币形成的交易对,俗称“池子”。每个交易对有一些基本属性:reserve0/reserve1以及total supply。reserve0/reserve1是交易对的两种代币的储存量。total supply是当前流动性代币的总量。每个交易对都对应一个流动性代币(LPT - liquidity provider token)。简单的说,LPT记录了所有流动性提供者的贡献。所有流动性代币的总和就是total supply。Uniswap协议的思想是reserve0*reserv
Solidity中智能合约的含义就是一组代码(它的功能)和数据(它的状态)的集合,并且它们是位于以太坊区块链的一个特定地址上的。uintstoredData;这一行代码声明了一个名为``storedData``的状态变量,其类型为uint(256位无符号整数)。 你也可以认为它是数据库里的一个插槽,并且可以通过调用管理数据库代码的函数进行查询和更改。在这个例子中,上述的合约定义了``set``和``get`` 函数,可以用来修改或检索变量的值。
隐私合约功能由一个基于可信执行环境的隐私合约环境提供。这个隐私合约环境由可信执行环境Enclave和隐私计算网关组成。其中Enclave是运行在可信执行环境的逻辑,负责对合约进行验证、编译、执行,敏感数据密文只能在Enclave中解密。长安链的Enclave中实现了一套WASM逻辑,可以对任意数据处理逻辑进行编译、运行。隐私计算网关负责将用户、Enclave发出的信息打包成区块链的交易payload,并转发给区块链存证。
QueryContract(contractName,method string,kvs[]*common.KeyValuePair,timeout int64)(*common.TxResponse,error)
withSyncResult:是否同步获取交易执行结果当为true时,若成功调用,common.TxResponse.ContractResult.Result为common.TransactionInfo当为false时,若成功调用,common.TxResponse.ContractResult为空,可以通过common.TxResponse.TxId查询交易结果
长安链SDK是业务模块与长安链交互的桥梁,支持双向TLS认证,提供安全可靠的加密通信信道。 长安链提供了多种语言的SDK,包括:Go SDK、Java SDK、Python SDK、Nodejs SDK方便开发者根据需要进行选用。
隐私计算网关调用系统合约把执行结果与签名传到链上。系统合约会从链上获取Enclave远程证明,从中提取出签名公钥,并对执行结果的签名进行验证,并从执行结果中提取隐私合约、链上数据部分,与区块链上的信息进行比对。如果这些验证都通过了,则系统合约执行成功,隐私合约的执行结果会被打包到区块中等待共识出块。
一般来说,参与到区块链交易中的数据对链参与者都是公开的。而长安链隐私合约功能为区块链提供在合约中处理敏感数据的能力,达到保护数据隐私的同时保证合约执行过程的可靠性(包括合约逻辑、数据的完整性)。长安链隐私合约采用可信计算技术,在可信执行环境中执行隐私合约。敏感数据以密文形式存在于区块链账本中,用户使用时在可信执行环境中解密,而可信执行环境外无法获得敏感数据明文。同时,可信执行环境的远程证明保证合约逻辑不被篡改。如此,达到敏感数据在区块链上的可用不可见,而数据处理流程仍然可以在区块链上公开验证的效果。
网络应用层:是指使用Liquid来实现网络通讯的上层应用集合,Liquid是使用应用协议(protocol.ID)来区分标识上层应用的,每个应用模块都应该有一个全局唯一的应用协议。应用协议描述详见4.1。消息发布及订阅模块(PubSub)是Liquid内置的一个应用。
Liquid内置了一个该接口的实现——pubsub.ChainPubSub。ChainPubSub是基于应用协议实现的链级数据隔离消息发布及订阅服务。ChainPubSub代码在pubsub包中。
发送流池负责管理连接所创建的所有发送流,每个连接对应创建一个发送流池,在创建时可初始化一定数量的发送流,当池中空闲发送流数量低于阈值且总发送流数量低于允许的最大值时,发送流池会自动创建一定数量新的发送流。如果发送流在发送过程中发生错误,则通过DropStream方法弃用该发送流。如果连接关闭,则会弃用所有发送流并关闭发送流池。
TCP传输是以TCP作为底层传输协议的一种传输层实现,默认实现在liquid/host/tcp包内。底层使用golang官方net库实现。
长安链支持自动发现、自动连接的组网方式,默认在线的每个节点都可以作为种子节点为其他节点提供网络发现服务,每个种子节点都会记录网内节点地址信息。当有新节点连接到某个种子节点时,新节点会向该种子节点查询网内其他可连接节点的地址,拿到其他节点地址后,新节点会主动尝试与这些节点建立连接;另外,种子节点在接受了新节点链接后,会通过网络发现服务将该新节点的地址通知给其他在线的种子节点,其他节点在获得该新节点地址后,也会主动尝试与该新节点建立连接。
验证区块:从节点在验证区块时会从交易池Get块中的交易,对存在于本节点交易池中的交易,Core模块只需比对块中交易和交易池中交易哈希是否一致即可(因为交易池已经做了相关检查),对于不在本节点交易池中的交易,Core模块则需要进行交易有效性检查和防重检查。验证区块有效后,Core模块会通知交易池将块中交易从待打包Queue队列中移至已打包Pending缓存中,此操作也是确保在MaxBFT共识下交易不会被重复打包。
#版本version:1.0.0#client配置client:#客户端默认使用的组织organization:Org1 logging:#sdk日志级别level:info tlsCerts:systemCertPool:false client:#用户TLS私钥路径 key:path:/release_path/config/fabric/crypto-config/peerOrganizations/org1.example.com/users/User1 org1.example.com/tls/client.key#用户TLS证书路径cert:
随机性调度算法:即针对同一批交易调度产生的交易执行顺序是随机的,即使同一节点针对同一批交易连续运行两次调度算法产生的结果也可能不同。此类算法往往调度速度较快,其难点在于验证节点如何保证执行顺序与提案节点一致并得到相同的执行结果。因此,交易的执行顺序必须打包至区块中并由其他节点据此验证。
用户合约在创建时,系统会自动创建一个新的数据库给该合约,所以不同的用户合约的状态数据以数据库进行区隔。在创建合约对应的数据库后,系统会执行合约init_contract函数中的SQL语句,包含非数据库事务的DDL语句,出于安全考虑,一个创建合约的交易或升级合约的交易将会被单独打包到区块中,不能与其他普通合约调用的交易一起打包。
SPV项目是ChainMaker的SPV轻节点,主要有两种模式,一种是spv模式,该模式支持ChainMaker(v2.0.0)和Fabric(v1.4.0+)两种链类型,该模式下将同步区块头及部分其他数据并通过同步的数据实现交易有效性的验证;另一种是light模式,该模式仅支持ChainMaker(v2.0.0),该模式下将同步区块头以及同组织内的交易信息,并支持用户注册回调,在区块被提交至本地数据库后执行。
存储模块中的Block DB、State DB、History DB等都是封装后的DB对象,其具体实现要基于特定的数据库引擎,比如LevelDB、BadgerDB、TikvDB、MySQL等数据库引擎。为了实现可插拔的数据库引擎,长安链在数据库引擎之上封装了一层接口,并将LevelDB、BadgerDB、TikvDB、MySQL等数据库封装成DB provider。用户可以根据业务需求选择合适的数据库引擎作为长安链的底层存储组件。
归档后的节点在对其他节点提供区块同步信息时,无法提供已归档的区块信息,所以在需要同步的节点选择连接的peer节点时,会只选择已归档高度比自己高度低的节点。如果是高度为1的全新节点,则只能从未归档的节点(peer)同步区块
tx_ids`longtext COLLATE utf8mb4_general_ci COMMENT'区块中交易ID列表',`additional_data`longblob COMMENT'区块产生以后附加的数据',PRIMARY KEY(`block_height`),KEY`idx_hash`(`block_hash`))ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
存储模块负责持久化存储链上的区块、交易、状态、历史读写集等账本数据,并对外提供上述数据的查询功能。区块链以区块为单位进行批量的数据提交,一次区块提交会涉及到多项账本数据的提交,比如:交易提交,状态数据修改等,所以存储模块需要维护账本数据的原子性。长安链支持常用的数据库来存储账本数据,如LevelDB、BadgerDB、TikvDB、MySQL等数据库,业务可选择其中任意一种数据库来部署区块链。
sdk_user_contract_claim_test.go func testUserContractClaimCreate(t *testing.T, client *ChainClient, admin1, admin2, admin3, admin4 *ChainClient, withSyncResult bool, isIgnoreSameContract bool) {
同步模块的消息handler 负责处理从 net 模块监听到的 NetMsg_SYNC_BLOCK_MSG 类型的消息 func (sync *BlockChainSyncServer) blockSyncMsgHandler(from string, msg []byte, msgType netPb.NetMsg_MsgType) error {
CreateChainConfigConsensusNodeIdUpdatePayload(nodeOrgId, nodeOldNodeId, nodeNewNodeId string) (*common.Payload, error) 1.4.3.18. 删除共识节点地址待签名payload生成
type BlockChainSyncServer struct { chainId string net protocol.NetService // 网络服务,向其他节点获取/发送数据,由外部模块提供实现
solidity合约内调用合约 ChainMaker evm虚拟机支持solidity合约动态调用solidity合约,solidity合约动态调用solidity合约,以及solidity合约动态调用其他类型合约。
泰山众筹模式在市场上的高活跃,首先可以证明着泰山众筹机制肯定是具备长久性,可持续性的优势,其市场也是已经有很多成功的新型电商消费平台,例如ck轻奢云,开心茶坊,共富,红辰乐购等都是借鉴泰山众筹模式打破了传统的消费逻辑,从“消耗式”消费转变为“增值性”消费,迎合了所有消费者的消费心理,让消费者真正参与到整个商品流通环节的利润分配中。
DAPP,是基于区块链的底层开发平台,被称为去中心化应用、分散式应用程序,所有数据都存储在分布式分类帐中。DApp自P2P网络开始以来就已经存在,其在不同计算机的P2P网络上运行,而不是在一台计算机上运行。DAPP旨在以不受任何单个实体控制的方式在网络上运行。
DAPP is the abbreviation of Decentralized Application,which is called Distributed Application/Decentralized Application in Chinese.Generally speaking,different DAPPs will adopt different underlying blockchain development platforms and consensus mechanisms,or issue tokens by themselves(or use univers
什么是去中心化系统? 去中心化,是互联网发展过程中形成的社会关系形态和内容产生形态,是相对于“中心化”而言的新型网络内容生产过程。在一个分布有众多节点的系统中,每个节点都具有高度自治的特征。节点之间彼此可以自由连接,形成新的连接单元。任何一个节点都可能成为阶段性的中心,但不具备强制性的中心控制功能。节点与节点之间的影响,会通过网络而形成非线性因果关系。这种开放式、扁平化、平等性的系统现象或结构,我们称之为去中心化
开发DAPP(去中心化应用)大致可分为四部分,首先开发智能合约,一般选择以太坊合约、bsc合约、tron合约建议采用solidity语言;接着部署智能合约,可先在测试网部署;然后,开发DAPP前端,一般采用VUE架构开发;最后,DAPP后端开发,一般需要后端作为辅助。
Pledge and liquid mining are well known.Recently,the two have been combined-liquid pledge and liquid pledge.The English name is Liquid Staging,which refers to the process in which users obtain liquidity through their pledged assets.Liquidity pledge allows investors to pledge their assets,and also al
什么是流动性挖矿? 流动性挖矿是基于AMM(自动做市商)原理开发的流动性挖矿产品,由不同的流动性池组成,每个流动性池中存在两种数字货币
Contract trading system is a digital asset derivative instrument.By judging the rise and fall,users can choose to buy long contracts or sell short contracts to gain income from the rise and fall of digital asset prices.The contract trading system adopts differential delivery.When the contract expire
Quantitative trading refers to the use of quantitative methods to formulate action plans and conduct trading.In the trading process,advanced mathematical models are used to quantify the disk data,replace artificial subjective judgment,repeatedly verify the historical data to find the"big probabilit