在 Ubuntu 上安装 Muduo 网络库的详细指南

server/2024/12/24 2:43:10/

在 Ubuntu 上安装 Muduo 网络库的详细指南

首先一份好的安装教程是非常重要的

C++ muduo网络库知识分享01 - Linux平台下muduo网络库源码编译安装-CSDN博客

像这篇文章就和shit一样,安装到2%一定会卡住,如果你不幸用了这个那真是遭老罪了

环境:ubuntu 24.04

文章目录

  • 在 Ubuntu 上安装 Muduo 网络库的详细指南
        • 1. 更新系统包列表
        • 2. 安装必要的依赖项
        • 3. 克隆 Muduo 的源码仓库
        • 4. 创建构建目录并编译
        • 5. 安装 Muduo(可选)
        • 6. 配置环境变量(如果需要)
        • 7. 验证安装
        • 8. 编写自己的项目
        • 9.测试代码
        • 常见问题及解决方案

1. 更新系统包列表

首先,确保你的系统包列表是最新的。

sudo apt-get update
sudo apt-get upgrade
2. 安装必要的依赖项

Muduo 依赖于一些基本的开发工具和库。安装这些依赖项:

sudo apt-get install -y git cmake g++ libboost-all-dev libssl-dev
  • git:用于克隆 Muduo 的源码仓库。
  • cmake:用于构建项目。
  • g++:C++ 编译器。
  • libboost-all-dev:Boost 库,Muduo 依赖于 Boost。
  • libssl-dev:用于 SSL 支持(如果需要)。
3. 克隆 Muduo 的源码仓库

使用 git 克隆 Muduo 的源码。Muduo 的官方仓库托管在 GitHub 上。

git clone https://github.com/chenshuo/muduo.git
4. 创建构建目录并编译

进入 Muduo 源码目录,创建一个构建目录,并使用 CMake 进行编译。

cd muduo
mkdir build
cd build
cmake ..
make

在这里插入图片描述

5. 安装 Muduo(可选)

如果你希望将 Muduo 安装到系统目录,可以执行以下命令:

sudo make install

在这里插入图片描述

默认情况下,Muduo 会被安装到 /usr/local 目录下。如果需要自定义安装路径,可以在运行 cmake 时指定 CMAKE_INSTALL_PREFIX

cmake -DCMAKE_INSTALL_PREFIX=/your/custom/path ..
make
sudo make install
6. 配置环境变量(如果需要)

如果你将 Muduo 安装到了自定义路径,可能需要将库路径添加到 LD_LIBRARY_PATH 环境变量中。

export LD_LIBRARY_PATH=/your/custom/path/lib:$LD_LIBRARY_PATH

你可以将上述命令添加到 ~/.bashrc~/.profile 文件中,以便每次启动终端时自动设置。

7. 验证安装

你可以编译并运行 Muduo 提供的示例程序,确保安装成功。

cd ../examples
make
./echo_server

如果 echo_server 启动成功并监听指定端口,说明 Muduo 安装成功。

8. 编写自己的项目

在你的项目中使用 Muduo 时,需要在 CMakeLists.txt 中添加相应的配置。例如:

cmake_minimum_required(VERSION 3.10)
project(MyMuduoApp)set(CMAKE_CXX_STANDARD 11)find_package(muduo REQUIRED)add_executable(MyMuduoApp main.cpp)
target_link_libraries(MyMuduoApp muduo_net muduo_base pthread)

确保 main.cpp 中包含 Muduo 的头文件并使用其功能。

9.测试代码

把muduo库的头文件和lib库文件拷贝完成以后,使用muduo库编写一个简单的echo回显服务器,测试muduo库是否可以正常使用,代码如下:

#include <muduo/net/TcpServer.h>
#include <muduo/base/Logging.h>
#include <boost/bind.hpp>
#include <muduo/net/EventLoop.h>// 使用muduo开发回显服务器
class EchoServer
{public:EchoServer(muduo::net::EventLoop* loop,const muduo::net::InetAddress& listenAddr);void start(); private:void onConnection(const muduo::net::TcpConnectionPtr& conn);void onMessage(const muduo::net::TcpConnectionPtr& conn,muduo::net::Buffer* buf,muduo::Timestamp time);muduo::net::TcpServer server_;
};EchoServer::EchoServer(muduo::net::EventLoop* loop,const muduo::net::InetAddress& listenAddr): server_(loop, listenAddr, "EchoServer")
{server_.setConnectionCallback(boost::bind(&EchoServer::onConnection, this, _1));server_.setMessageCallback(boost::bind(&EchoServer::onMessage, this, _1, _2, _3));
}void EchoServer::start()
{server_.start();
}void EchoServer::onConnection(const muduo::net::TcpConnectionPtr& conn)
{LOG_INFO << "EchoServer - " << conn->peerAddress().toIpPort() << " -> "<< conn->localAddress().toIpPort() << " is "<< (conn->connected() ? "UP" : "DOWN");
}void EchoServer::onMessage(const muduo::net::TcpConnectionPtr& conn,muduo::net::Buffer* buf,muduo::Timestamp time)
{// 接收到所有的消息,然后回显muduo::string msg(buf->retrieveAllAsString());LOG_INFO << conn->name() << " echo " << msg.size() << " bytes, "<< "data received at " << time.toString();conn->send(msg);
}int main()
{LOG_INFO << "pid = " << getpid();muduo::net::EventLoop loop;muduo::net::InetAddress listenAddr(8888);EchoServer server(&loop, listenAddr);server.start();loop.loop();
}

使用g++进行编译,注意链接muduo和pthread的库文件,编译命令如下:

g++ main.cpp -lmuduo_net -lmuduo_base -lpthread -std=c++11

编译链接完成,生成a.out可执行程序,上面的echo服务器监听8888端口,运行上面的a.out回显服务器如下:

darling@darling:~/桌面$ ./a.out
20241221 06:50:24.057765Z 10774 INFO  pid = 10774 - test.cpp:61

在这里插入图片描述

等待客户端连接,可以打开一个新的shell命令行用netcat命令模拟客户端连接echo服务器进行功能测试,命令如下:

darling@darling:~$ nc 127.0.0.1 8888
hello world
hello world
nihao a
nihao a

在这里插入图片描述

常见问题及解决方案
  • Boost 版本问题:确保安装的 Boost 版本与 Muduo 兼容。一般来说,Ubuntu 仓库中的 Boost 版本是足够的。
  • 权限问题:如果在安装过程中遇到权限问题,确保使用 sudo 执行需要权限的命令。
  • 依赖缺失:如果编译过程中提示缺少依赖项,安装相应的开发包。例如,如果缺少 openssl,可以安装 libssl-dev

http://www.ppmy.cn/server/152642.html

相关文章

RK3588 , mpp硬编码yuv, 保存MP4视频文件.

RK3588 , mpp硬编码yuv, 保存MP4视频文件. ⚡️ 传送 ➡️ Ubuntu x64 架构, 交叉编译aarch64 FFmpeg mppRK3588, FFmpeg 拉流 RTSP, mpp 硬解码转RGBRk3588 FFmpeg 拉流 RTSP, 硬解码转RGBRK3588 , mpp硬编码yuv, 保存MP4视频文件.

34 Opencv 自定义角点检测

文章目录 cornerEigenValsAndVecscornerMinEigenVal示例 cornerEigenValsAndVecs void cornerEigenValsAndVecs(InputArray src, --单通道输入8位或浮点图像OutputArray dst, --输出图像&#xff0c;同源图像或CV_32FC(6)int blockSize, --邻域大小值int ape…

【前端面试】list转树、拍平, 指标,

这个题目涉及的是将一组具有父子关系的扁平数据转换为树形结构&#xff0c;通常称为“树形结构的构建”问题。类似的题目包括&#xff1a; 1. 组织架构转换 给定一个公司的员工列表&#xff0c;每个员工有 id 和 managerId&#xff0c;其中 managerId 表示该员工的上级。任务…

Flink执行模式(批和流)如何选择

DataStream API支持不同的运行时执行模式(batch/streaming),你可以根据自己的需求选择对应模式。 DataStream API的默认执行模式就是streaming,用于需要连续增量处理并且预计会一直保持在线的无界(数据源输入是无限的)作业。 而batch执行模式则用于有界(输入有限)作业…

The option ‘android.enableAapt2‘ is deprecated and should not be used anymore.

The option android.enableAapt2 is deprecated and should not be used anymore. Use android.enableAapt2true to remove this warning. It will be removed at the end of 2018.. android.enableAapt2已经被弃用了&#xff0c;不能被使用了,但是遍寻项目都找不到有使用过en…

构建高性能异步任务引擎:FastAPI + Celery + Redis

在现代应用开发中&#xff0c;异步任务处理是一个常见的需求。无论是数据处理、图像生成&#xff0c;还是复杂的计算任务&#xff0c;异步执行都能显著提升系统的响应速度和吞吐量。今天&#xff0c;我们将通过一个实际项目&#xff0c;探索如何使用 FastAPI、Celery 和 Redis …

go语言学习之错误记录-1、GOPROXY

go语言下载包时报错&#xff0c;更改代码仓库下载地址 go: golang.org/x/netv0.0.0-20210929193557-e81a3d93ecf6: Get “https://proxy.golang.org/golang.org/x/net/v/v0.0.0-20210929193557-e81a3d93ecf6.mod”: dial tcp 142.250.217.113:443: connectex: A connection at…

STM32中ADC模数转换器

一、ADC简介 ADC模拟-数字转换器 ADC可以将引脚连续变化的模拟电压转换为内存中存储的数字变量&#xff0c;建立模拟电路到数字电路的桥梁 12位逐次逼近型ADC&#xff0c;1us转换时间 输入电压范围&#xff1a; 0~3.3V&#xff0c;转换结果范围&#xff1a;0~4095 18个输入…