lstat64가 기존 디렉터리에서 실패함

lstat64가 기존 디렉터리에서 실패함

일정 기간 동안 디버깅 시도가 실패한 후move_uploaded_file전화해봤어

strace -s 8192 -o strace.log -f /etc/init.d/apache22 restart

더 많은 출력 중에서 다음 줄이 생성되었습니다.

5069  lstat64("/var", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0
5069  lstat64("/var/apache22", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0
5069  lstat64("/var/apache22/var", 0xbffe0f8c) = -1 ENOENT (No such file or directory)

(예, 경로가 좀 이상한 것으로 알고 있습니다. 레거시 애플리케이션입니다.)

문제는"/var/apache22/var"존재합니까?. 루트 세션에서 그대로 붙여넣습니다([괄호 안의 텍스트] 제외).

# ls -la "/var/apache22/var"      
total 24
drwxr-xr-x  6 root root 4096 Mar  7  2011 .
drwxr-xr-x  9 root root 4096 Jan 11 19:18 ..
drwxr-xr-x 10 root root 4096 Mar  7  2011 apache22
drwxr-xr-x  3 root root 4096 Mar  7  2011 log
drwxr-xr-x  2 root root 4096 Jan 11 19:36 run
drwxr-xr-x  3 root root 4096 Mar  7  2011 usr

# stat "/var/apache22/var"
  File: `/var/apache22/var'
  Size: 4096        Blocks: 8          IO Block: 4096   directory
Device: 804h/2052d  Inode: 539214      Links: 6
Access: (0755/drwxr-xr-x)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2012-01-11 19:46:47.000000000 +0100
Modify: 2011-03-07 23:27:57.000000000 +0100
Change: 2011-06-06 19:39:40.000000000 +0200

# mount
/dev/sda1 on / type ext3 (rw)
/dev/sda3 on /usr type ext3 (rw)
/dev/sda4 on /var type ext3 (rw)
sysfs on /sys type sysfs (rw)
/var/[product name] on /var/apache22/var/apache22/export/[product name] type none (rw,bind)

심볼릭 링크 없음:

# file / /var /var/apache22 /var/apache22/var
/:                 directory
/var:              directory
/var/apache22:     directory
/var/apache22/var: directory

# uname -r
2.6.29.6

답변1

Apache가 실행 중인지 확인chroot(). 내가 생각할 수 있는 것은 당신이 그 상황을 어디에서 보았는가뿐 /var/apache22/var이지만 실제로는 그런 의미가 아닙니다 /var/apache22/var.

관련 정보