介绍如何使用一键挂载功能进行NAS挂载
一键挂载有什么用?
命令行挂载的问题
目前使用ECS挂载NAS,需要先登录ECS,然后手动输入复杂的命令行执行挂载。现有流程有以下几个问题:
- 挂载命令复杂:挂载执行的mount命令参数众多,任何格式或参数错误都会导致失败。使用错误的挂载参数,还会带来稳定性隐患。
- 自动挂载配置易错:自动挂载配置的格式复杂,只要有一点差错,都可能导致ECS重启变慢或失败。
- 失败原因难以定位:NFS客户端未安装、ECS与NAS网络不通、NAS权限组配置错误等原因都会导致挂载失败,即使是基础的常见问题,排查起来也费时费力。
- 多机管理麻烦:如果同时运维数台ECS的挂载状态,就需要在多台ECS界面之间来回切换,很容易绕晕。
- 内核参数配置复杂:如果Linux内核的sunrpc参数没有优化,文件系统的读写性能就无法达到最佳状态。
一键挂载功能发布,解决以上大部分问题!
图形界面操作
登录NAS控制台,进入NFS协议文件系统的挂载使用页面,您就可以在操作一栏中找到“挂载”、“卸载”、“查询”按钮,点击输入相关参数,即可在图形界面完成ECS对文件系统的相应操作,免去手动输入命令行的麻烦。
使用命令行挂载特别容易使用错误的挂载参数,尤其是漏掉noresvport参数会导致稳定性风险。一键挂载默认使用最优参数组合执行挂载,同时保留您修改挂载参数实现特殊需求的灵活度。
一键挂载的详细操作方法和参数具体解释,可以参考一键挂载文档。
配置自动挂载
如果您希望在每次ECS启动时,都自动挂载NFS协议文件系统,一键挂载功能可以大大简化您的配置过程。只需要在控制台点击“挂载”后,保留“开机自动挂载”的勾选,确认挂载即可。
如果您希望对已挂载的目录进行操作,打开或者关闭自动挂载,只需在查询结果列表中,点击相应的“自动挂载”开关即可。
避免常见问题
一键挂载功能,会在ECS上自动安装NFS客户端,自动创建不存在的挂载路径,自动创建不存在的NAS目录,避免最基础的常见挂载问题。
一键挂载还对NAS挂载点和ECS的网络情况进行了限制,仅支持专有网络类型的NAS挂载点和ECS。在选择ECS进行操作时,列表中只能看到和NAS挂载点相同VPC内的ECS,避免因为误选网络隔离的ECS而出现挂载失败。
对于其他挂载失败的情况,NAS控制台也会弹出提示框,说明失败的具体原因和解决方法。对于一些复杂原因造成的挂载失败问题,可以根据提示,查看挂载失败排查文档,下载脚本排查解决。
方便多机管理
如果您希望查看某个NAS挂载点在某台ECS上的挂载状态,可以使用“查询”功能。在看到结果列表后,您也可以点击列表顶部的ECS下拉列表,查看其他ECS对这个挂载点的挂载情况。
NAS控制台的挂载使用页面,仅支持每次对一台ECS进行操作。如果您希望在多台ECS上同时挂载、卸载、查询某个挂载点,请参考批量挂载文档。
配置内核参数
在普通的手动挂载过程中,内核参数配置很容易被忽略,一旦被忽略则很难被发现或修改。直到发现读写性能达不到预期,才会在复杂的排查后发现内核参数没有优化。现有的命令行修改方式,操作也很复杂。而一键挂载功能会在挂载执行之前,自动配置好Linux内核中的sunrpc参数,挂载完毕即可享受最佳性能。
一键挂载有哪些限制?
操作系统
- 仅支持Linux操作系统,不支持 Windows、CoreOS、FreeBSD、Fedora-CoreOS。
- RedHat操作系统请先使用rpm包方式安装云助手客户端,安装完成后才能正常使用一键挂载。
网络类型
- 不支持经典网络类型的ECS,经典网络ECS可以参考批量挂载文档,使用云助手控制台进行操作。
- 专有网络ECS所在的VPC必须与挂载点所在VPC一致。如果ECS所在VPC和挂载点所在VPC用云企业网打通,并且两个VPC属于同一个账号、同一个地域,则可以参考批量挂载文档,使用云助手控制台进行操作。
运行状态
- 仅支持“运行中”状态的ECS,如果ECS在停机、启动中等状态,则不支持操作。
还有什么需要注意的?
首次挂载速度
使用一键挂载功能,第一次将NAS挂载到ECS的时候,会自动安装NFS客户端。安装时间大概在一分钟左右,请耐心等待。个别Linux版本安装NFS客户端会超时,可以根据提示信息,等一等再重试挂载操作。
自动挂载细节
一键挂载功能对于自动挂载的配置过程,会将挂载信息写入/etc/fstab,并且删除/etc/rc.local与systemd的相关自动挂载配置。如果您一定需要使用/etc/rc.local或systemd来配置自动挂载,请避免使用一键挂载功能进行挂载和卸载。
强制卸载风险
如果挂载路径无法被正常卸载,则很可能是有应用还在读写挂载路径中的NAS文件或目录。这时进行强制卸载的话,可能会造成正在写入的数据丢失,相关应用异常退出。请登录ECS,执行“fuser -mv <挂载路径>”命令查看对应的进程信息。在退出相关进程后,重试普通卸载操作。如果确认所有进程已全部退出,却仍然无法正常卸载,可以在卸载对话框中勾选强制卸载,然后确认执行。系统会发送短信验证码到您阿里云账号绑定的手机上,输入验证码后才能完成操作。
推荐阅读
-
35 岁实现财务*,腾讯程序员手握2300万提前退休?-1000万房产、1000万腾讯股票、加上300万的现金,一共2300万的财产。有网友算了一笔账,假设1000万的房产用于自住,剩下1300万资产按照平均税后20-50万不等进行计算,大约花上26-60年左右的时间才能赚到这笔钱。也就是说,普通人可能奋斗一辈子,才能赚到这笔钱。在很多人还在为中年危机而惶惶不可终日的时候,有的人的35岁,就已经安全着陆,试问哪个打工人不羡慕?但问题是有这样财富积累必然有像样的实力做靠山。没有人可以不劳而获。 看到这里,肯定有人说,那么对于普通人来说,卷可能真就成了唯一的出路。但是卷也有轻松的卷,“偷懒”的卷法,对于程序员而言,刨除掉一时无法改掉的开会传统占用的大部分时间,如何把有限的时间和精力放在真正重要的架构设计、需求设计上,而不是重复的造*,编码、改bug、手动测试。因此在科技改变生活的今天,学会使用AI工具成为程序员们的必备技能。 以全栈式全自动的软件开发工具飞算SoFlu软件机器人为例,作为全球首款面向微服务架构设计和最佳实践的软件机器人,SoFlu软件机器人改变了原来手工编码的作业模式,通过可视化拖拽方式以及参数配置就能实现等同于编写复杂代码的业务逻辑,在设计业务逻辑时就完成了微服务应用开发,做到“业务即图,图即代码”,实现“软件开发,十倍提效”。 而作为飞算SoFlu软件机器人的一个重要组成部分,FuncGPT(慧函数)支持所有类型函数创建。通过自然语言描述Java函数需求,实时生成高质量、高可读性的Java函数代码。生成代码可直接复制到IDEA,或一键导入Java全自动开发工具函数库。 FuncGPT(慧函数)具有五大核心能力: ● 自然语言:通过自然语言即可生成函数,降低软件开发门槛。 ● 秒级函数开发:全自动秒级开发函数,秒级完成,效率千倍提升。 ● 一站式函数开发应用:函数生成即可直接应用,效率、安全有保障。 ● 质量可靠:生成的函数代码符合业界规范、具备良好的可读性,符合最优解。 ● 灵活生成:可以根据开发人员的具体需求生成并支持调整和修改。 以“将文件流转换为File对象”这个需求为例,以下是FuncGPT(慧函数)秒级生成的代码: / 类名:FileConverter // 函数名:convertStreamToFile // 函数功能:将文件流转换为File对象 // POM依赖包:无 import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; public class FileConverter { /** * 将文件流转换为File对象 * @param inputStream 文件流 * @param filePath 文件路径 * @param fileName 文件名 * @return 转换后的File对象 * @throws IOException 如果发生I/O异常 */ public static File convertStreamToFile(InputStream inputStream, String filePath, String fileName) throws IOException { File file = new File(filePath + File.separator + fileName); // 创建File对象 try (FileOutputStream outputStream = new FileOutputStream(file)) { // 创建文件输出流 byte buffer = new byte[1024]; int bytesRead; while ((bytesRead = inputStream.read(buffer)) != -1) { // 从文件流读取数据并写入文件 outputStream.write(buffer, 0, bytesRead); } } return file; // 返回转换后的File对象 } } // 函数示例 // 将文件流转换为File对象示例 // 入参:inputStream,文件流 // 入参:filePath,文件路径 // 入参:fileName,文件名 // 出参:file,转换后的File对象 // 调用示例: // InputStream inputStream = new FileInputStream("example.txt"); // String filePath = "C:\\Users\\User\\Documents"; // String fileName = "example.txt"; // File file = FileConverter.convertStreamToFile(inputStream, filePath, fileName); // System.out.println(file.getAbsolutePath); // 输出结果:例如,将文件流转换为File对象后,文件的绝对路径为:C:\Users\User\Documents\example.txt // 则输出结果为:C:\Users\User\Documents\example.txt 通过分析,不难发现以上代码:
-
纯干货分享 | 研发效能提升——敏捷需求篇-而敏捷需求是提升效能的方式中不可或缺的模块之一。 云智慧的敏捷教练——Iris Xu近期在公司做了一场分享,主题为「敏捷需求挖掘和组织方法,交付更高业务价值的产品」。Iris具有丰富的团队敏捷转型实施经验,完成了企业多个团队从传统模式到敏捷转型的落地和实施,积淀了很多的经验。 这次分享主要包含以下2个部分: 第一部分是用户影响地图 第二部分是事件驱动的业务分析Event driven business analysis(以下简称EDBA) 用户影响地图,是一种从业务目标到产品需求映射的需求挖掘和组织的方法。 在软件开发过程中可能会遇到一些问题,比如大家使用不同的业务语言、技术语言,造成角色间的沟通阻碍,还会导致一些问题,比如需求误解、需求传递错误等;这会直接导致产品的功能需求和要实现的业务目标不是映射关系。 但在交付期间,研发人员必须要将这些需求实现交付,他们实则并不清楚这些功能需求产生的原因是什么、要解决客户的哪些痛点。研发人员往往只是拿到了解决方案,需要把它实现,但没有和业务侧一起去思考解决方案是否正确,能否真正的帮助客户解决问题。而用户影响地图通常是能够连接业务目标和产品功能的一种手段。 我们在每次迭代里加入的假设,也就是功能需求。首先把它先实现,再逐步去验证我们每一个小目标是否已经实现,再看下一个目标要是什么。那影响地图就是在这个过程中帮我们不断地去梳理目标和功能之间的关系。 我们在软件开发中可能存在的一些问题 针对这些问题,我们如何避免?先简单介绍做敏捷转型的常规思路: 先做团队级的敏捷,首先把产品、开发、测试人员,还有一些更后端的人员比如交互运维的同学放在一起,组成一个特训团队做交付。这个团队要包含交付过程中所涉及的所有角色。 接着业务敏捷要打通整个业务环节和研发侧的一个交付。上图中可以看到在敏捷中需求是分层管理的,第一层是业务需求,在这个层级是以用户目标和业务目标作为输入进行规划,同时需要去考虑客户的诉求。业务人员通过获取到的业务需求,进一步的和团队一起将其分解为产品需求。所以业务需求其实是我们真正去发布和运营的单元,它可以被独立发布到我们的生产环境上。我们的产品需求其实就是产品的具体功能,它是我们集成和测试的对象,也就是我们最终去部署到系统上的一个基本单元。产品需求再到了我们的开发团队,映射到迭代计划会上要把它分解为相应的技术任务,包括我们平时所说的比如一些前端的开发、后端的开发、测试都是相应的技术任务。所以业务敏捷要达到的目标是需要去持续顺畅高质量的交付业务价值。 将这几个点串起来,形成金字塔结构。最上层我们会把业务目标放在整个金字塔的塔尖。这个业务目标是通过用户的目标以及北极星指标确立的。确认业务目标后再去梳理相应的业务流程,最后生产。另外产品需求包含了操作流程和业务规则,具需求交付时间、工程时间以及我们的一些质量标准的要求。 谈到用户影响的地图,在敏捷江湖上其实有一个传说,大家都有一个说法叫做敏捷需求的“任督二脉”。用户影响地图其实就是任脉,在黑客马拉松上用过的用户故事地图其实叫督脉。所以说用户影响地图是在用户故事地图之前,先帮我们去梳理出我们要做哪些东西。当我们真正识别出我们要实现的业务活动之后,用户故事地图才去梳理我们整个的业务工作流,以及每个工作流节点下所要包含的具体功能和用户故事。所以说用户影响地图需要解决的问题,我们包括以下这些: 首先是范围蔓延,我们在整张地图上,功能和对应的业务目标是要去有一个映射的。这就避免了一些在我们比如有很多干系人参与的会议上,那大家都有不同想法些立场,会提出很多需求(正确以及错误的需求)。这个时候我们会依据目标去看这些需求是否真的是会影响我们的目标。 这里提到的错误需求,比如是利益相关的人提出的、客户认为产品应该有的、某个产品经理需求分析师认为可以有的....但是这些功能在用户影响地图中匹配不到对应目标的话,就需要降低优先级或弃掉。另外,通常我们去制定解决方案的时候,会考虑较完美的实现,导致解决方案括很多的功能。这个时候关键目标至关重要,会帮助我们梳理筛选、确定优先级。 看一下用户影响到地图概貌 总共分为一个三层的结构: 第一层why,你的业务目标哪个是最重要的,为什么?涉及到的角色有哪些? 第二层how ,怎样产生影响?影响用户角色什么样的行为? (不需要去列出所有的影响,基于业务目标) 第三层what,最关键的是在梳理需求时不需一次把所有细节想全,这通常团队中经常遇到的问题。 我们用这个例子来看一下 这是一个客服中心的影响地图,业务目标是 3个月内不增加客服人数的前提下能支持1.5倍的用户数。此业务目标设定是符合 smart 原则的,specific非常的具体,miserable 是可以衡量的,action reoriented是面向活动的, real list 也是很实际的。 量化的目标会指引我们接下来的行动,梳理一个业务目标,尽量去量化,比如 :我们通过打造一条什么样的流水线,能够提高整个部署的效率,时间是原来的 1/2 。这样才是一个能量化的有意义的目标。 回到这幅图, how 层级识别出来的内容,客服角色:想要对它施加的影响,把客户引导到论坛上,帮助客户更容易的跟踪问题,更快速的去定位问题。初级用户:方论坛上找到问题。高级用户:在论坛上回答问题。通过我们这些用户角色,进行活动,完成在不增加客户客服人数的前提下支持更多的用户数量。 最后一个层级,才是我们日常接触比较多的真正的功能的特性和需求,比如引导到客户到论坛上,其实这个产品就需要有一个常见问题的论坛的链接。这个层次需要我们团队进一步地在交付,在每个迭代之前做进一步的梳理,细化成相应的用户故事。 这个是云智慧团队中,自己做的影响地图的范例,可以看下整个的层级结构。序号表示优先级。 那我们用户影响地图可以总结为:
-
如何在CentOS 7下实现多台内网服务器共享同一本地yum源? 1. 将共享源服务器(IP: 192.168.100.111)上的yum源进行本地化配置; 2. 使用Nginx为共享源服务器提供外部访问地址; 3. 在其他内网服务器上配置共享源服务器的地址。 共享源本地yum源的配置: 1. 在服务器上创建目录并备份原有yum源文件: ``` mkdir /data/{centos-yum.bak,centos,centos-images} mv /etc/yum.repos.d/* /data/centos-yum.bak/ 上传镜像文件到服务器: mv CentOS-7-x86_64-DVD-1810.iso /data/centos-images/ 挂载镜像文件: mount -o loop -t iso9660 /data/centos-images/CentOS-7-x86_64-DVD-1810.iso /data/centos #取消挂载 umount /data/centos ``` 2. 创建repo文件: ``` vim /etc/yum.repos.d/my.repo [my] name=my baseurl=file:///data/centos enabled=1 gpgcheck=0 ``` 3. 制作缓存: ``` yum clean all yum makecache ``` 4. 查看详细信息: ``` [root@omnis-server data]# pwd /data [root@omnis-server data]# ls centos centos-images centos-yum.bak [root@omnis-server data]# cd centos [root@omnis-server centos]# pwd /data/centos [root@omnis-server centos]# ls CentOS_BuildTag EFI EULA GPL images isolinux LiveOS Packages repodata RPM-GPG-KEY-CentOS-7 RPM-GPG-KEY-CentOS-Testing-7 TRANS.TBL ```
-
介绍如何使用一键挂载功能进行NAS挂载