使用指定glibc编译程序

https://blog.csdn.net/jefbai/article/details/47859335

有时候我们需要测试不同的glibc的性能,此时可以使用如下命令来指定动态库加载器和glibc,

 g++ test_log.c -Wl,--rpath=/usr/local/lib -Wl,--dynamic-linker=/usr/local/lib/ld-linux-x86-64.so.2 
1
其中/usr/local/lib为glibc动态库的路径,linker为动态装载器
以下test_log.c代码为例

/*
 *  learn for syslog/openlog 
 *
 *
 * */
#include <syslog.h>
#include <stdio.h>
#include <stdlib.h>


int main(int argc,char **argv)
{
    //check the argc,usage e.g. ./a.out filename 
    if(argc != 2){
        perror("argc != 2");
        exit(1);    
    }
    openlog(argv[0],LOG_PID | LOG_NOWAIT | LOG_NDELAY,LOG_USER);

    syslog(LOG_INFO,"%s","hello,world");
    closelog();
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
使用上述命令编译后,可以用/usr/bin/ldd查看a.out依赖的动态库

[jefby@localhost work]$ /usr/bin/ldd a.out 
    linux-vdso.so.1 =>  (0x00007fff3d9ff000)
    libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x0000003c67400000)
    libm.so.6 => /usr/local/lib/libm.so.6 (0x00007fdf9bc5c000)
    libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x0000003c67000000)
    libc.so.6 => /usr/local/lib/libc.so.6 (0x00007fdf9b8b8000)
    /usr/local/lib/ld-linux-x86-64.so.2 => /lib64/ld-linux-x86-64.so.2 (0x0000003c5a000000)
1
2
3
4
5
6
7
说明已经替换成功,运行

./a.out jefby
1
然后使用tail来查看是否成功写入系统日志中

sudo tail /var/log/messages
1
如下所示,可以看到已经成功写入:

[jefby@localhost work]$ ./a.out jefby
[jefby@localhost work]$ sudo tail /var/log/messages -n 1
Aug 22 14:30:02 localhost ./a.out[12965]: hello,world
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值