云原生-云应用挂载持久化存储卷NAS及通过NAS实现批量机器并发查找日志

本文涉及的产品
云服务器 ECS,u1 4核8GB 1个月
云服务器ECS,u1 2核4GB 1个月
云服务器 ECS,u1 2核4GB 3个月
简介: 云原生-云应用挂载持久化存储卷NAS及通过NAS实现批量机器并发查找日志

需求


先说明需求,为什么要用NAS?

1.因为之前机器都是在ECS模式下,日志都可以持久化存储在ECS机器上,但是一旦应用上云部署为云应用了,那么云应用机器的扩缩容会导致POD的销毁和创建,这种情况下日志会随着POD而销毁,因此需要有一个持久化的存储


2.再者就是实现批量机器查找日志,之前在ECS模式下可以使用集团内部的pgm命令,一把梭哈就可以在上千台机器中定位查找的日志在哪台机器,但云原生POD模式就咩有这种功能了,通过NAS最后也实现了。


NAS


我也是第一次知道有NAS这款产品,那就先为阿里云的兄弟打一波广告:文件存储 (NAS),不了解什么是NAS的同学可以先了解一下,再继续下面。


购买及配置NAS


工欲善其事,必先购买NAS

这里先说明一下,不同环境可能操作步骤有不同


由于我的是有状态云应用,用到yaml配置文件,因此需要用到NAS的话,需要先在yaml中配置好NAS挂载信息,又因为我的上千个云应用共用NAS,要实现每个应用的日志在NAS下要有所区分,又在NAS上区分了挂载目录。

大致的yaml配置脱敏示例如下:

     # nas挂载
      - name: "nasName"
        flexVolume:
          driver: "alicloud/nas"
          options:
            server: "file-system-id.region.nas.aliyuncs.com"
            path: "当前服务器上待挂载的本地路径"
            vers: "3" #文件系统版本,vers=3:使用NFS v3协议挂载文件系统。
            options: "*"


其实到这里NAS挂载和配置就已经结束了,不懂的可以私戳我协助!


通过NAS实现批量机器并发查找日志


我们可以把NAS理解为一个磁盘,我的每个云应用会在磁盘上创建对应的目录,想在所有应用上查询同一个字段信息,相当于在NAS磁盘查询就好了,但是NAS没有办法直接登录啊!

这里给到一个解法:将NAS挂载到一台ECS机器,这样相当于给ECS机器挂载了一个磁盘,就可以查询NAS了。


ECS机器挂载NAS


说干就干,买ECS机器就不说了

买完之后跟着下面这里操作新购ECS时挂载NAS文件系统

一路向西就操作完毕

下面可以检查挂载结果了

使用VNC连接ECS实例,执行df -h命令,即可查看挂载的NAS文件系统信息

类似下图:

2021032621220883.png


使用SSH密钥对连接Linux实例


使用VNC连接实例太不方便了,那是阿里云多少年前的东西了,也一直没有优化,用户体验极差


这里可以参考使用SSH密钥对连接Linux实例


1.由于前面买机器的时候没有创建公网固定IP或EIP,也没有创建密钥对,所以需要绑定EIP,创建密钥对

参考创建SSH密钥对

参考绑定SSH密钥对

2.我这里目前是通过:在支持SSH命令的环境中使用密钥对(通过命令配置信息)


(1)修改私钥文件的属性

chmod 400 [.pem私钥文件在本地机上的存储路径]


例如

chmod 400 /Users/kunzhi/**.pem

(2)连接实例

ssh -i [.pem私钥文件在本地机上的存储路径] root@[公网IP地址]


(3)输入密码登录即可


20210326213310810.png


日志搜索

成功连接到实例后,需要进入对应的路径进行日志搜索

如下命令是对当前目录及子目录进行文件搜索关注字,并且每个文件只展示最新一条

find -name "文件名" | xargs -I file sh -c 'grep  "关键字" file|tail -1 ;grep -l  "关键字" file'

查找当前目录及子目录下包含"关键字”的文件名

find . -name "文件名" | xargs grep -l "关键字"


xargs,这个确实是一个好东西,后面会专门写一篇博客来记录一下

这里先给大家分享一个链接,可以先自己了解下xargs 命令教程


并发日志搜索


前面说了xargs好,但是GNU Parallel更香

这里是使用Linux 并行处理器 GNU Parallel

先安装

yum install parallel


安装完毕后直接在shell环境执行并行命令即可

#parallel 默认并发执行,每个CPU执行一条,当前机器是8核,即8个线程同:-j 8
#并发查找当前目录及子目录下的文件,包含"关键字"的第一条匹配的内容
#-I% 占位符
#-m1 取第一条
find -name 文件 |parallel -I% grep -m1 "关键字" 文件


其实xargs 也可以并发执行 参数是-P,但xargs的查询不保证顺序,有兴趣的同学可以执行下面的语句验证一下


#并发查找当前目录及子目录下的文件,包含"关键字"关键字的最新一条匹配的内容
find -name 文件 | xargs -P 8  -I file sh -c 'grep  "关键字" file|tail -1 ;grep -l  "关键字" file'


⚠️nas挂载找不到解决方案

NAS挂载找不到了,我们不可能再买一台ECS机器去操作,只需要进行重新配置即可,这里通过Linux系统挂载NFS文件系统解决

进行配置实例、手动挂载、自动挂载都走一遍,然后还原挂载。


通过命令:df -h

查看挂载情况即可了

好了,这次可以跑路了。。。。

相关实践学习
ECS云服务器新手上路
本实验会自动创建一台ECS实例。首先,远程登陆ECS实例,并部署应用。然后,登陆管理控制台,并对这台ECS实例进行管理操作。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6天前
|
运维 Cloud Native 持续交付
探索云原生架构:构建现代应用的基石
【7月更文挑战第9天】本文深入探讨了云原生架构的核心概念、关键技术组件以及实施的最佳实践。通过分析云原生技术如何促进微服务架构的实现,容器化技术的利用,以及持续集成与持续部署(CI/CD)流程的自动化,本文旨在为读者提供一个全面的云原生技术框架视图,并揭示其在加速企业数字化转型过程中的关键作用。
|
5天前
|
Kubernetes Cloud Native 安全
探索云原生技术在现代企业中的应用与挑战
随着云计算技术的不断进步,云原生已成为推动企业数字化转型的关键力量。本文将深入探讨云原生的核心概念、关键技术以及在实际应用中所面临的挑战和解决方案。通过分析具体案例,本文旨在为读者提供一套完整的云原生技术应用框架,帮助企业有效利用云原生技术提升业务灵活性和市场竞争力。
|
5天前
|
Cloud Native 安全 持续交付
云原生技术在现代企业中的应用与挑战
本文深入探讨了云原生技术如何革新现代企业的IT架构,并分析了在实施过程中所面临的主要挑战。通过具体案例分析,本文揭示了云原生技术在提高业务敏捷性、降低成本和促进创新方面的巨大潜力,同时也指出了企业在采用云原生技术时需谨慎应对的技术复杂性和安全风险等问题。
16 0
|
2天前
|
运维 Cloud Native Devops
云原生技术在现代企业中的应用与挑战
【7月更文挑战第13天】本文深入探讨了云原生技术在现代企业中的实际应用情况,包括其带来的优势和所面临的挑战。通过分析云原生的核心概念、主要技术组件以及在不同行业中的应用场景,文章揭示了云原生技术如何助力企业实现快速迭代、弹性扩展和自动化管理。同时,本文也指出了企业在采纳云原生技术过程中可能遇到的技术复杂性、安全风险和文化适应性等问题,并提出了相应的解决策略。
|
3天前
|
Cloud Native 安全 API
云原生架构在现代企业中的应用与挑战
随着云计算技术的飞速发展,云原生架构逐渐成为推动企业数字化转型的重要力量。本文深入探讨了云原生架构的核心组件、实施策略以及面临的主要挑战,旨在为读者提供一套系统的云原生应用框架和解决方案。通过分析多个行业案例,本文揭示了云原生技术如何助力企业提升业务灵活性、加快产品上市时间并优化资源管理。
|
4天前
|
Kubernetes Cloud Native Devops
云原生技术在现代企业中的应用与挑战
本文深入探讨了云原生技术如何革新现代企业的IT架构,提升业务的灵活性和扩展性。通过分析Kubernetes容器编排、微服务架构以及DevOps文化的应用案例,揭示了云原生技术带来的效率提升和成本优化。同时,文章也指出了企业在采用云原生技术时面临的安全、技术复杂性和人才缺乏等挑战,并提供了应对策略。
|
6天前
|
运维 Cloud Native Devops
云原生架构在现代企业中的应用与挑战
随着数字化转型的深入,云原生技术成为支撑企业创新和灵活性的关键。本文将探讨云原生架构的核心概念、优势以及在实际应用中面临的主要挑战。通过分析不同行业的案例,我们将揭示云原生如何助力企业实现资源的最优配置和业务流程的自动化,同时指出安全性、合规性和技术复杂性等实施障碍,为读者提供一套实施云原生架构时的考量框架。
|
8天前
|
Kubernetes Cloud Native 安全
云原生技术在现代企业中的应用与挑战
【7月更文挑战第7天】随着数字化转型的深入,云原生技术已成为推动企业IT架构现代化的关键力量。本文将探讨云原生技术的基本原理、核心组件及其在现代企业中的具体应用场景。同时,我们也将分析实施云原生技术时可能遇到的挑战和相应的解决策略,以期为企业提供一条清晰的云原生转型路径。
|
7天前
|
Kubernetes Cloud Native 微服务
企业级容器部署实战:基于ACK与ALB灵活构建云原生应用架构
这篇内容概述了云原生架构的优势,特别是通过阿里云容器服务Kubernetes版(ACK)和应用负载均衡器(ALB)实现的解决方案。它强调了ACK相对于自建Kubernetes的便利性,包括优化的云服务集成、自动化管理和更强的生态系统支持。文章提供了部署云原生应用的步骤,包括一键部署和手动部署的流程,并指出手动部署更适合有技术背景的用户。作者建议在预算允许的情况下使用ACK,因为它能提供高效、便捷的管理体验。同时,文章也提出了对文档改进的建议,如添加更多技术细节和解释,以帮助用户更好地理解和实施解决方案。最后,展望了ACK未来在智能化、安全性与边缘计算等方面的潜在发展。水文一篇,太忙了,见谅!
|
15天前
|
关系型数据库 MySQL Serverless
Serverless 应用引擎产品使用合集之在SAE2.0上的应用如何访问云原生数据库PolarDB MySQL版集群
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。