Portál AbcLinuxu, 10. května 2025 05:25
Přes strace -p PID
se připojte na běžícího klienta a pak v klientovi přepněte do problematického adresáře. Ve výstupu strace hledejte, které volání ohledně daného adresáře/souboru selhalo nebo vrací, co by nemělo.
Když to nepomůže, je třeba pustit klienta pod debuggerem a podívat, co se proč soubory daného adresáře nevrátí.
I když nejsem si jistý, jestli to je práce klienta nebo serveru.
select(58, [0 5 7 57], [], [], NULL ) = 1 (in [0]) read(0, "\r", 1) = 1 stat64("/mnt", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0 chdir("/mnt") = 0 rt_sigaction(SIGTSTP, {SIG_IGN, [], SA_RESTART}, {0xb720a8e0, [], SA_RESTART}, 8) = 0 poll([{fd=0, events=POLLIN}], 1, 0) = 0 (Timeout) poll([{fd=0, events=POLLIN}], 1, 0) = 0 (Timeout) write(1, "\r\33[52dReading directory...\10", 27) = 27 rt_sigaction(SIGTSTP, {0xb720a8e0, [], SA_RESTART}, NULL, 8) = 0 stat64("/mnt", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0 gettimeofday({1260954298, 428739}, NULL) = 0 open("/mnt", O_RDONLY|O_NONBLOCK|O_LARGEFILE|O_DIRECTORY|O_CLOEXEC) = 58 getdents64(58, /* 5 entries */, 32768) = 120 getdents64(58, /* 0 entries */, 32768) = 0 close(58) = 0 stat64("/mnt/nas", {st_mode=S_IFDIR|0775, st_size=0, ...}) = 0 stat64("/mnt/rum", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0 stat64("/mnt/test", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0U Mocp se tam píší automaticky nějaké timouty, ale zkusil jsem to prohledat
open("/mnt", O_RDONLY|O_NONBLOCK|O_LARGEFILE|O_DIRECTORY|O_CLOEXEC) = 4 getdents(4, /* 5 entries */, 32768) = 80 stat64("/mnt/test", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0 stat64("/mnt/rum", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0 stat64("/mnt/nas", {st_mode=S_IFDIR|0775, st_size=0, ...}) = 0 getdents(4, /* 0 entries */, 32768) = 0 close(4) = 0Nevidím v tom oproti cplay chdir. Seznam adresářů je v pořádku, ale v aplikaci /mnt/nas není vidět.
write(1, "\33[49;7H\33[37m\33[44mFiles: 2 "..., 56) = 56Přitom, tam v seznamu ty adresáře jsou 3.
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.