下载源码
wget https://phoenixnap.dl.sourceforge.net/project/log4cplus/log4cplus-stable/2.1.2/log4cplus-2.1.2.tar.gz
如下图所示即为安装完成
解压&安装
执行下述命令,解压下载的源码,并且进入解压后的目录
tar -xzvf log4cplus-2.1.2.tar.gz
cd log4cplus-2.1.2
配置
cmake .. \
-DCMAKE_INSTALL_PREFIX=/usr/local \
-DLOG4CPLUS_BUILD_LOGGINGSERVER=ON \
-DLOG4CPLUS_BUILD_TESTS=ON \
-DLOG4CPLUS_ENABLE_DEBUG=ON \
-DLOG4CPLUS_MULTITHREADED=ON \
-DLOG4CPLUS_BUILD_STATIC_LIBS=OFF \
-DLOG4CPLUS_BUILD_SHARED_LIBS=ON
- cmake后面的“..”是指定上一级目录,因为当前目录是在新建的build目录下
-DCMAKE_INSTALL_PREFIX
:指定安装路径,默认是/usr/local
。-DLOG4CPLUS_BUILD_LOGGINGSERVER
:是否构建日志服务器(可选)。-DLOG4CPLUS_BUILD_TESTS
:是否构建测试程序(可选)。-DLOG4CPLUS_ENABLE_DEBUG
:是否启用调试信息。-DLOG4CPLUS_MULTITHREADED
:是否启用多线程支持(推荐开启)。-DLOG4CPLUS_BUILD_STATIC_LIBS
:是否构建静态库。-DLOG4CPLUS_BUILD_SHARED_LIBS
:是否构建动态库。
编译
执行下述命令进行编译
make -j$(nproc)
出现下图所示即代表编译成功
安装
执行下述命令进行安装
make install
出现下图所示即代表安装成功,在前面配置安装的路径(/usr/local)下能够找到对应的头文件和库文件,至此,后续开发时即可使用log4cplus了
验证
创建一个项目然后引用安装的log4cplus
引入库文件和头文件
在cmakelists中做如下编辑即可
cmake_minimum_required(VERSION 3.27)
project(log4cplusExample)
set(CMAKE_CXX_STANDARD 20)
add_executable(log4cplusExample main.cpp)
# 指定可执行文件的输出路径
set_target_properties(log4cplusExample PROPERTIES RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
# 指定log4cplus头文件路径
target_include_directories(log4cplusExample PRIVATE /usr/local/include/log4cplus)
# 指定log4cplus库文件路径
target_link_directories(log4cplusExample PRIVATE /usr/local/lib)
# 链接log4cplus库
target_link_libraries(log4cplusExample log4cplus)
设置log4cplus配置文件
log4cplus.rootLogger=DEBUG, stdout, file
log4cplus.appender.stdout=log4cplus::ConsoleAppender
log4cplus.appender.stdout.layout=log4cplus::PatternLayout
log4cplus.appender.stdout.layout.ConversionPattern=%d{%m/%d %H:%M:%S} %-5p %c{2} - %m%n
log4cplus.appender.file=log4cplus::FileAppender
log4cplus.appender.file.File=app.log
log4cplus.appender.file.layout=log4cplus::PatternLayout
log4cplus.appender.file.layout.ConversionPattern=%d{%m/%d %H:%M:%S} %-5p %c{2} - %m%n
测试执行
注意:配置文件的路径和可执行文件的路径一定要对应上,避免找不到配置文件
#include "log4cplus/log4cplus.h"
int main() {
// 加载.properties格式的配置文件
log4cplus::PropertyConfigurator config("/mnt/d/clion_project/log4cplusExample/config/log4cplus.properties");
config.configure();
// 记录一条日志
LOG4CPLUS_INFO(log4cplus::Logger::getRoot(), "Hello, log4cplus!");
LOG4CPLUS_WARN(log4cplus::Logger::getRoot(), "Hello, log4cplus!");
LOG4CPLUS_DEBUG(log4cplus::Logger::getRoot(), "Hello, log4cplus!");
return 0;
}
执行结果如下图所示