這篇“EOSIO區(qū)塊鏈的通信模型是什么”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“EOSIO區(qū)塊鏈的通信模型是什么”文章吧。
榆社ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!
每個EOS智能合約都有一組操作和類型。action
表示單個操作。你可以將其視為JavaScript中的函數(shù)或C#中的方法。type
定義合約中使用的所需內(nèi)容和結(jié)構(gòu)。大多數(shù)時候我們將它們用于我們的表。
EOSIO中的合約可以相互通信。它是通過基于消息的通信架構(gòu)實現(xiàn)的。
EOS通信模型就是他們溝通的方式。通信模型有兩種類型:Inline Communication Model(內(nèi)聯(lián)通信模型)和Deferred Communication Model(延時通信模型)。
內(nèi)聯(lián)操作是內(nèi)聯(lián)通信模型的一部分。如果你了解它們,就能理解內(nèi)聯(lián)通信。
我們來看看下圖:
用戶從智能合約A執(zhí)行操作(Action #1)。當(dāng)操作開始執(zhí)行時,它會觸發(fā)另外兩個操作:來自智能合約B的操作Action #1.1和來自智能合約C的操作Action #1.2。一切都在當(dāng)前交易中完成。
在當(dāng)前交易中執(zhí)行并與其完成相關(guān)的操作,稱為inline action
即內(nèi)聯(lián)操作。
重要的是要記住內(nèi)聯(lián)操作是作為調(diào)用操作的一部分執(zhí)行的。因此,它們與原始交易的范圍和權(quán)限相同。這是他們將被執(zhí)行的保證。如果其中一個操作失敗,則整個交易將失敗。
所以,你應(yīng)該已經(jīng)知道內(nèi)聯(lián)通信是什么意思了吧。
請求將執(zhí)行操作作為調(diào)用操作的一部分是inline communication
即內(nèi)聯(lián)通信的示例。
第二種類型是延時通信模型。表示模型的延時操作非常有趣,因為它們不在同一交易中執(zhí)行。我們來看看下圖:
我們有相同的交易工作流程。這里唯一的區(qū)別是從智能合約C執(zhí)行的第二個操作不是內(nèi)聯(lián)而是延時。延時操作計劃在將來運行。
根據(jù)生產(chǎn)者的判斷,延時的操作最好可以安排在稍后的時間運行。無法保證延期操作將執(zhí)行。
即使它們不屬于同一交易,它們也具有發(fā)送它們的合約的權(quán)限。
所以基本上,延時通信在概念上采用發(fā)送給對等交易的操作通知的形式。
在繼續(xù)演示之前,讓我們檢查一些有趣的東西。
在EOSIO中,交易和操作之間存在差異。操作表示單個操作,而交易是一個或多個操作的集合。
交易可以包含N個操作。但是,每個交易必須在30ms或更短
的時間內(nèi)執(zhí)行。如果交易包含多個操作,并且這些操作的總和大于30毫秒,則整個交易將失敗。
我們要做個機器人。你可以在我們的GitHub中找到包含所有智能合約和代碼的項目。
作為一家創(chuàng)造未來的機器人公司,我們希望一切都是完美的。新建新的機器人時,應(yīng)發(fā)送出售信息,并在終端上打印相關(guān)信息。為了實現(xiàn)這三個操作,我們將使用內(nèi)聯(lián)操作。
看一下下面的代碼片段。
void RobotFactory::create(account_name account, robot newRobot) { robotIndex robots(_self, _self); auto iterator = robots.find(newRobot.series_number); eosio_assert(iterator == robots.end(), "Robot with this series number already exists"); robots.emplace(account, [&](auto& robot) { robot.series_number = newRobot.series_number; robot.model = newRobot.model; robot.operating_system = newRobot.operating_system; robot.profession = newRobot.profession; robot.owner = name{account}.to_string(); robot.manufactured = now(); }); // Execute INLINE ACTION from another contract // action({permission_level}, {contract_deployer}, {contract_action}, {data_to_pass}).send(); action(permission_level(account, N(active)), N(market), N(forsale), make_tuple(account, newRobot.series_number, newRobot.model, newRobot.manufactured )).send(); // Execute INLINE ACTION from another contract // action({permission_level}, {contract_deployer}, {contract_action}, {data_to_pass}).send(); action(permission_level(account, N(active)), N(messenger), N(printmessage), make_tuple(newRobot.model)).send(); }
首先,我們開始創(chuàng)建一個新的機器人。操作完成后,它將出現(xiàn)第一個內(nèi)聯(lián)操作。我們讓發(fā)送機器人一個出售信息,所以我們要求RobotMarketplace
智能合約的forsale
。
請注意,當(dāng)我們要求智能合約A從智能合約B執(zhí)行操作時,應(yīng)首先添加適當(dāng)?shù)臋?quán)限。我們將在下一部分介紹,目前,請務(wù)必遵循README.md中的指南。
第一個內(nèi)聯(lián)操作完成后,第二個內(nèi)聯(lián)操作就會完成。這次我們從Messenger
智能合約中請求printmessage
。 同樣應(yīng)該添加適當(dāng)?shù)臋?quán)限。
在這兩種情況下,當(dāng)我們通過終端執(zhí)行創(chuàng)建操作時,我們已收到操作已完成(或失?。┑耐ㄖ?。
cleos push action weyland create '{"account":"weyland","newRobot":{"series_number":14441992,"model":"A330","operating_system":"DX42","profession":"engineer","owner":"","manufactured":0}}' -p weyland executed transaction: 9874a8a5f516ca540c44cafd8b9b371c856fe7958be1fc6268641cc7ab67fdaf 136 bytes 6000 us # weyland <= weyland::create {"account":"weyland","newRobot":{"series_number":14441992,"model":"A330","operating_system":"DX42",... # market <= market::forsale {"account":"weyland","robotForSale":{"series_number":14441992,"model":"A330","manufactured":0}} # messenger <= messenger::printmessage {"message":"A330"} >> ==== For sale | Robot model: A330
讓我們將printmessage
操作從內(nèi)聯(lián)更改為延時。為此,我們需要使用EOSIO的transaction.hpp
標(biāo)頭。
void RobotFactory::create(account_name account, robot newRobot) { robotIndex robots(_self, _self); auto iterator = robots.find(newRobot.series_number); eosio_assert(iterator == robots.end(), "Robot with this series number already exists"); robots.emplace(account, [&](auto& robot) { robot.series_number = newRobot.series_number; robot.model = newRobot.model; robot.operating_system = newRobot.operating_system; robot.profession = newRobot.profession; robot.owner = name{account}.to_string(); robot.manufactured = now(); }); // Execute inline action from another contract // action({permission_level}, {contract_deployer}, {contract_action}, {data_to_pass}).send(); action(permission_level(account, N(active)), N(market), N(forsale), make_tuple(account, newRobot.series_number, newRobot.model, newRobot.manufactured )).send(); // Execute DEFERRED ACTION from another contract eosio::transaction tx; tx.actions.emplace_back(permission_level{account, N(active)}, N(messenger), N(printmessage), make_tuple(newRobot.model)); tx.delay_sec = 12; tx.send(N(newRobot.model), account); }
要創(chuàng)建延時交易,我們首先從類型交易聲明一個變量tx
。然后我們在其操作集合中添加一個新操作。我們可以選擇設(shè)置延時。如果它為0,則延時交易將在調(diào)用之后立即進行。
設(shè)置完所有后,我們只需調(diào)用send方法即可。
但是,不保證將執(zhí)行延時交易。此外,我們不會像在內(nèi)聯(lián)操作中那樣收到有關(guān)其成功或失敗的任何通知。
cleos push action weyland1 create '{"account":"weyland1","newRobot":{"series_number":14441993,"model":"A330","operating_system":"DX42","profession":"engineer","owner":"","manufactured":0}}' -p weyland1 executed transaction: 5f45b48877aac9d03172616a2443b7a9079ee9f74a124a0976d2fcf0b756e985 176 bytes 2722 us # weyland1 <= weyland1::create {"account":"weyland1","newRobot":{"series_number":14441993,"model":"A330","operating_system":"DX42",... # market <= market::forsale {"account":"weyland1","robotForSale":{"series_number":14441993,"model":"A330","manufactured":0}} # No notification for printmessage action
正如你在12秒后看到的那樣,執(zhí)行延時交易。
以上就是關(guān)于“EOSIO區(qū)塊鏈的通信模型是什么”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。