函数工作流 FunctionGraph
函数工作流 FunctionGraph
- 最新动态
- 功能总览
- 产品介绍
- 计费说明
- 快速入门
- 用户指南
-
最佳实践
- FunctionGraph最佳实践汇总
-
数据处理类实践
- 使用FunctionGraph函数对OBS中的图片进行压缩
- 使用FunctionGraph函数为OBS中的图片打水印
- 使用FunctionGraph函数对DIS数据进行格式转换并存储到CloudTable
- 使用FunctionGraph函数实现通过API方式上传文件
- 使用FunctionGraph函数对IoTDA中的设备坐标数据进行转换
- 使用FunctionGraph函数对OBS中的文件进行加解密
- 使用FunctionGraph函数识别LTS中的异常业务日志并存储到OBS
- 使用FunctionGraph函数对LTS中的日志进行实时过滤
- 使用FunctionGraph函数流对OBS中的图片进行旋转
- 使用FunctionGraph函数流对图片进行压缩和打水印
- 功能应用类实践
- 函数构建类实践
- 开发指南
- API参考
- SDK参考
- 场景代码示例
-
常见问题
-
产品咨询
- 使用FunctionGraph是否需要开通计算、存储、网络等服务?
- 使用FunctionGraph开发程序之后是否需要部署?
- FunctionGraph为函数分配的磁盘空间有多少?
- 是否支持在函数中启动TCP的监听端口,通过EIP接收外部发送过来的TCP请求?
- 函数发起HTTP请求的源地址如何获取?
- FunctionGraph是否支持对上传的zip文件进行反编译?
- FunctionGraph的函数是否支持功能扩展?
- FunctionGraph中的代码是如何隔离的?
- 函数常规信息中的“应用”如何理解?
- 用户需要为函数的冷启动时间付费吗?
- 函数计费中的调用次数,是某一账号下在不同region的所有函数的调用次数总和吗?
- Python语言的函数从V1版本迁移到V2版本时需注意哪些兼容性问题?
- FunctionGraph函数支持哪些编程语言?
- 创建函数
-
配置函数
- 能否在函数环境变量中存储敏感信息?
- FunctionGraph的函数如何读写上传的文件?
- 为函数挂载文件系统时,报“failed to mount exist system path”
- FunctionGraph如何实现域名解析?
- FunctionGraph如何通过域名访问专享版APIG中注册的接口?
- FunctionGraph函数通过域名访问APIG中注册的接口时,报域名无法解析?
- 使用定制运行时语言的函数能操作哪些目录?
- FunctionGraph的函数支持哪些中文字体?
- 能否在函数代码中使用线程和进程?
- 函数如何访问MySQL数据库?
- 函数无法通过VPC连接对应的Redis?
- 如何读取函数的请求头?
- Python语言的函数中,中文注释报乱码错误
-
调用函数
- FunctionGraph的函数执行需要多长时间?
- FunctionGraph的函数执行包含了哪些过程?
- FunctionGraph函数长时间不执行时,相关的实例会如何处理?
- 如何获取函数运行过程中的内存使用量信息?
- 为什么首次调用函数时速度会比较慢?
- 为什么函数实际使用内存大于预估内存,甚至触发内存溢出OOM?
- 函数执行失败返回“runtime memory limit exceeded”时,如何查看内存占用大小?
- 自定义镜像函数执行失败报“CrashLoopBackOff”
- 同步调用函数时,未收到调用响应的可能原因?
- 函数中os.system("command &")命令的执行日志未采集,应如何处理?
- 函数执行超时的可能原因有哪些?
- 使用APIG触发器调用一个返回String的FunctionGraph函数时,报500错误
- Python2.7在执行reload(sys)后无法通过print打印日志
- 运行函数时报错error while loading shared libraries时如何处理?
- 配置触发器
- 配置依赖包
-
产品咨询
- 视频帮助
- 文档下载
- 通用参考
文档首页/
函数工作流 FunctionGraph/
最佳实践/
功能应用类实践/
使用FunctionGraph部署AI对话ChatGLM3应用/
进阶使用:使用ECS作为NFS服务器实现多用户资源隔离
更新时间:2025-02-08 GMT+08:00
链接复制成功!
进阶使用:使用ECS作为NFS服务器实现多用户资源隔离
应用场景
FunctionGraph的函数除了支持挂载弹性文件系统SFS外,也支持挂载ECS服务器共享出的NFS共享路径。在多用户使用场景下,使用ECS能够有效地进行多用户的资源管理,通过配置特定的权限,满足用户之间需要强隔离的使用需求。
前提条件
- 每位用户均需完成部署AI对话ChatGLM3准备工作,委托中包含“SWR Admin”、“VPC Administrator”、“Server Administrator”、“SFS FullAccess”和“SFS Turbo FullAccess”权限。
- 每位用户均需完成部署和使用AI对话ChatGLM3应用步骤,应用创建成功。
步骤一:购买ECS服务器
进入购买ECS服务器页面,购买过程中请参照以下注意事项。实例类型可根据业务需要自行选择,其他参数可参考设置ECS购买参数。
- 基础配置:如图1所示,本示例使用“按需计费”,区域选择“华东-上海一”。
- 操作系统:本示例镜像选用EulerOS 2.5 64bit(40GiB)。
不同镜像版本下,部分Linux命令可能存在差异。
- 储存与备份:鉴于多数模型文件的大小在1GB到10GB以上,建议依据具体需求选择系统盘容量,并参考图2新增数据盘进行挂载。
- 网络:虚拟私有云与主网卡请选择创建虚拟私有云VPC和子网中所创建VPC与子网,如图3所示。
- 安全组:请参考图4新建安全组,入方向规则允许子网内IP访问端口111、2049、2051、2052、20048以支持NFS服务;其他端口,如22端口用于SSH和SFTP、21端口用于FTP等,具体协议端口和源地址请根据实际需要配置。
- 公网访问:请根据实际需求购买弹性公网IP并设置带宽大小。
步骤二:设置ECS下的NFS共享
ECS购买完成后即可进行NFS共享设置,以下示例中以两个用户user1和user2的场景进行介绍,可根据实际需要增减用户数。
- 添加用户user1和user2并创建home目录。
useradd -m user1 && useradd -m user2
- 修改user1和user2的密码。
passwd user1 passwd user2
- 创建用户的共享目录,并修改共享目录操作权限为777。
mkdir /home/user1/share && chmod 777 /home/user1/share mkdir /home/user2/share && chmod 777 /home/user2/share
共享目录作为用户home目录的子目录,限制其他用户操作,确保函数挂载该目录后拥有操作权限。因此,设置权限为777不会导致权限过度。
- 安装NFS服务。
yum install rpcbind nfs-utils // 使用apt或其他包管理工具的镜像请使用相应的命令
- 编辑/etc/exports,写入如下内容:
/home/user1/share xx.xx.xx.xx/xx(rw) // 网段处请填写之前创建的子网网段 /home/user2/share xx.xx.xx.xx/xx(rw) // 网段处请填写之前创建的子网网段
- 启动NFS服务。
systemctl start rpcbind nfs
- 设置开机自启。
echo "xx.xx.xx.xx:/home/user1/share /nfs nfs4 defaults 0 0" >> /etc/fstab // IP处请填ECS在子网中的IP echo "xx.xx.xx.xx:/home/user2/share /nfs nfs4 defaults 0 0" >> /etc/fstab // IP处请填ECS在子网中的IP mount -av
- 查看共享信息,显示如图5所示即表示创建NFS共享成功。
showmount -e xx.xx.xx.xx // 请填搭建服务器主机的私有地址
步骤三:在AI对话应用中挂载ECS
登录函数工作流控制台,进入应用中心,用户user1和user2已分别在各自的账号下成功创建了AI对话ChatGLM3应用。以下以user1为例进行介绍,user2操作步骤相同。
- user1进入应用详情页,在“资源”列表中分别找到逻辑名称为“chatglm”和“custom_models_tool”的函数资源,如图6所示单击链接进入函数详情页面。
- 进入函数详情页,如图7所示单击“设置 > 网络配置”,打开“函数访问VPC内资源”开关并配置VPC和子网,请选择步骤一:购买ECS服务器中使用的VPC和子网,其余参数保持默认,单击“保存”。
- 在“设置”页签的左侧导航栏中,单击“磁盘挂载 > 添加挂载”,配置完成后,单击“确定”。
- 文件系统来源:选择“ECS”。
- 云服务器名称:选择步骤一:购买ECS服务器创建的云服务器。
- 共享目录路径:填写“/home/user1/share”(user2的应用则填写/home/user2/share)。
- 函数访问路径:填写“/mnt/auto”。
如已挂载SFS Turbo文件系统,可在成功挂载ECS后取消挂载SFS Turbo文件系统,并及时释放SFS Turbo文件系统资源避免持续收费。
- 参照#functiongraph_05_1210/li1795565811249~#functiongraph_05_1210/li773816521195完成“custom_models_tool”的函数设置。
步骤四:上传与使用自定义模型
- 返回应用详情页,单击“开始使用”进入ChatGLM3 WebUI界面。函数会自动在挂载目录中创建应用所需目录和文件。
- 请参考上传与使用自定义模型进行模型文件的上传和使用。