当前位置: 首页 > news >正文

Python 远程抓取服务器日志最后 1000行

哈喽,大家好,我是木头左!

一、神奇的 Python 工具箱

1. SSH 连接的密钥——paramiko

paramiko 库提供了丰富的方法来处理 SSH 连接的各种细节。从创建连接对象,到执行远程命令,再到获取命令输出,它都能有条不紊地完成任务。例如,可以使用 paramiko.SSHClient() 来创建一个 SSH 客户端实例,然后通过 connect() 方法传入服务器的 IP 地址、用户名和密码等信息,就能成功建立连接。一旦连接建立,就可以使用 exec_command() 方法在远程服务器上执行各种命令,就像在本地终端输入命令一样自然。

2. 文本处理的利器——内置函数和方法

Python 本身就拥有许多强大的文本处理功能,这在截取日志文件特定行数的操作中起着关键作用。比如,字符串的分割方法 split() 可以将一行文本按照指定的分隔符拆分成多个部分;列表的切片操作 [start:end] 可以方便地获取列表中的一段元素,这在截取日志文件的最后 n 行时会大显身手。

此外,文件操作相关的函数如 open()read()write() 等也是实现目标的重要帮手。通过这些函数,可以打开本地和远程的文件,读取其中的内容,并将处理后的数据写入新的文件中。

二、踏上远程连接的征程

1. 搭建 SSH 桥梁

要用 paramiko 搭建起与远程服务器的 SSH 连接。下面是一段简洁而有效的代码示例:

import paramikodef create_ssh_connection(hostname, port, username, password):client = paramiko.SSHClient()client.set_missing_host_key_policy(paramiko.AutoAddPolicy())client.connect(hostname, port, username, password)return clienthostname = 'your_server_ip'
port = 22
username = 'your_username'
password = 'your_password'
ssh_client = create_ssh_connection(hostname, port, username, password)

在这段代码中,定义了一个名为 create_ssh_connection 的函数,它接收服务器的 IP 地址、端口号、用户名和密码作为参数,并返回一个 SSH 客户端对象。通过调用这个函数,可以轻松地与远程服务器建立连接。需要注意的是,为了简化示例,这里采用了明文存储密码的方式,但在实际应用中,应该使用更安全的方式来管理密码,如环境变量或加密存储。

三、深入日志文件的迷宫

经过一番努力,终于成功地与远程服务器建立了连接,现在是时候深入服务器的文件系统,找到那个神秘的 /home/test.log 日志文件了。这就像是进入了一个充满宝藏的迷宫,需要准确地找到目标所在的房间。

1. 定位日志文件

在服务器的文件系统中,日志文件通常存放在特定的目录下。对于 /home/test.log 这个文件,它位于用户的主目录下的 test.log 文件中。可以使用 SSH 客户端提供的 exec_command() 方法来执行 Linux 系统的命令,从而找到并查看这个文件的内容。

以下是一个简单的代码片段,用于检查日志文件是否存在:

def check_file_exists(ssh_client, filepath):stdin, stdout, stderr = ssh_client.exec_command(f'ls {filepath}')if stdout.channel.recv_exit_status() == 0:return Trueelse:return Falsefilepath = '/home/test.log'
if check_file_exists(ssh_client, filepath):print("日志文件存在")
else:print("日志文件不存在")

在这段代码中,定义了一个 check_file_exists 函数,它接收 SSH 客户端对象和文件路径作为参数。通过执行 ls 命令并检查命令的退出状态,可以判断文件是否存在。如果文件存在,函数返回 True,否则返回 False

2. 揭开日志文件

一种常见的方法是使用 Linux 系统的 tail 命令。tail 命令可以方便地显示文件的末尾部分内容。可以结合 Python 的 exec_command() 方法和 tail 命令来实现这一功能:

def get_last_n_lines(ssh_client, filepath, n):command = f'tail -n {n} {filepath}'stdin, stdout, stderr = shh_client.exec_command(command)lines = stdout.read().decode('utf-8').splitlines()return linesn = 100
lines = get_last_n_lines(ssh_client, filepath, n)
for line in lines:print(line)

在这段代码中,定义了 get_last_n_lines 函数,它接收 SSH 客户端对象、文件路径和要截取的行数 n 作为参数。通过构建 tail 命令并执行它,可以获取日志文件的最后 n 行内容,并将其作为一个字符串列表返回。然后,可以遍历这个列表,打印出每一行的内容。

四、将宝藏带回本地——下载日志文件

现在,已经成功地从远程服务器上截取了 /home/test.log 文件的最后 n 行内容,接下来就是将这些珍贵的“宝藏”下载到本地的 tesg.log 文件中了。

1. 搭建传输通道

要将远程服务器上的数据下载到本地,需要建立一个数据传输通道。在 Python 中,可以使用文件 I/O 操作来实现这一功能。在本地创建一个名为 tesg.log 的文件,并打开它准备写入数据。

以下是创建本地文件并打开它的代码示例:

local_filename = 'tesg.log'
with open(local_filename, 'w') as local_file:pass

在这段代码中,使用 open() 函数以写入模式(‘w’)打开或创建一个名为 tesg.log 的文件,并将文件对象赋值给 local_file 变量。这样,就可以通过这个文件对象将数据写入本地文件中了。

2. 传输数据的魔法时刻

有了本地文件和从远程服务器获取的数据,现在就可以开始数据传输了。将之前获取的日志文件最后 n 行的内容逐行写入本地文件中。

下面是完成数据传输的代码片段:

for line in lines:local_file.write(line + '
')

在这段代码中,遍历从远程服务器获取的每一行数据,并使用 write() 方法将其写入本地文件中。为了确保每行数据之间有正确的换行符,在每行数据后面添加了一个换行符 ' '

五、关闭连接与清理工作

1. 关闭 SSH 连接的大门

在使用完 SSH 客户端后,应该及时关闭与远程服务器的连接,以释放系统资源并确保安全。这就好比是在离开一座房子后要锁好门一样重要。

关闭 SSH 连接非常简单,只需要调用 SSH 客户端对象的 close() 方法即可:

ssh_client.close()
2. 清理临时文件与资源

在本地,创建了 tesg.log 文件用于存储下载的日志数据。如果在后续的处理过程中不再需要这个文件,可以将其删除以释放磁盘空间。同样,在远程服务器上,如果在操作过程中产生了一些临时文件或数据,也应该及时清理掉,以保持服务器环境的整洁。

在 Python 中,可以使用 os.remove() 函数来删除本地文件:

import osos.remove(local_filename)

通过以上步骤,成功地实现了从服务器远程截取 /home/test.log 文件的最后 n 行并下载到本地 tesg.log 文件中的功能。

我是木头左,感谢各位童鞋的点赞、收藏,我们下期更精彩!

相关文章:

Python 远程抓取服务器日志最后 1000行

哈喽,大家好,我是木头左! 一、神奇的 Python 工具箱 1. SSH 连接的密钥——paramiko paramiko 库提供了丰富的方法来处理 SSH 连接的各种细节。从创建连接对象,到执行远程命令,再到获取命令输出,它都能有…...

vue3+screenfull实现部分页面全屏(遇到的问题会持续更新)

需求&#xff1a;除了左侧菜单&#xff0c;右侧主体部分全部全屏 首先下载screenfull全屏插件 npm install screenfull --save页面引入 import screenfull from screenfull;我这里是右上角全屏图标 <el-iconref"elIconRef"color"#ffffff"size"2…...

Ubuntu 下 nginx-1.24.0 源码分析 (1)

main 函数在 src\core\nginx.c int ngx_cdecl main(int argc, char *const *argv) {ngx_buf_t *b;ngx_log_t *log;ngx_uint_t i;ngx_cycle_t *cycle, init_cycle;ngx_conf_dump_t *cd;ngx_core_conf_t *ccf;ngx_debug_init(); 进入 main 函数 最…...

2025数据存储技术风向标:解析数据湖与数据仓库的实战效能差距

一、技术演进的十字路口 当前全球数据量正以每年65%的复合增长率激增&#xff0c;IDC预测到2027年企业将面临日均处理500TB数据的挑战。在这样的背景下&#xff0c;传统数据仓库与新兴数据湖的博弈进入白热化阶段。Gartner最新报告显示&#xff0c;采用混合架构的企业数据运营效…...

探索高性能AI识别和边缘计算 | NVIDIA Jetson Orin Nano 8GB 开发套件的全面测评

随着边缘计算和人工智能技术的迅速发展&#xff0c;性能强大的嵌入式AI开发板成为开发者和企业关注的焦点。NVIDIA近期推出的Jetson Orin Nano 8GB开发套件&#xff0c;凭借其40 TOPS算力、高效的Ampere架构GPU以及出色的边缘AI能力&#xff0c;引起了广泛关注。本文将从配置性…...

数据结构 常见的排序算法

&#x1f33b;个人主页&#xff1a;路飞雪吖~ &#x1f320;专栏&#xff1a;数据结构 目录 &#x1f33b;个人主页&#xff1a;路飞雪吖~ 一、插入排序 &#x1f31f;直接插入排序 &#x1f31f;希尔排序 二、选择排序 &#x1f31f;选择排序 &#x1f31f;堆排序…...

ES索引知识

索引是数据的载体&#xff0c;存储了文档和映射的信息 索引是具有相同结构的文档的合集体。 设置索引&#xff0c;不仅仅是设置索引名字&#xff0c;还有索引的一些配置&#xff0c;比如&#xff1a;分片和副本&#xff0c;刷新频率&#xff0c;搜索结果的最大参数&#xff0c…...

FreeRTOS第17篇:FreeRTOS链表实现细节05_MiniListItem_t:FreeRTOS内存优化

文/指尖动听知识库-星愿 文章为付费内容,商业行为,禁止私自转载及抄袭,违者必究!!! 文章专栏:深入FreeRTOS内核:从原理到实战的嵌入式开发指南 1 为什么需要迷你列表项? 在嵌入式系统中,内存资源极其宝贵。FreeRTOS为满足不同场景需求,设计了标准列表项(ListItem_…...

Golang | Gin(简洁版)

文章目录 安装使用RESTful API响应页面获取请求参数路由讲解中间件 安装使用 Gin 是一个 golang 的微框架&#xff0c;封装比较优雅&#xff0c;API 友好&#xff0c;源代码比较明确。具有快速灵活&#xff0c;容错方便等特点。其实对于 golang 而言&#xff0c;web 框架的依赖…...

RAG外挂知识库

目录 RAG的工作流程 python实现RAG 1.引入相关库及相关准备工作 函数 1. 加载并读取文档 2. 文档分割 3. embedding 4. 向集合中添加文档 5. 用户输入内容 6. 查询集合中的文档 7. 构建Prompt并生成答案 主流程 附录 函数解释 1. open() 函数语法 2.client.embe…...

Rust语言:开启高效编程之旅

目录 一、Rust 语言初相识 二、Rust 语言的独特魅力​ 2.1 内存安全:消除隐患的护盾​ 2.2 高性能:与 C/C++ 并肩的实力​ 2.3 强大的并发性:多线程编程的利器​ 2.4 跨平台性:适配多环境的优势​ 三、快速上手 Rust​ 3.1 环境搭建:为开发做准备​ 3.2 第一个 R…...

蓝桥杯备考:图论初解

1&#xff1a;图的定义 我们学了线性表和树的结构&#xff0c;那什么是图呢&#xff1f; 线性表是一个串一个是一对一的结构 树是一对多的&#xff0c;每个结点可以有多个孩子&#xff0c;但只能有一个父亲 而我们今天学的图&#xff01;就是多对多的结构了 V表示的是图的顶点集…...

Codeforces Round 502 E. The Supersonic Rocket 凸包、kmp

题目链接 题目大意 平面上给定两个点集&#xff0c;判定两个点集分别形成的凸多边形能否通过旋转、平移重合。 点集大小 ≤ \leq ≤ 1 0 5 10^{5} 105&#xff0c;坐标范围 [0, 1 0 8 10^{8} 108 ]. 思路 题意很明显&#xff0c;先求出凸包再判断两凸包是否同构。这里用…...

机器人匹诺曹机制,真话假话平衡机制

摘要&#xff1a; 本文聚焦于机器人所采用的一种“匹诺曹机制”&#xff0c;该机制旨在以大概率保持“虚拟鼻子”&#xff08;一种象征虚假程度的概念&#xff09;不会过长&#xff0c;通过在对话中夹杂真话与假话来实现。文章深入探讨了这一机制的原理&#xff0c;分析其背后的…...

用Python分割并高效处理PDF大文件

在处理大型PDF文件时&#xff0c;将它们分解成更小、更易于管理的块通常是有益的。这个过程称为分区&#xff0c;它可以提高处理效率&#xff0c;并使分析或操作文档变得更容易。在本文中&#xff0c;我们将讨论如何使用Python和为Unstructured.io库将PDF文件划分为更小的部分。…...

【RAG】混合检索(Hybrid Search) 提高检索精度

1.问题&#xff1a;向量检索也易混淆&#xff0c;而关键字会更精准 在实际生产中&#xff0c;传统的关键字检索&#xff08;稀疏表示&#xff09;与向量检索&#xff08;稠密表示&#xff09;各有利弊。 举个具体例子&#xff0c;比如文档中包含很长的专有名词&#xff0c; 关…...

CTFHub-FastCGI协议/Redis协议

将木马进行base64编码 <?php eval($_GET[cmd]);?> 打开kali虚拟机&#xff0c;使用虚拟机中Gopherus-master工具 Gopherus-master工具安装 git clone https://github.com/tarunkant/Gopherus.git 进入工具目录 cd Gopherus 使用工具 python2 "位置" --expl…...

【算法day4】最长回文子串——动态规划方法

最长回文子串 给你一个字符串 s&#xff0c;找到 s 中最长的 回文 子串。 https://leetcode.cn/problems/longest-palindromic-substring/submissions/607962358/ 动态规划&#xff1a; 回文串即是从前面开始读和从后面开始读&#xff0c;读出来的字符串均相同的字符串&#…...

C++之“string”类的模拟实现

​ &#x1f339;个人主页&#x1f339;&#xff1a;喜欢草莓熊的bear &#x1f339;专栏&#x1f339;&#xff1a;C入门 前言 hello &#xff0c;大家又来跟着bear学习了。一起奔向更好的自己&#xff0c;上篇博客已经讲清楚了string的一些功能的使用。我们就实现一些主要的功…...

请谈谈 HTTP 中的安全策略,如何防范常见的Web攻击(如XSS、CSRF)?

一、Web安全核心防御机制 &#xff08;一&#xff09;XSS攻击防御&#xff08;跨站脚本攻击&#xff09; 1. 原理与分类 ​存储型XSS&#xff1a;恶意脚本被持久化存储在服务端&#xff08;如数据库&#xff09;​反射型XSS&#xff1a;脚本通过URL参数或表单提交触发执行​…...

如何快速掌握深度学习调参技巧:tuning_playbook_zh_cn完全解析

如何快速掌握深度学习调参技巧&#xff1a;tuning_playbook_zh_cn完全解析 【免费下载链接】tuning_playbook_zh_cn 一本系统地教你将深度学习模型的性能最大化的战术手册。 项目地址: https://gitcode.com/gh_mirrors/tu/tuning_playbook_zh_cn tuning_playbook_zh_cn是…...

突破3大资源壁垒:UABEA工具实战指南

突破3大资源壁垒&#xff1a;UABEA工具实战指南 【免费下载链接】UABEA UABEA: 这是一个用于新版本Unity的C# Asset Bundle Extractor&#xff08;资源包提取器&#xff09;&#xff0c;用于提取游戏中的资源。 项目地址: https://gitcode.com/gh_mirrors/ua/UABEA 当你…...

Dirsearch字典玄学:从默认字典到AI生成,我的扫描效率提升300%的秘密

Dirsearch字典玄学&#xff1a;从默认字典到AI生成&#xff0c;我的扫描效率提升300%的秘密 在Web安全测试的战场上&#xff0c;目录扫描工具就像侦察兵手中的望远镜&#xff0c;而字典则是望远镜的镜片质量。从业五年来&#xff0c;我见证了太多安全工程师将90%的时间浪费在无…...

SDMatte效果可视化对比:传统U-Net抠图 vs SDMatte+,玻璃反光/薄纱透光细节放大评测

SDMatte效果可视化对比&#xff1a;传统U-Net抠图 vs SDMatte&#xff0c;玻璃反光/薄纱透光细节放大评测 1. 评测背景与目标 在电商设计、影视后期和平面制作领域&#xff0c;高质量图像抠图一直是刚需。传统U-Net架构虽然能完成基础的主体分离&#xff0c;但在处理玻璃器皿…...

薛定谔共价对接实战:如何为你的靶点蛋白快速找到‘锁死’它的共价抑制剂?

薛定谔共价对接实战&#xff1a;靶点蛋白的共价抑制剂高效筛选策略 药物研发领域正经历一场静默革命——共价抑制剂从曾经的"危险分子"摇身变为现代药物设计的明星。与传统可逆抑制剂不同&#xff0c;共价抑制剂能与靶点蛋白形成稳定的共价键&#xff0c;实现近乎不可…...

5个超实用技巧:用Awesome Adb实现手机调试效率倍增

5个超实用技巧&#xff1a;用Awesome Adb实现手机调试效率倍增 【免费下载链接】awesome-adb ADB Usage Complete / ADB 用法大全 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-adb 副标题&#xff1a;告别繁琐操作&#xff0c;让Android设备管理效率提升10倍 …...

AI辅助学术写作:Qwen3-0.6B-FP8搭配LaTeX生成论文章节与参考文献

AI辅助学术写作&#xff1a;Qwen3-0.6B-FP8搭配LaTeX生成论文章节与参考文献 写论文&#xff0c;尤其是写引言和参考文献&#xff0c;是不是让你特别头疼&#xff1f;对着空白的文档发呆&#xff0c;不知道从何下笔&#xff1b;或者为了找一篇关键的参考文献&#xff0c;在数据…...

网络电台个性化高效管理:foobox-cn技术实现与应用指南

网络电台个性化高效管理&#xff1a;foobox-cn技术实现与应用指南 【免费下载链接】foobox-cn DUI 配置 for foobar2000 项目地址: https://gitcode.com/GitHub_Trending/fo/foobox-cn foobox-cn作为foobar2000的DUI配置方案&#xff0c;通过创新的电台管理系统架构&…...

Qwen3-ForcedAligner与Node.js后端集成方案

Qwen3-ForcedAligner与Node.js后端集成方案 1. 引言 语音处理在现代应用中越来越重要&#xff0c;从语音识别到音频分析&#xff0c;都需要高效可靠的技术方案。Qwen3-ForcedAligner作为一个强大的强制对齐模型&#xff0c;能够精确地将文本与语音进行时间戳对齐&#xff0c;…...

不会写C代码也能做飞控?手把手教你用Matlab/Simulink和FMT搭建无人机算法模型

零代码飞控开发实战&#xff1a;用Matlab/SimulinkFMT实现无人机算法快速迭代 当无人机行业从极客玩具转向工业级应用时&#xff0c;传统飞控开发模式正面临严峻挑战——某高校研究团队曾花费三个月手工编写PID控制代码&#xff0c;却在首次试飞时因姿态解算模块的数值溢出导致…...