0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

教你如何快速学习阿里云FaaS F2

YCqV_FPGA_EETre 来源:未知 作者:佚名 2017-10-31 16:02 次阅读

前言

阿里云虚拟化团队异构计算和高性能计算团队一直致力于将计算资源"平民化";平民化这个词我第一次是从高性能计算团队何万青老师那边听到的,他们在做的E-HPC就是要让所有云上用户都能够瞬间拥有一个小型的超算集群,使得使用超算不再仅仅是一些超算中心和高校的特权;我们异构计算团队则致力于将目前最快,最新的计算设备在云上提供给用户,之前的产品GPU云服务器EGS;大概半年前我们正式推出了FPGA云服务器FaaS;经过内测,公测,现在终于正式上线,用户只需要开通白名单就可以和使用ECS虚拟机一样使用FPGA资源了!

FaaS介绍

FaaS,全名FPGA as a Service,是一种在云上使用FPGA的方式;我们现在支持两种不同的实例,分别为:

实例型号 FPGA型号
F1 intel A10
F2 Xilinx ku115

F2从入门到放弃

准备

新建子帐号(可选)

建议用户新建一个子帐号,并使用子帐号来操作阿里云资源,通过授权子帐号必要的权限,来保证安全!

1. 登陆阿里云RAM控制台

2. 在左侧边栏位置选择[用户管理] -> [新建用户]

3. 在弹出的创建用户的表单中填写:用户名,显示名,邮箱,电话等信息,**选中为该用户自动生成AccessKey**,点击确定

4. 在弹出的窗口中保存用户的AK/AS,这里请一定要记住AK/AS,后续操作都会需要用到这个信息!

5. 至此,RAM子帐号已经创建好,接下来需要给该子帐号授权!

6. 在RAM控制台里,选中左侧的[用户管理]标签,可以看到刚刚新建的RAM子帐号,点击[授权]按钮,进行子帐号授权

7. 至少给该子帐号授予如下权限:AliyunOSSFullAccess, AliyunECSFullAccess, AliyunRAMFullAccess & AliyunSTSAssumeRoleAccess;选中后点击确定即可

开通OSS,并创建一个专用的bucket

FaaS的镜像相关操作依赖于阿里云OSS存储,因此用户必须开通OSS服务;同时我们建议用户新建一个专有的bucket,用来存储您自己的FPGA镜像中间结果

开通OSS(如果已经开通请忽略这一步)

1. 登陆OSS售卖页面,点击立即开通

在华东1区新建一个bucket

建议用户新建一个bucket,专门用于FaaS服务,因此这个bucket会对aliyun官方管理帐号开通读写权限,因此不建议用户存储和FaaS不相关内容;**请记住这个bucket名字,在后续操作中会经常用到**

1. 登陆OSS管理控制台

2. 点击左上方的"+"号,新建一个bucket

3. 在右侧弹出的对话框中给这个bucket起一个名字,选择区域为**华东1**,点击确定

4. 可以在左侧看到刚刚创建的bucket

购买To 预算比较紧张,购买按量付费的用户: 考虑到F2实例价格比普通ECS价格高一些,因此建议用户在调试,编译阶段采用普通ECS;建议使用阿里云计算型实例,4核以上;在完成调试和编译后,真正需要下载到FPGA里运行时,再购买F2实例;

1. 目前购买F2实例仍然需要开白名单,请用户提工单(或者联系阿里云BD)提供自己的阿里云帐号

2. 开通白名单后,在阿里云官网购买页面直接购买,请选择华东1,可用区B,VPC网络;F2目前支持**按量付费**和**包年包月**两种售卖方式;实例规格请选择**异构计算**,**FPGA计算型**

3. Xilinx的开发环境,我们准备了一个镜像,用户直接使用该镜像创建实例即可;该镜像后期会在镜像市场免费提供给用户,目前还只能通过共享镜像的方式提供,因此用户在选择镜像时,请选择**共享镜像**;如果在共享镜像里看不到镜像,需要提工单(或者联系阿里云BD)

F2 实例OpenCL开发最佳实践

这里我们以使用普通计算型实例做编译和仿真,以F2实例作为最终运行为例;当然,编译和仿真也完全可以在F2实例上完成,这样更简单编译,仿真

对于按量用户,建议使用更加便宜的普通ECS实例(建议使用计算型4核以上实例)进行编译和仿真,因为这时候不需要真正使用到FPGA;购买普通ECS实例和购买F2实例类似,只是在选择实例规格时,选择型号不同,但是**依然要使用我们共享的镜像**

1. 首先配置SDx环境 source /opt/Xilinx/SDx/2017.2/settings64.sh2. 运行SDx自带demo:cd /opt/Xilinx/SDx/2017.2/examples/vadd

查看在当前目录下sdaccel.mk里面的platform(第60行)是否为XDEVICE=xilinx_kcu1500_4ddr-xpr_4_0

改common.mk文件vim ../common/common.mk

把第61行CLCC_OPT += $(CLCC_OPT_LEVEL) ${DEVICE_REPO_OPT} --platform ${XDEVICE} -o ${XCLBIN} ${KERNEL_DEFS} ${KERNEL_INCS}

改成CLCC_OPT += $(CLCC_OPT_LEVEL) ${DEVICE_REPO_OPT} --platform ${XDEVICE} -o ${XCLBIN} ${KERNEL_DEFS} ${KERNEL_INCS} --xp param:compiler.acceleratorBinaryContent=dcp

软件仿真make -f sdaccel.mk run_cpu_em

看结果是否PASSED

直接运行export XCL_EMULATION_MODE=true #一定要设置这个环境变量,不然会报错,找不到设备./vadd bin_vadd_cpu_emu.xclbin#如果报如下错:Error: Unable to find Target Device xilinx_kcu1500_4ddr-xpr_4_0;请检查XCL_EMULATION_MODE是否为true,如果没有,请设置:export XCL_EMULATION_MODE=true

硬件仿真make -f sdaccel.mk cleanallmake -f sdaccel.mk run_hw_em

看仿真结果是否PASSED

直接运行export XCL_EMULATION_MODE=true #一定要设置这个环境变量,不然会报错,找不到设备./vadd bin_vadd_cpu_emu.xclbin#如果报如下错:Error: Unable to find Target Device xilinx_kcu1500_4ddr-xpr_4_0;请检查XCL_EMULATION_MODE是否为true,如果没有,请设置:export XCL_EMULATION_MODE=true

编译make -f sdaccel.mk cleanallmake -f sdaccel.mk xbin_hw

//其他一些操作/*make -f sdaccel.mk xbin_hw #生成最终的二进制文件,时间比较长,差不多4个小时才能完成make -f ./sdaccel.mk help #查看帮助文档#Compile and run CPU emulation using default xilinx:adm-pcie-7v3:1ddr:3.0 DSAmake -f sdaccel.mk run_cpu_em //即:软件仿真#Compile and run hardware emulation using default xilinx:adm-pcie-7v3:1ddr:3.0 DSAmake -f sdaccel.mk run_hw_em //硬件仿真#Compile host executable onlymake -f sdaccel.mk host //只编译host代码#Compile XCLBIN file for system run onlymake -f sdaccel.mk xbin_hw //这个最重要,编译生成可以下载到FPGA内的二进制文件#Clean working diretory#make -f sdaccel.mk clean#Super clean working directory#make -f sdaccel.mk cleanall*/

ps:此处编译的时间会比较久,建议通过screen或者nohub等方式,防止ssh timeout退出。

3. 配置安全烧写环境

source /root/xbinst_oem/F2_env_setup.shfaascmd config --id=--key=#id/key为阿里云accessID/accessKey,上述新建子帐号曾经保存过

faascmd auth --bucket=#新建的OSS bucket 名字

4. 编译成功后打包结

#如果/root/xbinst_oem/目录里没有sdaccel_package.sh,先下载:wgethttp://fpga-tools.oss-cn-shanghai.aliyuncs.com/sdaccel_package.sh/root/xbinst_oem/sdaccel_package.sh -xclbin=/opt/Xilinx/SDx/2017.2/examples/vadd/bin_vadd_cpu_emu.xclbin

5. 上传压缩包到自己的OSS指定的bucket

faascmd upload_object --object=<在bucket中名字,建议和file一致> --file=<打包生成的结果,一个tar包>

6. 新建一个可以在F2上运行的FPGA image

faascmd create_image --object=<在bucket中名字,建议和file一致> --fpgatype=xilinx --name=hereIsFPGAImageName --tags=hereIsFPGAImageTag --encrypted=false --shell=V1.0

7. 查看fpga image是否已经可以下载

我们看到状态已经是success,可以下载了。记下FPGAIamgeUUID,一会下载的时候需要用

下载

如何编译和仿真是在另外一台ECS上完成的,这里首先要购买一台F2实例;具体的购买过程参考**购买**章节

1. 首先配置安全烧写环境(如果之前已经设置过,跳过)source /root/xbinst_oem/F2_env_setup.sh

faascmd config --id=--key=#id/key为阿里云accessID/accessKey,上述新建子帐号曾经保存过

faascmd auth --bucket=#新建的OSS bucket 名字

2. 获取fpgauuidfaascmd list_instances --instanceId=hereIsYourInstanceIdvm instance Id:可以在阿里云控制台找到

3. 下载fpga imagefaascmd download_image --instanceId=hereIsYourInstanceId --fpgauuid=hereIsFpgaUUID --fpgatype=xilinx --imageuuid=hereIsImageUUID --imagetype=afu --shell=V1.0

4. 查看是否下载成功faascmd fpga_status --fpgauuid=hereIsFpgaUUID --instanceId=hereIsYourInstanceId

板卡上的FpgaImageUUID已经跟需要下载的image一致,并且TaskStatus已经valid,说明下载已经成功。

5.跑host程序

make -f sdaccel.mk hostunset XILINX_SDX./vadd bin_vadd_hw.xclbin


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

原文标题:FPGA资源平民化 - 阿里云FaaS F2使用指南

文章出处:【微信号:FPGA-EETrend,微信公众号:FPGA开发圈】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    CW3005F/CW3005FAAS赛微双通道USB识别快充方案全方位设计资料

    ,对其进行自动检测以提供更加快速的充电过程。 CW3005FAAS/CW3005F适用于所有USB接口的充电器产品和墙上适配器,该集成电路能够提供具有应用在D+/D-点上高达+/-8kV 的静电保护
    发表于 12-14 16:50

    学习阿里架构选择哪家培训机构好?

      学习阿里架构选择哪家培训机构好?在这个问题上,我们一定要加以重视,千万不能盲目选择。一方面浪费金钱,另一方面更耗费我们的时间和精力。如果您有意向学习,也可以走进老男孩教育课堂免费
    发表于 12-20 15:31

    FaaS如何在2.0时代发挥优势,又将走向何方?

    推动业务能力的化,计算进入2.0时代。12月19日的阿里云栖大会上,阿里函数计算负责人杨皓然做了主题为“触摸云端编程之道——利用函数计
    发表于 01-24 16:09

    【FPGA-F3】阿里FAAS平台,极大简化FPGA开发部署流程

    摘要: 阿里FPGA服务器平台FaaS(FPGA as a Service)在云端提供统一硬件平台与中间件,可大大降低加速器的开发与部署成本。普惠开发者FPGA (现场可编程门阵列)由于其硬件并行
    发表于 05-17 20:17

    支持阿里Link物联网平台的CC2640R2F解决方案

    ,结合阿里Link物联网平台旗下阿里智能APP SDK,帮助开发人员快速而安全的开发出产品,并保证产品的稳定性。TI基于CC2640R2F
    发表于 03-19 06:45

    基于CC2640R2F的SDK支持阿里Link物联网平台

    上?是否想在节省时间的同时,便捷地获取更加强大的功能、稳定性和多重云端安全保障?德州仪器(TI)的CC2640R2F解决方案支持阿里Link物联网平台,结合阿里
    发表于 07-15 06:51

    F2产品技术培训_4.CRC

    F2产品技术培训_4.CRC
    发表于 03-15 15:07 1次下载

    F2产品技术培训_20.SDIO

    F2产品技术培训_20.SDIO
    发表于 03-15 14:34 1次下载

    F2产品技术培训_19.SPI

    F2产品技术培训_19.SPI
    发表于 03-15 14:32 12次下载

    阿里FaaS F2使用教程

    阿里虚拟化团队异构计算和高性能计算团队一直致力于将计算资源平民化;平民化这个词我第一次是从高性能计算团队何万青老师那边听到的,他们在做的E-HPC就是要让所有上用户都能够瞬间拥有一个小型的超算
    发表于 11-15 11:25 2736次阅读
    <b class='flag-5'>阿里</b><b class='flag-5'>云</b><b class='flag-5'>FaaS</b> <b class='flag-5'>F2</b>使用教程

    向您介绍 STM32 F2 系列

    意法半导体STM32 F2 系列介绍.
    的头像 发表于 06-22 17:10 4543次阅读

    大神F2联通版性能怎么样

    8月26日大神在北京国家会议中心举办发布会,发布了大神F2,尽管没有采用传说中的MT6595芯片,但是8和4G承诺还是如期而至,从过去这两个月的销量来看,大神F2还是得到了市场的认可,为了满足网友不通的网络需求,采用了高通615方案的大神
    的头像 发表于 12-17 11:16 1742次阅读

    赛灵思支持阿里加速机器学习和其他关键计算工作负载

    CPU 的架构,并可以协同服务器 CPU 一起提供性能和功耗效率。据阿里最近发布的数据显示,其 F2 实例的处理效率比 CPU 高达 30 倍,实现了更具成本效益的解决方案。
    的头像 发表于 07-29 14:04 1677次阅读

    POCO F2处理器和屏幕参数曝光

    早在2020年年中,POCO品牌就在印度地区发布了POCO F2 Pro手机。但是,在网上曝光了很久的POCO F2手机却没有太多消息。1月4日,据91mobiles报道,POCO在官方那个推特账号上确定了这款手机“POCO F2
    的头像 发表于 01-05 10:44 1921次阅读

    预涂相变材料的 F1 和 F2 模块

    预涂相变材料的 F1 和 F2 模块
    发表于 11-15 20:10 0次下载
    预涂相变材料的 <b class='flag-5'>F</b>1 和 <b class='flag-5'>F2</b> 模块