CubeAI 开源网络AI平台开源项目

我要开发同款
匿名用户2019年07月22日
38阅读
开发技术Java
所属分类人工智能
授权协议Apache

作品详情

CubeAI★智立方 是参考 LinuxAI基金会(LFAI)开源项目Acumos的设计理念,由中国联通网络技术研究院完全自主开发的集AI模型开发、模型共享和能力开放等功能于一体的开源网络AI平台。

CubeAI平台目前提供AI模型打包、模型导入、容器化封装、模型编排、模型发布、模型搜索、模型部署、AI能力开放、能力编排、能力演示等功能,支持AI模型的docker容器化封装和微服务化部署。

CubeAI致力于在AI模型开发者和模型的实际使用者之间架设一条互通的桥梁。开发者无需关心具体的部署环境,最终用户无需了解AI算法的具体实现细节,使得开发者和使用者能够专注于各自最擅长的领域进行创新,从而加速AI创新和应用进程,促进AI算法从设计、开发直到部署、应用整个生命周期的快速迭代和演进。

系统架构

本系统由AI建模、AI模型共享(AI商城)和AI能力开放三大平台组成。其中AI建模目前暂采用线下形式,使用Acumos提供的客户端工具来实现模型打包。

软件架构

本系统AI模型共享平台(AI商城)和AI能力开放平台基于SpringCloud微服务架构进行开发。前端采用Angular6.0框架实现,编程语言主要为TypeScript和HTML;后端采用SpringBoot框架实现,编程语言主要为Java。部分微服务初始代码框架采用Jhipster代码脚手架工具生成。

微服务基础组件Consul

使用Consul作为微服务注册/发现中心和数据配置中心。

API网关

API网关是一个特殊的微服务,用于为后端的业务应用微服务提供一个统一的访问入口,主要功能包括:HTTP路由,负载均衡,安全控制,QoS控制,接入控制,熔断机制等等。

本系统将API网关功能与采用Angular编写的前端Portal页面集成于同一个微服务之中,命名为:gateway。

uaa

uaa(用户认证授权中心)是一个特殊的微服务,为系统提供统一的安全控制服务,主要用于用户的认证、鉴权、授权,微服务的访问控制,以及基于角色的访问控制。

消息中间件

消息中间件由一组特殊的微服务组成,主要用于系统中微服务间异步数据和消息的高效传输和处理。本系统采用开源软件Kafka来作为消息中间件。

搜索/日志/可视化套件

搜索/日志/可视化采用ELK套件来实现。ELKStack构建在开源基础之上,能够安全可靠地获取微服务架构中任何来源、任何格式的数据,并且能够实时地对数据进行搜索、分析和可视化呈现。

CubeAI应用微服务Portal

前端采用Angular框架进行开发,将其代码托管于API网关所在的后端微服务gateway之中。

umm

AI模型管理。下挂一个MySql数据库,统一管理CubeAI应用中所有需要持久化的数据模型。

umu

AI模型导入。负责将建模阶段打包好的AI模型导入CubeAI平台,并生成docker形式的微服务镜像。

umo

AI模型编排。以可视化图形界面将多个基础模型组件组合编排成一个功能更为复杂的AI模型。

umd

AI模型部署。将CubeAI平台中已发布模型部署至Kubernetes云平台,以docker容器的方式运行,以RESTfulAPI的形式向用户提供AI能力开放接口。

ability

AI能力开放网关。对Kubernetes平台中docker容器提供的AI能力接口进行封装,增强API访问的安全性。

udemo

AI能力开放示范平台。为Kubernetes中已部署的部分典型AI开放能力接口提供图形化演示界面。

CubeAI应用支撑组件Nexus

提供用于存储AI模型相关构件和文档的文件服务器,以及用于存贮AI模型docker镜像的docker仓库。

Kubernates

AI模型部署目标平台,以docker容器形式为AI能力开放提供微服务化容器编排和调度平台。

开发环境

操作系统

Linux,建议Ubuntu16.04LTS

版本管理

git

JavaJDK

安装

#aptinstallopenjdk-8-jdk

配置环境变量:

exportJAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-amd64exportPATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/jre/bin

Javabuild工具

Maven

安装

#apt-getinstallmaven

查看maven版本号

#mvn--version

配置本地仓库

Maven缺省使用当前用户登录目录下的.m2目录作为本地仓库。

Node.js

从 https://nodejs.org/en/download/ 下载相应版本,拷贝至/opt。

解压,创建符号连接(用实际版本号替换以下版本号):

cd/opt#tar-xvfnode-v8.10.0-linux-x64.tar.xz#ln-snode-v8.10.0-linux-x64nodejs#ln-s/opt/nodejs/bin/node/usr/bin/node#ln-s/opt/nodejs/bin/npm/usr/bin/npm#node-v

前端build工具

Yarn

安装

#curl-sShttps://dl.yarnpkg.com/debian/pubkey.gpg|apt-keyadd-#echo"debhttps://dl.yarnpkg.com/debian/stablemain"|tee/etc/apt/sources.list.d/yarn.list#apt-getupdate#apt-getinstallyarn

微服务代码脚手架工具

JHipster

安装

#yarnglobaladdyo#yarnglobaladdgenerator-jhipster

Docker

卸载旧版本(如果非初次安装)

#apt-getremovedockerdocker-enginedocker.io

配置仓库

更新apt-get包索引

apt-getupdate

安装软件包使apt可使用HTTPS:

#apt-getinstallapt-transport-httpsca-certificatescurlsoftware-properties-common

添加Docker官方GPGkey:

#curl-fsSLhttps://download.docker.com/linux/ubuntu/gpg|apt-keyadd-

验证指纹,是否有9DC858229FC7DD38854AE2D88D81803C0EBFCD88

#apt-keyfingerprint0EBFCD88

Setupthestablerepository:

#add-apt-repository"deb[arch=amd64]https://download.docker.com/linux/ubuntu$(lsb_release-cs)stable"

安装DOCKERCE

#apt-getupdate#apt-getinstalldocker-ce

安装docker-compose

#apt-getinstalldocker-compose

验证安装成功:

#dockerrunhello-world

集成开发环境

建议:IdeaIntelliJ安装、开发和部署

代码下载

#gitclonehttps://github.com/cube-ai/cubeai.git

开发

参照docker/dev文件夹下的README文档,拉起平台开发需要依赖的所有基础微服务。

参照uaa、gateway、umm、umu、umd、ability等文件夹下的README文档,分别进行各微服务的开发调试。

部署

参照docker/prod文件夹下的README文档,对整个平台运行所需要的所有微服务进行部署。
声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论