百度區塊鏈所遇到的問題及處理彙總

前言

這篇文章說下使用百度鏈可能遇到的問題及解決辦法html

創世節點帳戶餘額最大值

cat data/config/xuper.json java

我隨便寫了一個值 239位node

而後查詢下餘額能夠查到算法

因此就認爲沒有最大值吧 設置爲多少就是多少嘍json

若要知道精確的 須要看下源碼數組

轉帳金額大小有限制嗎

./xchain-cli transfer --to XC1111111111111111@xuper --amount 2000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 安全

有點震驚吶 這麼大均可以轉帳 哈哈網絡

這個帳戶我也沒有建立 我直接往裏面轉帳 也是能夠的?併發

在轉帳的時候同時建立好了這個帳戶,但不是合約帳戶哦ide

普通帳戶和合約帳戶能夠是同一個帳戶名稱

咱們再來測試下哈

一、先給一個不存在的帳戶轉帳

此時會建立這個普通帳戶

二、在建立一個同名的合約帳戶

印證了上述的猜想

調用合約 保存K-V Key和Value長度有限制嗎

我測試的時候是用的36288長的字符串 是能夠的

若是是 36288*2 長度 java代碼已經不支持了 超過了java 字符串常量的長度

這裏科普下java的基本知識

`a、字符串變量:
String內部是以char數組的形式存儲,數組的長度是int類型,那麼String容許的最大長度就是Integer.MAX_VALUE = 2^zhi31 - 1 = 2147483647。又因爲java中的字符是以16位存儲的,所以大概須要4GB的內存才能存儲最大長度的字符串。
b、字符串常量:
如「abc」、」1234」之類寫在代碼中的字符串str,那麼容許的最大長度取決於字符串在常量池中的存儲大小,也就是字符串在class格式文件中的存儲格式:
CONSTANT_Utf8_info {
u1 tag;
u2 length;
u1 bytes[length];
}
u2是無符號的16位整數,所以理論上容許的string str的最大長度是2^16-1=65535。然而實際測試代表,容許的最大長度僅爲65534,超過就編譯錯誤。`

既然調用合約是經過java sdk調用 因此字符串最大不能超過java所支持的範圍

測試環境

2個出塊節點 1個同步節點

分別命名爲 節點1 節點2 節點3

建立一個合約帳戶並轉帳 看在其餘的節點是否有同步過去

  • 在節點2建立一個合約帳戶

使用節點1帳戶地址訪問節點2

經過java sdk 鏈接節點1 建立合約帳戶 XC1111111111116666@xuper

create account de1dc9e04a2d8b9bbf734f60431ab7eac5843f8711c3fe430c5df345dac272b8

  • 給該合約帳戶轉點錢

使用節點1的帳戶訪問節點2

transfer 3d6023d4a1ba08506fdd1e0ee0cc234f6d93f639a708e32ebe8d1d51d8272349

  • 分別查看節點一、節點二、節點3的該合約帳戶的餘額

節點1餘額查詢 1000000000

節點2餘額查詢 1000000000

節點3餘額查詢 1000000000

小結:在一個節點建立合約帳戶併發起轉帳交易 會同步給其餘的節點

部署合約看是否同步

  • 在一個節點部署一個合約

使用節點1的帳戶訪問節點3

./xchain-cli wasm deploy --account XC1111111111116666@xuper --cname hello_last_1 --fee 5574291 --runtime go /Users/mengfanxiao/Documents/project/company/XinPools_INFO/document/business/baidu/20200714-最新版本/xuperchain/core/contractsdk/go/example/eleccert_final/eleccert_final.wasm -a '{"creator":"mengfanxiao"}'

  • 在不一樣的節點分別調用該合約作交易

在節點1調用合約

`invoke txid: 60b4ee039415ed2e8880212cf182361143f314f988034a669aee5be2a9c6b02a
response:
gas: 100608`

在節點2調用合約

和節點1區別在於 key爲 mac1(這個合約的key是惟一的)

`invoke txid: 127ad9ea3c0071dad560fb189b6be054e9fde06dc07d2202171aed5a32f49d3b
response:
gas: 100609`

在節點3調用合約

和節點1區別在於 key爲 mac2

`invoke txid: 56cd4547e266423630b6db038692bb04f0730ea207b776f55654d7d0db705717
response:
gas: 100609`

小結:在一個節點部署合約 會同步給其餘的全部節點

  • 到不一樣的節點查看一個hash值 看是否都一致

好比查詢 60b4ee039415ed2e8880212cf182361143f314f988034a669aee5be2a9c6b02a

./xchain-cli tx query 60b4ee039415ed2e8880212cf182361143f314f988034a669aee5be2a9c6b02a

在節點一、節點二、節點3查詢的交易詳情內容一致

小結:在一個節點作的交易會同步給全部的節點

升級版本是否會影響到歷史數據

  • 方式一(不推薦 也不對)

目前我是用的master分支 但不是最新的

當前的區塊高度是605

那我想要升級到最新的master代碼

一、現將全部節點停掉

二、建立新的文件夾用來存放最新的版本

三、下拉最新的代碼並進行編譯

四、替換可執行文件

`cp -r output/* lastv-20200729/pn1
cp -r output/* lastv-20200729/pn2
cp -r output/* lastv-20200729/pn3`

五、將上一版本下的data和conf目錄替換到最新的

`cp -R pn1/data/ lastv-20200729/pn1/data
cp -R pn1/conf/ lastv-20200729/pn1/conf
cp -R pn2/data lastv-20200729/pn2/data
cp -R pn2/conf lastv-20200729/pn2/conf
cp -R pn3/data/ lastv-20200729/pn3/data
cp -R pn3/conf/ lastv-20200729/pn3/conf`

六、重啓

nohup ./xchain --vm ixvm &

節點1能夠啓動,但節點2啓動失敗 說明這種升級的方式不對

  • 方式二(推薦)

查看升級文檔 https://xuperchain.readthedoc..._guides.html#id2

我上面的思路是建立新的文件夾 將老版本數據複製到新文件夾中

官方文檔的思路是 將新的「plugins文件夾, 二進制文件xchain,xchain-cli」這些文件將老版本的替換掉 而後重啓便可

`cp -R output/plugins/ pn1/plugins/
cp -R output/xchain pn1/xchain
cp -R output/xchain-cli pn1/xchain-cli
cp -R output/plugins/ pn2/plugins/
cp -R output/xchain pn2/xchain
cp -R output/xchain-cli pn2/xchain-cli
cp -R output/plugins/ pn3/plugins/
cp -R output/xchain pn3/xchain
cp -R output/xchain-cli pn3/xchain-cli`

升級完成 保留了老數據

新增出塊節點 節點數據同步中

  • 如何新增節點

a、如果新增一個同步節點 不須要修改 創世塊配置 不須要刪除老數據 只須要修改 yaml文件便可 而後啓動便可

https://xuperchain.readthedocs.io/zh/latest/advanced_usage/multi-nodes.html?highlight=%E5%A2%9E%E5%8A%A0%E8%8A%82%E7%82%B9#id1

b、如果新增一個出塊節點 這個不只僅須要修改yaml文件還須要修改創世塊配置 因此須要刪除老數據

  • 系統如何選擇出塊節點

此時系統在選擇出塊節點的算法中會判斷該節點是否已同步完成 若已同步完成纔會選擇該節點做爲當前節點

  • 查詢請求過來如何處理

查詢的是當前同步到的狀態

  • 新搭的場景 出塊節點須要再創世快配置中配置 ;非新搭場景 添加一個出塊節點 先修改yaml文件 跑起來 而後進行token抵押 才能出塊

若一筆上鍊交易 在系統確認好一個出塊節點以後 若忽然這個節點掛掉了 此時系統是如何處理的這筆交易呢

若是發起一筆上鍊交易 交易在出塊前會在各個節點間轉發,該節點掛掉其它節點能夠繼續打包

如何使用xpos共識

加上這個配置就是使用xpos,也就是(tdpos+chainedBFT)

不加就是tdpos,不能保證安全性

若是經過sdk調用合約上鍊的時候 節點如果響應超時的話或由於網絡問題沒有收到響應 此時並無收到hash值

  • 交易hash沒有返回必定沒有上鍊,說明預執行失敗
  • 首先客戶端向節點發起交易預執行請求,預執行結束後會返回客戶端讀寫集,這時客戶端會在本地計算txhash,若是沒有獲得txhash說明交易根本不可能上鍊 計算txhash成功後,纔會將完整的tx發送至網絡

感謝

很是感謝百度鏈的技術大牛的支持 超哥

本文使用 mdnice 排版

相關文章
相關標籤/搜索