Portál AbcLinuxu, 9. listopadu 2025 07:01
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, ...}) = 0
U 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) = 0
Nevidí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.