news 2026/5/13 12:06:14

fate隐私求交案例

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
fate隐私求交案例

intersect组件是解决纵向联邦学习中的隐私求交问题

fate隐私求交的方式有三种:raw,rsa,dh。raw方式不安全,rsa和dh方式是安全的,dh是基于对称加密的安全交集 rsa是基于RSA(非对称加密)的安全交集,,dh方法也用于安全的信息检索(SIR),fate intersect 支持多主机模式即(1个guest与多个host进行求交集)

可配置的hash方法有sha256、md5 和 sm3。raw交集支持base64编码,支持与缓存的交集。

统案例脚本文件:/data/projects/fate/examples/dsl/v2/

1、 1v1案例:

本次案例在guest执行任务,求交host

host

guest

数据文件名称

xxl_test_host.csv

xxl_test_guest.csv

表空间名称

sp_host

sp_guest

表名称

tb_host

tb_guest

/data/projects/fate/examples 目录创建测试目录,并拷贝系统配置

cd /data/projects/fate/examples/mytest cp /data/projects/fate/examples/dsl/v2/intersect/test_intersect_job_dsl.json ./ cp /data/projects/fate/examples/dsl/v2/intersect/test_intersect_job_raw_conf.json ./

1.1上传文件

1.1.1、host创建上传脚本:

upload_xxl_host.json

{ "file": "/data/projects/fate/examples/mytest/xxl_test_host.csv", "head": 1, "partition": 10, "work_mode": 0, "namespace": "sp_host", "table_name": "tb_host" }

xxl_test_host.csv 是数据文件(需要有表头)

namespace 表空间名称

table_name 表名称

1.1.2、guest创建脚本:

upload_xxl_guest.json

{ "file": "/data/projects/fate/examples/mytest/xxl_test_guest.csv", "head": 1, "partition": 10, "work_mode": 0, "namespace": "sp_guest", "table_name": "tb_guest" }
1.1.3上传文件

# host 端:
source /data/projects/fate/bin/init_env.sh
flow data upload -c upload_xxl_host.json

# guest端:
source /data/projects/fate/bin/init_env.sh
flow data upload -c upload_xxl_guest.json

1.2创建任务脚本

1.2.1、创建dsl文件

test_intersect_job_dsl.json

{ "components": { "reader_0": { "module": "Reader", "output": { "data": [ "data" ] } }, "data_transform_0": { "module": "DataTransform", "input": { "data": { "data": [ "reader_0.data" ] } }, "output": { "data": [ "data" ], "model": [ "model" ] } }, "intersect_0": { "module": "Intersection", "input": { "data": { "data": [ "data_transform_0.data" ] } }, "output": { "data": [ "data" ] } } } }
1.2.2、创建任务配置文件

test_intersect_job_rsa_conf.json

{ "dsl_version": 2, "initiator": { "role": "guest", "party_id": 9999 }, "role": { "guest": [ 9999 ], "host": [ 10000 ] }, "component_parameters": { "common": { "intersect_0": { "intersect_method": "rsa", "sync_intersect_ids": false, "only_output_key": true, "rsa_params": { "hash_method": "sha256", "final_hash_method": "sha256", "split_calculation": false, "key_length": 2048 } } }, "role": { "guest": { "0": { "reader_0": { "table": { "name": "tb_guest", "namespace": "sp_guest" } }, "data_transform_0": { "with_label": false, "output_format": "dense" } } }, "host": { "0": { "reader_0": { "table": { "name": "tb_host", "namespace": "sp_host" } }, "data_transform_0": { "with_label": false, "output_format": "dense" } } } } } }

1.3执行任务(guest端执行)

cd /data/projects/fate/examples/mytest
source /data/projects/fate/bin/init_env.sh
flow job submit -d test_intersect_job_dsl.json -c test_intersect_job_raw_conf.json

2、1v2案例

本次案例在guest上执行求交任务,求交host2个文件

2.1 上传文件

2.1.1 host创建上传脚本(2个):

upload_xxl_host.json

# 上传第一个文件:upload_xxl_host1.json { "file": "/data/projects/fate/examples/mytest/1v2/xxl_test_host1.csv", "head": 1, "partition": 10, "work_mode": 0, "namespace": "sp_host1", "table_name": "tb_host1" } # 上传第二个文件:upload_xxl_host2.json { "file": "/data/projects/fate/examples/mytest/xxl_test_host2.csv", "head": 1, "partition": 10, "work_mode": 0, "namespace": "sp_host2", "table_name": "tb_host2" }
2.1.2 guest创建脚本:

upload_xxl_guest.json

{ "file": "/data/projects/fate/examples/mytest/1v2/xxl_test_guest.csv", "head": 1, "partition": 10, "work_mode": 0, "namespace": "sp_guest1", "table_name": "tb_guest1" }
2.1.3 上传文件

# host 端:
source /data/projects/fate/bin/init_env.sh
cd /data/projects/fate/examples/mytest/1v2

flow data upload -c upload_xxl_host1.json

flow data upload -c upload_xxl_host2.json

# guest端:
source /data/projects/fate/bin/init_env.sh
cd /data/projects/fate/examples/mytest/1v2

flow data upload -c upload_xxl_guest.json

2.2 创建任务脚本

本次任务在guest上执行,任务脚本在guest端

2.2.1 创建dsl文件

test_union_job_dsl.json

{ "components": { "reader_0": { "module": "Reader", "output": { "data": [ "data" ] } }, "reader_1": { "module": "Reader", "output": { "data": [ "data" ] } }, "intersection_0": { "module": "Intersection", "input": { "data": { "data": [ "reader_0.data" ] } }, "output": { "data": [ "data" ] } }, "intersection_1": { "module": "Intersection", "input": { "data": { "data": [ "reader_1.data" ] } }, "output": { "data": [ "data" ] } }, "union_0": { "module": "Union", "input": { "data": { "data": [ "intersection_0.data", "intersection_1.data" ] } }, "output": { "data": [ "data" ] } } } }
2.2.2 创建任务配置文件

test_union_job_conf.json

注意:因为 guest 只有1个文件,host 有2个文件,guest 1个文件求交 host 2个文件,所以这里 guest 角色的 reader_ 和 reader_1 读取的数据都是 guest 同一个表的同一份数据

{ "dsl_version": 2, "initiator": { "role": "guest", "party_id": 9999 }, "role": { "host": [ 10000 ], "guest": [ 9999 ] }, "component_parameters": { "common": { "union_0": { "allow_missing": false, "need_run": true } }, "role": { "guest": { "0": { "reader_0": { "table": { "name": "tb_guest1", "namespace": "sp_guest1" } }, "reader_1": { "table": { "name": "tb_guest1", "namespace": "sp_guest1" } } } }, "host": { "0": { "reader_0": { "table": { "name": "tb_host1", "namespace": "sp_host1" } }, "reader_1": { "table": { "name": "tb_host2", "namespace": "sp_host2" } } } } } } }

2.3 执行任务(guest端执行)

cd /data/projects/fate/examples/mytest/1v2
source /data/projects/fate/bin/init_env.sh

flow job submit -d test_intersect_job_dsl.json -c test_intersect_job_raw_conf.json

正确求交页面显示:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/13 12:02:16

私有云时代来临:AI NAS如何重塑你的数字生活?

超越传统存储,打造你的私人云端 在信息爆炸的时代,随着个人存储需求的激增和变化,以及个体对数据隐私和安全性的日益重视,外加AI的技术加持,一种大家也许并不熟知的存储解决方案——NAS迎来了发展机遇。 NAS是Network …

作者头像 李华
网站建设 2026/5/13 11:58:36

msgp部署与集成:微服务架构中的完整应用指南

msgp部署与集成:微服务架构中的完整应用指南 【免费下载链接】msgp A Go code generator for MessagePack / msgpack.org[Go] 项目地址: https://gitcode.com/gh_mirrors/ms/msgp msgp是一款高效的Go代码生成工具,专为MessagePack序列化与反序列化…

作者头像 李华
网站建设 2026/5/13 11:55:57

从ResNet到ViT:手把手教你用Grad-CAM可视化不同视觉模型的‘注意力’

从ResNet到ViT:揭秘视觉模型注意力机制的实战对比 计算机视觉领域近年来经历了从卷积神经网络(CNN)到视觉Transformer(ViT)的范式转变。这种架构演进不仅改变了模型处理图像的方式,也重塑了我们理解模型决策…

作者头像 李华
网站建设 2026/5/13 11:52:58

Mac百度网盘SVIP破解终极指南:3步解锁无限下载速度

Mac百度网盘SVIP破解终极指南:3步解锁无限下载速度 【免费下载链接】BaiduNetdiskPlugin-macOS For macOS.百度网盘 破解SVIP、下载速度限制~ 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduNetdiskPlugin-macOS 还在为百度网盘的龟速下载而烦恼吗&…

作者头像 李华
网站建设 2026/5/13 11:50:33

Linux 设备树深度解析之Amlogic SoC 多媒体

第一部分:Amlogic Canvas —— 视频像素缓冲区元数据中间件1.1 设计精髓分析Amlogic Canvas本质上是一个硬件级别的像素缓冲区描述符池。它存储每个编号对应的宽度、高度、物理地址、包裹模式、块模式(GXBB及之后还支持端序)等元数据。视频解…

作者头像 李华