每天乙個linux命令(69) ldd 命令

2021-09-26 10:19:34 字數 3672 閱讀 9278

linux ldd引數說明:

--version  列印ldd的版本號

-v --verbose  列印所有資訊,例如包括符號的版本資訊

-d --data-relocs  執行符號重部署,並報告缺少的目標物件(只對elf格式適用)

-r --function-relocs  對目標物件和函式執行重新部署,並報告缺少的目標物件和函式(只對elf格式適用)

--help 用法資訊

如果命令列中給定的庫名字包含'/',這個程式的libc5版本將使用它作為庫名字;否則它將在標準位置搜尋庫。執行乙個當前目錄下的共享庫,加字首"./"。

錯誤:ldd不能工作在a.out格式的共享庫上。

ldd不能工作在一些非常老的a.out程式上,這些程式在支援ldd的編譯器發行前已經建立。如果你在這種型別的程式上使用ldd,程式將嘗試argc = 0的執行方式,其結果不可預知。

例如:ldd /bin/bash

但是ldd本身不是乙個程式,而僅是乙個shell指令碼:

$ which ldd

/usr/bin/ldd

$ file /usr/bin/ldd

/usr/bin/ldd: bourne-again shell script text executable

ldd命令其實是依靠設定一些環境變數而實現的(也就是說ldd的作用只是設定一些環境變數的值)

如:ld_trace_loaded_objects

只要設定其值非空即可。

$ export ld_trace_loaded_objects=1

$ ls /usr

linux-gate.so.1 =>  (0xb7fac000)

librt.so.1 => /lib/tls/i686/cmov/librt.so.1 (0xb7f93000)

libselinux.so.1 => /lib/libselinux.so.1 (0xb7f79000)

libacl.so.1 => /lib/libacl.so.1 (0xb7f70000)

libc.so.6 => /lib/tls/i686/cmov/libc.so.6 (0xb7e0d000)

libpthread.so.0 => /lib/tls/i686/cmov/libpthread.so.0 (0xb7df4000)

/lib/ld-linux.so.2 (0xb7fad000)

libdl.so.2 => /lib/tls/i686/cmov/libdl.so.2 (0xb7df0000)

libattr.so.1 => /lib/libattr.so.1 (0xb7dea000)

撤銷該環境變數,ls即又可以恢復正常使用:

$ unset ld_trace_loaded_objects

$ ls  /usr/

bin  games  include  lib  lib32  lib64  local  sbin  share  src  x11r6

更多的環境變數:

1、ld_trace_loaded_objects

2、ld_warn

3、ld_bind_now

4、ld_library_version

5、ld_verbose

6、ld_debug

ldd預設開啟的環境變數是:ld_trace_loaded_objects=1

其他的變數(和值)分別對應一些選項:

-d, --data-relocs -> ld_warn=yes

-r, --function-relocs ->ld_warn和ld_bind_now=yes

-u, --unused -> ld_debug="unused"

-v, --verbose -> ld_verbose=yes

ld_trace_loaded_objects為必要環境變數,其他視具體情況。

ldd命令的本質是執行了:/lib/ld-linux.so.*

我們可以從以上的內容中(ls /usr中)發現:/lib/ld-linux.so.2 (0xb7fad000)。

$ ls -l /lib/ld-linux.so.*

lrwxrwxrwx 1 root root 9 2009-09-05 22:54 /lib/ld-linux.so.2 -> ld-2.9.so

剛編譯後的檔案可能是:/lib/ld.so。如果是libc5則是/lib/ld-linux.so.1, 而glibc2應該是/lib/ld-linux.so.2。

$ /lib/ld-linux.so.2  --list /bin/ls

1、首先ldd不是乙個可執行程式,而只是乙個shell指令碼

2、ldd能夠顯示可執行模組的dependency,其原理是通過設定一系列的環境變數,如下:ld_trace_loaded_objects、ld_warn、ld_bind_now、ld_library_version、ld_verbose等。當ld_trace_loaded_objects環境變數不為空時,任何可執行程式在執行時,它都會只顯示模組的dependency,而程式並不真正執行。要不你可以在shell終端測試一下,如下:

(1) export ld_trace_loaded_objects=1

(2) 再執行任何的程式,如ls等,看看程式的執行結果

3、ldd顯示可執行模組的dependency的工作原理,其實質是通過ld-linux.so(elf動態庫的裝載器)來實現的。我們知道,ld-linux.so模組會先於executable模組程式工作,並獲得控制權,因此當上述的那些環境變數被設定時,ld-linux.so選擇了顯示可執行模組的dependency。

4、實際上可以直接執行ld-linux.so模組,如:/lib/ld-linux.so.2 --list program(這相當於ldd program)ldd命令使用方法(摘自ldd --help)

名稱 ldd - 列印共享庫的依賴關係

大綱 ldd [選項]... 檔案...

描述 ldd 輸出在命令列上指定的每個程式或共享庫需要的共享庫。 選項

--version

列印ldd的版本號

-v --verbose

列印所有資訊,例如包括符號的版本資訊

-d --data-relocs

執行符號重部署,並報告缺少的目標物件(只對elf格式適用)

-r --function-relocs

對目標物件和函式執行重新部署,並報告缺少的目標物件和函式(只對elf格式適用)

--help 用法資訊

ldd的標準版本與glibc2一起提供。libc5與老版本以前提供,在一些系統中還存在。在libc5版本中長選項不支援。另一方面,glibc2版本不支援-v選項,只提供等價的--version選項。

如果命令列中給定的庫名字包含'/',這個程式的libc5版本將使用它作為庫名字;否則它將在標準位置搜尋庫。執行乙個當前目錄下的共享庫,加字首"./"。

ldd不能工作在a.out格式的共享庫上。

ldd不能工作在一些非常老的a.out程式上,這些程式在支援ldd的編譯器發行前已經建立。如果你在這種型別的程式上使用ldd,程式將嘗試argc = 0的執行方式,其結果不可預知。

每天乙個Linux命令

將我遇到的linux指令總結一下,不斷增加 1 sz和rz 一般來說,linux 伺服器大多是通過 ssh客戶端來進行遠端的登陸和管理的,使用 ssh登陸 linux ssh有關的兩個命令可以提供很方便的操作 sz 將選定的檔案傳送 send 到本地機器 rz 執行該命令會彈出乙個檔案選擇視窗,從本...

每天乙個linux命令

linux cmp命令 linux cmp命令用於比較兩個檔案是否有差異。當相互比較的兩個檔案完全一樣時,則該指令不會顯示任何資訊。若發現有所差異,缺省會標示出第乙個不同之處的字元和列數編號。若不指定任何檔名稱或是所給予的檔名為 則cmp指令會從標準輸入裝置讀取資料。語法cmp clsv i 字元數...

每天乙個 Linux 命令

head 與 tail 就像它的名字一樣的淺顯易懂,它是用來顯示開頭或結尾某個數量的文字區塊,head 用來顯示檔案的開頭至標準輸出中,而 tail 想當然爾就是看檔案的結尾。1 命令格式 head 引數 檔案 2 命令功能 head 用來顯示檔案的開頭至標準輸出中,預設head命令列印其相應檔案的...