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

devtools/2024/12/22 19:01:11/

在 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/devtools/144452.html

相关文章

文件,IO流

目录 一 java 1. IO流 1&#xff09;输入输出&#xff08;以程序的视角判断 &#xff09; 1.1 IO流的分类 1&#xff09;字符流效率高于字节流 1.2 流和文件的关系 2. inputstream--字节输入流 2.1 fileinputstream 2.1.1常用方法&#xff1a; 1&#xff09;单个字符…

vscode的keil assistant 中搜索不到全局变量

搜不到 但是在包含的文件中输入 ../../../,就是全局搜索的结果 我的文件结构是&#xff1a;\Desktop\LVGL文件系统移植&#xff08;lvgl8&#xff0e;&#xff13;&#xff09;\Projects\MDK-ARM 盲猜是keil assistant 当前文件夹打开的时候是进入到了MDK-ARM文件夹层次&…

Python tkinter写的《电脑装配单》和 Html版 可打印 可导出 excel 文件

Python版 样图&#xff1a; 说明书&#xff1a; markdown # 电脑配置单使用说明书 ## 一、软件简介 电脑配置单是一个用于创建和比较两套电脑配置方案的工具软件。用户可以选择各种电脑配件,输入数量和价格,软件会自动计算总金额,并支持导出和打印配置单。 ## 二、主要功能 1. …

免登陆是什么?

‌免登陆‌是指用户在访问系统或应用时&#xff0c;无需输入用户名和密码即可直接使用某些功能或服务。这种机制主要通过记录用户的身份信息&#xff0c;并在后续访问时通过会话管理、Token认证等方式进行身份验证&#xff0c;从而提升用户体验并减少登录负担‌。 实现原理 ‌…

Java进程占用的内存有哪些部分?

大家好&#xff0c;我是锋哥。今天分享关于【Java进程占用的内存有哪些部分?】面试题。希望对大家有帮助&#xff1b; Java进程占用的内存有哪些部分? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Java进程在运行时&#xff0c;会将内存划分为多个区域&#xf…

【0374】Postgres内核 MultiXactState shared memory 初始化 ( 2 - 1)

上一篇: 【0373】Postgres内核 MultiXact shared memory 初始化 ( 2 ) 1. 初始化 MultiXactState 本文是作为 【0373】Postgres内核 MultiXact shared memory 初始化 ( 2 ) 的续篇,因为在 MultiXactShmemInit() 函数中, 一共完成了 MultiXactOffsetCtl(MultiXactOffs…

利用 Python 解决 “奇数之和” 问题

一、问题描述 在这个问题场景中&#xff0c;有着特定的时间和内存限制&#xff0c;每次测试时间限制为 2 秒&#xff0c;每个测试的内存限制为 256 MB。我们会获得两个整数 n 和 k&#xff0c;任务是判断 n 是否可以表示为 k 个不同的正奇数&#xff08;不能被 2 整除的整数&a…

GaussDB数据库迁移方案介绍

云数据库GaussDB提供了多种数据迁移方案&#xff0c;可满足从MySQL数据库、Oracle数据库、GaussDB数据库、PostgreSQL数据库、DB2 for LUW、RDS for SQL Server、Microsoft SQL Server数据库到云数据库GaussDB的迁移。 数据迁移工具有DRS、DAS和gs_loader。推荐使用DRS&#x…