Ubuntu 24.04部署安装Honeyd蜜罐

news2025/5/27 13:30:48

🌴 前言

最近有个大作业,里面要求我们部署Hoenyd蜜罐,在网上搜了一通,发现相关的教程竟然少的可怜,即使有比较详细的教程,也是好几年前的了,跟着做一遍报一堆错,无奈之下,自己研究了好几天,于是有了这篇教程。

🍁 本地上传依赖文件

scp -r ~/Downloads/honeyd/ root@服务器IP:~/honeyd # 一键上传文件

在这里插入图片描述

⚠️:注意请将文件路径替换成你本地的文件路径,以及将服务器IP替换成你服务器的具体IP
以上命令是使用scp将本地下载好的依赖文件上传到服务器,依赖文件主要有:

libevent:非同步事件通知的函数库
libdnet:提供跨平台的网络相关的API函数库
libpcap:一个数据包捕获函数库,大多数网络软件都以它为基础
zlib: 开源的、高效的数据压缩库(呃,这个可能不需要,看参考帖中有这个库,因此加上)
Honeyd: honeyd源代码,注意这是从github上下载的开发者版本,而不是官网上的honeyd-1.5c

依赖文件已上传到百度网盘,网盘链接:依赖文件
在这里插入图片描述

🌱 服务器部署Honeyd

🎉 部署前准备

连接服务器,建议用本地终端ssh远程连接。
第一步当然是先更新软件源:sudo apt update

在这里插入图片描述
然后安装依赖,这里将所有依赖写入一条指令中了,可以方便一键安装依赖:

sudo apt install automake libtool g++ gcc flex bison libedit-dev unzip libssl-dev  -y # 一键安装依赖

在这里插入图片描述
第三步,将刚才上传的依赖文件解压缩,进入~/honeyd目录,依次将压缩文件解压缩,以下是不同压缩格式文件的解压命令:

tar -zxvf 文件名.tar.gz
tar -Jxvf 文件名.tar.xz
unzip -o -d ./ 文件名.zip

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

🎉 编译安装依赖文件

除了Honeyd-master外,其他四个库的编译安装只需要执行三部曲,即进入编译文件目录,执行 ./configuresudo makemake install,如下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


OK,到以上应该都没有问题,下面开始编译安装honeyd。

首先,需要先执行./autogen.sh,以生成configure文件。
在这里插入图片描述

执行./configure,报错如下:
在这里插入图片描述
这是因为虽然我们刚才手动编译安装了libevent,但是编译器找不到它,需要我们在手动指定libevent的编译路径,如下:

 ./configure   --with-libevent=/usr/local/lib   CPPFLAGS="-I/usr/local/include"   LDFLAGS="-L/usr/local/lib"

执行完上述命令后,出现新的报错,如下:
在这里插入图片描述
尝试手动将/usr/local/include下的event.h复制到/usr/local/lib下,指令如下:

 cp /usr/local/include/event.h /usr/local/lib

重新执行刚才的configure指令,问题解决。


执行make,报错如下:
在这里插入图片描述
意思是出现“变量重复定义”问题,仔细阅读编译信息之后,尝试过在第一次声明这些变量的头文件中加上条件编译,并在变量名前面加上extern声明,如下:

#ifndef HONEYD_H
#define HONEYD_H
extern struct event_base *libevent_base;
#endif

然而并没有什么用处。

在网上找了一下这个报错问题的解决,找到一篇帖子,照着做了依旧没有什么用,就当我准备放弃的时候,我习惯性的翻了翻评论区,点击“被折叠评论”,看到这样一条评论:
在这里插入图片描述
照着做了,果然不再报错了,虽然这个方法可能不是那么规范,但是确是最省事、目前我找到唯一有用的解决方法,姑且照做吧,“自古评论区出人才”诚不欺我!

要修改的头文件如下:
在这里插入图片描述
修改的地方请阅读刚才make编译链接时的报错信息,由于报错信息中有很多条都是关于同一个头文件的同一个变量在不同C源文件中的重复定义,因此可以对报错信息进行删减,我的方法是将报错信息复制到Vscode里面,删除涉及重复变量的报错,最后得到不含重复变量的报错信息:
在这里插入图片描述

在这里插入图片描述

可以看到,要修改honeyd.h的第59行,修改如下:
在这里插入图片描述
再比如修改stats.h,报错信息里说的是96行,但实际是加在第94,我相信聪明的广大程序员朋友应该不会这么死板吧。
在这里插入图片描述
照着上面的做法,将报错涉及到的所有头文件里面的重复定义变量前面加上static,完成以上步骤之后,执行make clean && make重新编译,此时编译应该不会再有问题。
在这里插入图片描述

执行make install,报错如下:
在这里插入图片描述
执行下面指令建立python3和python2的符号链接:

sudo ln -s /usr/bin/python3 /usr/bin/python

在这里插入图片描述
重新make install,报错如下:
在这里插入图片描述
这是因为Python 2允许0666(八进制)和666(十进制)两种写法,而Python 3严格要求八进制,必须用0o666表示。手动修改init.py,vim ./scripts/lib/init.py,修改如下:
在这里插入图片描述
重新make install,此时应不再报错。

执行honeyd验证,报错如下:
在这里插入图片描述
依次执行下面指令:

# 进入目录并创建链接
cd /usr/local/lib/ 
sudo ln -sf libdnet.1 libdnet.so.1 
sudo ln -sf libdnet.1.0.1 libdnet.so.1.0.1

# 刷新动态库缓存
sudo ldconfig

在这里插入图片描述

重新验证,成功。

在这里插入图片描述

🌿 总结

以上内容全是干货,几乎不带个人情感,下面请允许我抒发一下个人情感。这篇文章写下来也就40分钟不到,但是为了部署这个honeyd,我花了将近4天,从早到晚在解决这个问题,几乎就没干其他事情了。事实上,本来在第2天,我就阴差阳错地部署成功了,但当时思绪极其混乱,我看了好几篇帖子,问了好多AI,因此非常具有偶然性,我自己都不知道我是怎么部署成功的,没办法,强迫症犯了,怎么可以这么不明不白?!于是我重装了系统,重头开始重新部署,于是便是噩梦的开始,怎么都无法复现了!我当时真想抽自己几个耳光,但没办法,只能硬着头皮继续查资料,尝试了n种方法,重装了n遍系统,其背后之艰辛,只有我一个人知道。事实上,最后如果没有看到那位老哥的评论,可能还需要花更长的时间,这怎么不能说是一种幸运呢,有时候运气也是在学习过程中的一大乐趣,我深以为然。当今天下午成功复现了几次部署之后,我顿感神清气爽,走路都是飘的,天好蓝,草好绿!总的来说,虽然费了很多时间,做了好多无用功,但也收获了很多,首先就是网上关于这方面的教程少之又少,要么年代久远,要么不够详细,我也算是填补了这一“空白”,其次就是我对于编译项目有了更多的经验,知道如何去定位错误以及解决错误,最后是我明白了一个道理,那就是在学习过程中,于我而言,就是在学习计算机的过程中,要能坐得住冷板凳,要有耐心,像一个侦探一样细心关注每一个蛛丝马迹,最终解决一个看似不可能的问题。翻越一座座高山,在不断地历经艰辛后收获正反馈,也许这就是我学习计算机当中最大的乐趣!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2386104.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MCP技术体系介绍

MCP,全称时Model Context Protocol,模型上下文协议,由Claude母公司Anthropic于2014年11月正式提出。 MCP的核心作用是统一了Agent开发过程中大模型调用外部工具的技术实现流程,从而大幅提高Agent的开发效率。在MCP诞生之前,不同外部工具各有不同的调用方法。 要连接这些…

我的第1个爬虫程序——豆瓣Top250爬虫的详细步骤指南

我的第1个爬虫程序——豆瓣Top250爬虫的详细步骤指南 一、创建隔离开发环境 1. 使用虚拟环境(推荐venv) # 在项目目录打开终端执行 python -m venv douban_env # 创建虚拟环境 source douban_env/bin/activate # Linux/macOS激活 douban_env\Scri…

Selenium 测试框架 - C#

🚀Selenium C# 自动化测试实战:以百度搜索为例 本文将通过一个简单示例,手把手教你如何使用 Selenium + C# 实现百度搜索自动化测试。适合初学者快速上手,也适合作为企业 UI 自动化测试模板参考。 🧩 一、安装必要 NuGet 包 在 Visual Studio 的 NuGet 管理器中安装以下…

JavaWeb:SpringBoot工作原理详解

一、SpringBoot优点 1.为所有Spring开发者更快的入门 2.开箱即用,提供各种默认配置来简化项目配置 3.内嵌式容器简化Web项目 4.没有冗余代码生成和XML配置的要求 二、SpringBoot 运行原理 2.1. pom.xml spring-boot-dependencies: 核心依赖在父工程中;…

dify_plugin数据库中的表总结

本文使用dify-plugin-daemon v0.1.0版本,主要对dify_plugin数据库中的数据表进行了总结。 一.agent_strategy_installations 源码位置:dify-plugin-daemon\internal\types\models\agent.go type AgentStrategyInstallation struct {ModelTenantID …

HarmonyOS学习——UIAbility组件(上)

UIAbility组件概述 应用程序有几种界面交互形式 UIAbility:应用程序的入口 概述 UIAbility组件是一种包含UI的应用组件,主要用于和用户交互。 UIAbility的设计理念: 原生支持应用组件级的跨端迁移和多端协同。 支持多设备和多窗口形态。…

【Linux】磁盘空间不足

错误提示: no space left on device 经典版(block占用) 模拟 dd if/dev/zero of/var/log/nginx.log bs1M count2000排查 #1. df -h 查看哪里空间不足,哪个分区#2. du -sh详细查看目录所占空间 du -sh /* 排查占用空间大的目录 du -sh /var/* du…

持续更新 ,GPT-4o 风格提示词案例大全!附使用方式

本文汇集了各类4o风格提示词的精选案例,从基础指令到复杂任务,从创意写作到专业领域,为您提供全方位的参考和灵感。我们将持续更新这份案例集,确保您始终能够获取最新、最有效的提示词技巧。 让我们一起探索如何通过精心设计的提…

QStandardItemModel的函数和信号介绍

前言 Qt版本:6.8.0 QStandardItem函数介绍 函数 部分函数有不同的重载来适应不同的模型,例如appendrow 构造函数与析构函数 1. QStandardItemModel(QObject *parent nullptr) 说明:创建一个空的模型(0行0列)。参数: parent&…

Python 内存管理机制详解:从分配到回收的全流程剖析

在 Python 编程中,开发者无需像 C/C 那样手动分配和释放内存,但这并不意味着内存管理与我们无关。了解 Python 内存管理机制,能帮助我们编写出更高效、稳定的代码。接下来,我们将深入剖析 Python 内存管理的各个环节,并…

【报错】Error attempting to get column ‘created_time‘ from result set.解决方法

postman报错以下内容 {"code": "500","msg": "查询失败:Error attempting to get column created_time from result set. Cause: java.sql.SQLFeatureNotSupportedException\n; null; nested exception is java.sql.SQLFeatur…

Google 推出 Flow —— AI 电影制作新平台

这周, Google I/O 2025 大会上发布了一些重磅 AI 公告。 他们推出了全新的图像模型 Imagen 4,还发布了升级版视频生成器 Veo 3、升级版 Gemini Pro 模型,以及一系列其他令人印象深刻的更新。 但将所有这些生成式媒体工具整合在一起的,是他们称为 Flow 的平台。 什么是 F…

跨链风云:打破区块链孤岛,实现价值自由流转

嘿,各位技术爱好者们!今天我们来聊一个区块链领域非常火热且至关重要的话题——跨链技术。你可能听说过,比如想把在波场(Tron)链上的USDT转移到以太坊(Ethereum)网络上,这个过程就涉…

鸿蒙开发:了解$$运算符

前言 本文基于Api13 有这样一个需求,一个Text组件,一个TextInput组件,要求Text组件同步展示TextInput组件里的内容,也就是TextInput组件输入什么内容,就要在Text组件里展示什么内容,这个需求如何实现呢&…

基于CEEMDAN-Transformer-BiLSTM的多特征风速气候预测的完整实现方案及PyTorch源码解析

基于CEEMDAN-Transformer-BiLSTM的多特征风速气候预测的完整实现方案及PyTorch源码解析 一、模型架构设计 1.1 整体框架 该模型采用三级架构设计(图1): CEEMDAN分解层:对非平稳风速序列进行自适应分解多模态特征融合模块&#…

基于TypeScript的全栈待办事项应用Demo

Demo地址:git clone https://gitcode.com/rmbnetlife/todo-app.git Todo List 应用 这是一个基于TypeScript的全栈待办事项应用,前端使用React,后端使用Node.js和Express。 项目概述 这个Todo List应用允许用户: 查看所有待办…

国际荐酒师(香港)协会亮相新西兰葡萄酒巡展深度参与赵凤仪大师班

国际荐酒师(香港)协会率团亮相2025新西兰葡萄酒巡展 深度参与赵凤仪MW“百年百碧祺”大师班 广州/上海/青岛,2025年5月12-16日——国际荐酒师(香港)协会(IRWA)近日率专业代表团出席“纯净独特&…

【深度学习】2. 从梯度推导到优化策略:反向传播与 SGD, Mini SGD

反向传播算法详解 1. 前向传播与输出层误差定义 假设我们考虑一个典型的前馈神经网络,其最后一层为 softmax 分类器,损失函数为交叉熵。 前向传播过程 对于某一隐藏层神经元 j j j: 输入: x i x_i xi​ 权重: w j…

工业软件国产化:构建自主创新生态,赋能制造强国建设

随着全球产业环境的变化和技术的发展,建立自主可控的工业体系成为我国工业转型升级、走新型工业化道路、推动国家制造业竞争水平提升的重要抓手。 市场倒逼与政策护航,国产化进程双轮驱动 据中商产业研究院预测,2025年中国工业软件市场规模…

UART、RS232、RS485基础知识

一、UART串口通信介绍 UART是一种采用异步串行、全双工通信方式的通用异步收发传输器功能。 硬件电路: •简单双向串口通信有两根通信线(发送端TX和接收端RX) •TX与RX要交叉连接 •当只需单向的数据传输时,可以只接一根通信线…