获赞
331
粉丝
70
关注
19
看过 TA
153
第一拖拉机制造厂拖拉机学院
2018
Java
IP属地:广东
暂未填写个人简介
私信
关注
当我们的canister比较多时,一个一个升级比较麻烦。或者如果我们canister是由root canister创建,我们不是controller时。以及我们需要分散权限,不想由某个人本地身份直接部署时。可以考虑使用该方法进行版本管理通过motoko语言我们需要 目标canister对应模块的最新wasm文件,并且canister创建时需要指定 调用升级api的模块为它的 controller.首先需要将ic-manage 声明复制到本地`https://github.com/johnxiaohe/ICP-Spark/blob/dev/src/spark_backend/management.mo`然后在负责升级的模块 声明IC管理模块客户端 和 升级方法```actor{    type Management = management.Management;    let mng : Management = actor("aaaaa-aa");    public shared func updatecodeWithoutArgs(wasm: [Nat8], cids:[Text]): async(Bool){        for(cid in Iter.fromArray(cids)){            await mng.install_code({                arg = to_candid();                wasm_module = wasm;                mode = #upgrade;                canister_id = Principal.fromText(cid);            });        };        return true;    };    public shared func updatecodeWithArgs(wasm: [Nat8], cids:[Text]): async(Bool){        for(cid in Iter.fromArray(cids)){            await mng.install_code({                arg = to_candid('arg1','arg2','arg3','arg4');                wasm_module = wasm;                mode = #upgrade;                canister_id = Principal.fromText(cid);            });        };        return true;    };}```wasm文件流可以通过js客户端获取wasm文件生成流,调用motoko canister来升级我们的 主canister 、 child canister当我们的child canister有很多动态的init参数,这时更新代码需要同样的init参数作为arg,可以使用下面的方法将参数按照顺序传入生成blob,```to_candid('arg1','arg2','arg3','arg4')```因为child的init参数是动态的,不可预知。建议由child canister提供 argsblob 接口,升级时通过接口获取该canister的init args blob信息感谢这些作者提供的思路https://forum.dfinity.org/t/encode-principal-to-candid-arguments/10465https://github.com/peterpeterparker/motoko_to_rust_migration/blob/1d51608bbea4f7257d6ed0916a5238d4427ec13b/src/motoko_to_rust_migration_backend/main.mohttps://forum.dfinity.org/t/need-help-implementing-install-code-canister-method/18313
0 点赞 评论 收藏
分享
我们如何通过不部署模块,获取该模块的wasm文件。比如这些模块是从Root Canister/ Parent Canister 创建/派生出来的,这些子模块有很多初始化参数,并且都有意义.我们无法通过 dfx deploy 创建该模块的Canister,或者我们需要构建一个无意义初始化参数创建一个无意义的Canister.我认为这些并不是必须的,我们只想将该模块代码打包 生成wasm文件用于更新线上canister。首先,我们需要在 `dfx.json` 文件声明子模块(并不是为了直接dfx deploy)```    "spark_user": {      "main": "src/spark_backend/user.mo",      "type": "motoko"    },```然后,我们启动本地dfx`dfx start --background --clean`我们需要执行canister创建命令,为子模块创建本地canister(只是为了有一个canisterid,否则无法build)`dfx canister create spark_user`执行完毕后,我们执行build命令即可生成wasm文件`dfx build spark_user`最终生成wasm文件路径(workdir: 项目根目录)`./.dfx/local/canisters/module-name/spark_user.wasm`使用场景:通过根模块自动生成创建的子模块,子模块无法直接deploy部署,但是需要它的wasm文件时
0 点赞 评论 收藏
分享

创作者周榜

更多
关注他的用户也关注了:
牛客网
牛客企业服务