[喵咪Liunx(4)Monit进程监控

[喵咪Liunx(4)Monit进程监控

前言

有一段时间没有更新博客了,最近因为公司项目全球化以及最近慢慢在偏向学习团队管理忙的有点不可开交了,不过这次要给大家带来两篇关于Liunx日常开发维护管理中非常好用的两款利器,其中一个就是Monit啦,Monit是什么呢?他是一个进程级别的一个监控软件,不卖关子我们就进入到今天的正文当中吧!

附上:

喵了个咪的博客:w-blog.cn

Monit官网地址:https://www.mmonit.com/monit/documentation/monit.html

1. 问题

在我们平时研究一样东西或者说遇到一项困难时我们会更具问题来寻找解决方案,那就看待Monit之前就要先了解遇到了什么问题?

Nginx挂啦~~~~

笔者就是有意思客户反映到领导那里去了,你们平台怎么用不了了?,最后一查居然是Nginx死掉了~~死掉的时候是下午5点完成8点才收到反馈,用户不反馈就算等到明天可能还不知道!

脚本死了

Liunx开篇推荐的软件Supervisor可以帮助你运行脚本或者说软件,但是运行的软件默认连续过快退出三次就结束了,这个时候你怎么知道没有运行了?

2. Monit能搞定吗?

Monit的核心功能就是邮件通知,当你配置好需要监控的进程之后,无论是进程死亡,或者是进程变更都会发送报警邮件并且会更具你的预先配置好的命令尝试重启它,更牛逼的事当monit被关闭的时候也会发送邮件通知Moint被关闭,并且它还可以完成如下功能!

附加功能

比如你不是用的云服务器自己管理的机器,但是机器数量又没有特别多没有到要搭建一套完整的监控系统的份上(zabbix或open-falcon)的份上Monit可以比较好的帮你低成本的解决这个问题

web管理

可以用过web界面监控服务的资源占用,开始,暂停,重启等.

3. 安装Monit

这里笔者还是使用的centos6.5进行安装,只需要简单的yum一下即可

yum install monit

然后通过service命令就可以开关monit了

service monit start
service monit stop

4. 配置文件解读

使用monit最重要的就是设置好配置文件,具体的可以在官方文档查看这里只说几个重要的

# 检查时间默认30秒一次
set daemon  30 

# 邮箱配置({名称}替换成实际值)
set mailserver {smtp地址}                                                                                      
username "{邮箱用户名}" password "{邮箱密码}"                                                                 

set mail-format {   
# 邮件模板自定义                                                                                               
      from: {邮箱用户名}                                                                                      
   subject: monit alert --  $EVENT $SERVICE                                                                        
   message: $EVENT Service $SERVICE                                                                                
                 Date:        $DATE                                                                                
                 Action:      $ACTION                                                                              
                 Host:        $HOST                                                                                
                 Service:     $SERVICE                                                                             
                 Description: $DESCRIPTION                                                                         
            Your faithful employee,                                                                                
            Monit                                                                                                  
 }                                                                                                                 
set alert {接受的邮箱1}
set alert {接受的邮箱2}

# web访问配置 默认端口号2812
set httpd port 2812 and                                                                                            
    use address {能访问到的外网地址}                                             
    allow 0.0.0.0/0  #限制的请求IP                                     
    allow admin:monit  #登录用户名密码

基本配置就完成了,如果配置正确我们就会有道一封Monit启动的邮件

monit alert – Monit instance changed {主机名}

Monit instance changed Service {主机名}
                Date:        Fri, 14 Oct 2016 23:23:52
                Action:      start
                Host:        {主机名}
                Service:     {主机名}
                Description: Monit 5.14 started
           Your faithful employee,
           Monit

并且能够通过配置好的web端口访问得到如下界面(一下是配置好监控项才会有的)

注意:配置文件中还有系统报警等可以自行了解这里不做太多说明

5. 配置报警的几种方式

重中之重就是监控进程或者是服务器的报警,我们一般会选择/etc/monit.d/下面建立和监控的进程名一样的文件,Monit会自动读取解析,这里先来介绍几种常见的配置

按照PID进行监控

使用PID进行监控的基本上是一些程序组件比如Nginx,PHP-FPM,Supervisor,KafKa等,它们都会有一个共同点就是会有一个*.pid的文件来记录系统进程标示,所以我们如下配置:

/etc/monit.d/nginx

check process nginx with pidfile /var/run/nginx.pid #通过PID文件监控nginx                                                            
start program "/etc/init.d/nginx start"  #启动程序 死亡自动启动                                                                    
stop program "/etc/init.d/nginx stop"   #关闭程序 web界面可以操作

按照程序绝对命令

还有一种就是我们运行的脚本,不如运行了一个php index.php需要对它进行监控需要如下配置:

/etc/monit.d/phpindex

check process taskEmail with MATCHING 'php index.php'  
# 通过命令获取pid监控方式                                                                                                              
if changed pid then alert

注意:这里有过有多个命令都是php index.php会会出现问题

6. 总结

大家今天GET到了没有啊,Monit在日常中可以在非常低的成本下帮助我们发现问题及时告知我们,并且还有一些简单的web界面的配合,那么今天就到这里下一节将给大家介绍一个多服务器管理利器pssh,多谢大家的支持!

注:笔者能力有限有说的不对的地方希望大家能够指出,也希望多多交流!

### LlamaIndex 多模态 RAG 实现 LlamaIndex 支持多种数据类型的接入与处理,这使得它成为构建多模态检索增强生成(RAG)系统的理想选择[^1]。为了实现这一目标,LlamaIndex 结合了不同种类的数据连接器、索引机制以及强大的查询引擎。 #### 数据连接器支持多样化输入源 对于多模态数据的支持始于数据收集阶段。LlamaIndex 的数据连接器可以从多个异构资源中提取信息,包括但不限于APIs、PDF文档、SQL数据库等。这意味着无论是文本还是多媒体文件中的内容都可以被纳入到后续的分析流程之中。 #### 统一化的中间表示形式 一旦获取到了原始资料之后,下一步就是创建统一而高效的内部表达方式——即所谓的“中间表示”。这种转换不仅简化了下游任务的操作难度,同时也提高了整个系统的性能表现。尤其当面对复杂场景下的混合型数据集时,良好的设计尤为关键。 #### 查询引擎助力跨媒体理解能力 借助于内置的强大搜索引擎组件,用户可以通过自然语言提问的形式轻松获得所需答案;而对于更复杂的交互需求,则提供了专门定制版聊天机器人服务作为补充选项之一。更重要的是,在这里实现了真正的语义级关联匹配逻辑,从而让计算机具备了一定程度上的‘认知’功能去理解和回应人类意图背后所蕴含的意义所在。 #### 应用实例展示 考虑到实际应用场景的需求多样性,下面给出一段Python代码示例来说明如何利用LlamaIndex搭建一个多模态RAG系统: ```python from llama_index import GPTSimpleVectorIndex, SimpleDirectoryReader, LLMPredictor, PromptHelper, ServiceContext from langchain.llms.base import BaseLLM import os def create_multi_modal_rag_system(): documents = SimpleDirectoryReader(input_dir='./data').load_data() llm_predictor = LLMPredictor(llm=BaseLLM()) # 假设已经定义好了具体的大型预训练模型 service_context = ServiceContext.from_defaults( chunk_size_limit=None, prompt_helper=PromptHelper(max_input_size=-1), llm_predictor=llm_predictor ) index = GPTSimpleVectorIndex(documents, service_context=service_context) query_engine = index.as_query_engine(similarity_top_k=2) response = query_engine.query("请描述一下图片里的人物表情特征") print(response) ``` 此段脚本展示了从加载本地目录下各类格式文件开始直到最终完成一次基于相似度排序后的top-k条目返回全过程。值得注意的是,“query”方法接收字符串参数代表使用者想要询问的内容,而在后台则会自动调用相应的解析模块并结合先前准备好的知识库来进行推理计算得出结论。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

文振熙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值