Merge pull request #36 from jd-opensource/fix20260330 rm erp
Merge pull request #36 from jd-opensource/fix20260330
rm erp
随着生成式人工智能应用的广泛落地,内容安全、数据泄露、提示词攻击等风险也日益凸显。如何保障大模型输出符合法规要求、避免安全漏洞,已成为企业必须面对的关键挑战。为此,京东正式开源大模型安全框架——JoySafety,该框架在京东内部广泛应用,覆盖AI导购、物流客服、销售助手、医疗问诊、商家工作台、法务咨询、安全问答等场景,支持日均亿级调用、95%+攻击拦截率,致力于为企业提供一套成熟、可靠、免费的大模型安全防护方案。
企业级实战验证
高可靠性保障
灵活的架构设计
智能负载均衡
开箱即用
请确保已安装以下软件:
#1. git clone https://github.com/jd-opensource/JoySafety.git #2. 进入项目路径 cd JoySafety #3. 设置环境变量(建议复制执行,后续脚本/服务均可自动识别) export SAFETY_ROOT_PATH=`pwd` #正常为JoySafety 根路径 echo ${SAFETY_ROOT_PATH}
=======
模型说明
推荐使用 git-lfs 拉取大模型文件 ```shell
cd $SAFETY_ROOT_PATH
# git lfs install
git clone https://huggingface.co/jdopensource/JoySafety ${SAFETY_ROOT_PATH}/data/models
### 2. 配置 .env 文件 - 【在项目根路径】 **复制** `.env.example` 或手动创建 `.env`: ```shell # 注:切换Shell窗口, 重新设置SAFETY_ROOT_PATH cd $SAFETY_ROOT_PATH cp -f .env.example .env # 测试只需修改.env文件中变量:SAFETY_MODEL_DIR,路径需与模型实际下载路径一致【绝对路径】 SAFETY_MODEL_DIR=
docker-compose --env-file .env up
详细 API 测试案例及使用说明移步到 quickstart/README.md。
请参考 quickstart 目录下的文档,获取最新的 API 测试脚本和案例说明。
该项目可以同时支持多个业务,每个业务都可以动态增加,分钟级生效。 0. 注册原子能力(如果需要用的原子能力未注册过),可参考原子能力管理参考: function_api.md
一个完整的代码实例:example.py
识别策略整体是DAG,从rootId对应的node开始,逐层执行识别策略;策略的每个node分为两部分,function和router;function为当前结点执行的具体能力,router为基于当前结点的识别结果决定需要执行的下一个结点。
function类别包含single_label_pred(支持现成的两种开箱即用的实现)、keyword、kb_search、rag_answer、multi_turn_detect,配置方式和含义见上节如何接入一个业务中的完整实例,另外,还支持一个虚拟的类别parallel,以支持在单个node内多个function并行执行。
常用的router类别包括stupid_end和groovy,前者表示直接结束,后续是groovy脚本基于识别结果来返回一下步的node_id。groovy脚本中的内置变量是ctx,其结构见对象SessionContext.java。
ctx
比较典型的策略编排示例见:README.md
支持按分组+业务来管理敏感词,另外all业务下的敏感词对所有业务生效。
分组+业务
all
对敏感词的管理方式可以参考:sensitive_words_api.md
本项目对知识的管理是分两层的;第一层: 使用mysql数据库用于数据持久化以;第二层:使用safety_knowledge+vearch实现知识的向量化及语义检索。
知识在数据库的管理方式可以参考:knowledge_api.md;知识向量化及存储至vearch可以参考:[index_all.py](example/safety-skills/safety-knowledge/index_all.py)
参考 API 文档
多语言调用:
常见问题与解决方案见 FAQ
基于产品特性,项目中的示例仅用于产品功能说明使用,不得用于其他领域,非项目开发者观点。
最佳实践见best_practice.md
. ├── README.md ├── deploy │ ├── docker-compose.yml // 打包启动服务(各个模块也可以单独启动) │ └── thirdparty // 第三方依赖相关配置及文档 │ ├── mysql │ ├── redis │ └── vearch ├── safety │ ├── safety-admin // 用于管理配置和数据后台服务 │ ├── safety-api // 对外提供能力的api服务 │ ├── safety-basic // 核心jar包,服务于safety-admin、safety-basic及safety-demo中的java部分 │ ├── safety-demo // 使用safety-api的多语言示例 │ │ ├── golang │ │ ├── java │ │ └── python │ └── safety-skills // safety-api支持的各项技能实现及部署 │ ├── safety-bert // 用于部署bert模型的服务 │ ├── safety-fasttext // 用于部署fasttext模型的服务 │ ├── safety-keywords // 敏感词能力的实现 │ └── safety-knowledge // 支持知识检索、基于知识的代答以及多轮对话的检测 └── quickstart // 用于用户快速体验
仅涉及后台管理、原子能力注册、策略/业务场景配置、数据写入。用户/业务系统不参与,所有配置数据最终写入数据库,供执行时期加载。
flowchart TD Quickstart[quickstart/脚本] Admin[safety-admin后台管理] Bert[safety-bert独立服务] FastText[safety-fasttext独立服务] Keywords[safety-keywords独立服务] Knowledge[safety-knowledge独立服务] DB[(MySQL/Redis)] Vearch[(Vearch 向量库)] Strategy[防御策略编排] Business[业务场景配置] Quickstart-->|初始化/注册|Admin Admin-->|注册原子能力|Bert Admin-->|注册原子能力|FastText Admin-->|注册原子能力|Keywords Admin-->|注册原子能力|Knowledge Admin-->|敏感词管理|Keywords Admin-->|知识库管理|Knowledge Admin-->|配置写入|DB Admin-->|策略编排|Strategy Admin-->|业务场景配置|Business Bert-->|模型/配置|DB FastText-->|模型/配置|DB Keywords-->|敏感词数据|DB Knowledge-->|知识/配置|DB Knowledge-->|向量检索|Vearch
用户/业务系统发起请求,API服务加载数据库配置和策略,调用各 Skill 服务完成检测/处理。safety-admin 不参与执行链路,仅在配置时期写入数据。
flowchart TD User[用户/业务系统] API[safety-apiAPI服务] Core[safety-basicJava lib] Bert[safety-bert独立服务] FastText[safety-fasttext独立服务] Keywords[safety-keywords独立服务] Knowledge[safety-knowledge独立服务] DB[(MySQL/Redis)] Vearch[(Vearch 向量库)] User-->|HTTP/SDK|API API-->|依赖|Core API-->|读策略/配置|DB API-->|HTTP/RESTful|Bert API-->|HTTP/RESTful|FastText API-->|HTTP/RESTful|Keywords API-->|HTTP/RESTful|Knowledge Bert-->|模型/数据|DB FastText-->|模型/数据|DB Keywords-->|敏感词数据|DB Knowledge-->|知识/配置|DB Knowledge-->|向量检索|Vearch
模块依赖关系说明:
参考各个模块中的README文档
我们欢迎所有好想法和建议!如果您想成为项目的共建者,可随时提交 Pull Request,同时签署贡献者许可协议(CLA)。 有任何事宜可邮箱联系:org.joysafety1@jd.com。
本项目采用 Apache License 2.0 开源协议,欢迎企业和个人自由使用、修改和二次开发。
JoySafety旨在构建完整大模型安全解决方案,此次开源主要为大模型安全防护能力,后续将陆续推出:
安全审核大模型 在Huggingface平台开源部分安全审核大模型,后续Joysafety集成此系列模型实现大模型风险合规的审计能力
大模型安全评测:针对大模型应用上线前的安全风险检测,覆盖《生成式人工智能服务安全基本要求》中5大类31小类风险类型。
Agent安全防护:包括身份与权限管理、数据与记忆防护、工具与执行安全、MCP代码安全检测、供应链与协议安全等能力。
欢迎加入JoySafety官方微信交流群:
版权所有:中国计算机学会技术支持:开源发展技术委员会 京ICP备13000930号-9 京公网安备 11010802032778号
JoySafety —— 大模型安全框架
📋 目录
new release
项目简介
随着生成式人工智能应用的广泛落地,内容安全、数据泄露、提示词攻击等风险也日益凸显。如何保障大模型输出符合法规要求、避免安全漏洞,已成为企业必须面对的关键挑战。为此,京东正式开源大模型安全框架——JoySafety,该框架在京东内部广泛应用,覆盖AI导购、物流客服、销售助手、医疗问诊、商家工作台、法务咨询、安全问答等场景,支持日均亿级调用、95%+攻击拦截率,致力于为企业提供一套成熟、可靠、免费的大模型安全防护方案。
✨ 特性
🚀 生产级别
企业级实战验证
高可靠性保障
📈 高扩展性
灵活的架构设计
智能负载均衡
💡 易用性
开箱即用
🎯 核心技术亮点
突破性创新
1. 大模型多轮会话智能识别
2. 采用Free-Taxi异步输出模式,大幅提升检测响应, 实现用户体验与安全的完美平衡
3. 多维响应策略矩阵
🚀 快速开始
环境依赖
请确保已安装以下软件:
0. 克隆项目
=======
1. 下载模型文件(Huggingface)
模型说明
推荐使用 git-lfs 拉取大模型文件 ```shell
进入项目路径
cd $SAFETY_ROOT_PATH
# git lfs install
方案1
git clone https://huggingface.co/jdopensource/JoySafety ${SAFETY_ROOT_PATH}/data/models
方案2
因网络问题,您也可以从ModelScope下载)
3. 一键启动(Docker Compose)
4. API 测试
详细 API 测试案例及使用说明移步到 quickstart/README.md。
请参考 quickstart 目录下的文档,获取最新的 API 测试脚本和案例说明。
📖 使用指南
如何接入一个业务
一个完整的代码实例:example.py
如何配置策略(DAG)
识别策略整体是DAG,从rootId对应的node开始,逐层执行识别策略;策略的每个node分为两部分,function和router;function为当前结点执行的具体能力,router为基于当前结点的识别结果决定需要执行的下一个结点。
function类别包含single_label_pred(支持现成的两种开箱即用的实现)、keyword、kb_search、rag_answer、multi_turn_detect,配置方式和含义见上节如何接入一个业务中的完整实例,另外,还支持一个虚拟的类别parallel,以支持在单个node内多个function并行执行。
常用的router类别包括stupid_end和groovy,前者表示直接结束,后续是groovy脚本基于识别结果来返回一下步的node_id。groovy脚本中的内置变量是
ctx,其结构见对象SessionContext.java。比较典型的策略编排示例见:README.md
如何管理敏感词
支持按
分组+业务来管理敏感词,另外all业务下的敏感词对所有业务生效。对敏感词的管理方式可以参考:sensitive_words_api.md
如何管理知识库
本项目对知识的管理是分两层的;第一层: 使用mysql数据库用于数据持久化以;第二层:使用safety_knowledge+vearch实现知识的向量化及语义检索。
知识在数据库的管理方式可以参考:knowledge_api.md;知识向量化及存储至vearch可以参考:[index_all.py](example/safety-skills/safety-knowledge/index_all.py)
API 接口调用
参考 API 文档
多语言调用:
FAQ
常见问题与解决方案见 FAQ
基于产品特性,项目中的示例仅用于产品功能说明使用,不得用于其他领域,非项目开发者观点。
🏆最佳实践
最佳实践见best_practice.md
🏗️ 架构设计
项目目录结构
技术架构说明
1. 配置时期流程图
flowchart TD Quickstart[quickstart/脚本] Admin[safety-admin后台管理] Bert[safety-bert
独立服务] FastText[safety-fasttext
独立服务] Keywords[safety-keywords
独立服务] Knowledge[safety-knowledge
独立服务] DB[(MySQL/Redis)] Vearch[(Vearch 向量库)] Strategy[防御策略编排] Business[业务场景配置] Quickstart-->|初始化/注册|Admin Admin-->|注册原子能力|Bert Admin-->|注册原子能力|FastText Admin-->|注册原子能力|Keywords Admin-->|注册原子能力|Knowledge Admin-->|敏感词管理|Keywords Admin-->|知识库管理|Knowledge Admin-->|配置写入|DB Admin-->|策略编排|Strategy Admin-->|业务场景配置|Business Bert-->|模型/配置|DB FastText-->|模型/配置|DB Keywords-->|敏感词数据|DB Knowledge-->|知识/配置|DB Knowledge-->|向量检索|Vearch
2. 执行时期流程图
flowchart TD User[用户/业务系统] API[safety-apiAPI服务] Core[safety-basic
Java lib] Bert[safety-bert
独立服务] FastText[safety-fasttext
独立服务] Keywords[safety-keywords
独立服务] Knowledge[safety-knowledge
独立服务] DB[(MySQL/Redis)] Vearch[(Vearch 向量库)] User-->|HTTP/SDK|API API-->|依赖|Core API-->|读策略/配置|DB API-->|HTTP/RESTful|Bert API-->|HTTP/RESTful|FastText API-->|HTTP/RESTful|Keywords API-->|HTTP/RESTful|Knowledge Bert-->|模型/数据|DB FastText-->|模型/数据|DB Keywords-->|敏感词数据|DB Knowledge-->|知识/配置|DB Knowledge-->|向量检索|Vearch
模块依赖关系说明:
模块依赖关系说明:
主要模块说明
🛠️ 开发
参考各个模块中的README文档
🤝 贡献
我们欢迎所有好想法和建议!如果您想成为项目的共建者,可随时提交 Pull Request,同时签署贡献者许可协议(CLA)。 有任何事宜可邮箱联系:org.joysafety1@jd.com。
项目共建者
📄 许可证
本项目采用 Apache License 2.0 开源协议,欢迎企业和个人自由使用、修改和二次开发。
📅计划
JoySafety旨在构建完整大模型安全解决方案,此次开源主要为大模型安全防护能力,后续将陆续推出:
安全审核大模型 在Huggingface平台开源部分安全审核大模型,后续Joysafety集成此系列模型实现大模型风险合规的审计能力
大模型安全评测:针对大模型应用上线前的安全风险检测,覆盖《生成式人工智能服务安全基本要求》中5大类31小类风险类型。
Agent安全防护:包括身份与权限管理、数据与记忆防护、工具与执行安全、MCP代码安全检测、供应链与协议安全等能力。
欢迎加入JoySafety官方微信交流群:
Star History