squid 파일 수정 여부 판단 메커니즘 분석

2197 단어 qui

전제:
1. 저 는 간단 한 http 서버 를 썼 습 니 다. 다음은 httpserver 라 고 부 릅 니 다.
2. 전단 에 squid 를 사용 하여 역방향 대 리 를 하고 다음은 squid 라 고 부른다.squid 는 http 서버 2 대 를 동시에 반대로 대 리 했 습 니 다. 그 중 하 나 는 httpserver 이 고 다른 하 나 는 nginx 입 니 다.
 
질문:
access. log 를 보면 squid 를 통 해 httpserver 에 있 는 파일 을 요청 할 때 squid 는 모두 TCPMISS。
하지만 같은 squid, nginx 파일 을 통 해 TCPHT, squid 자체 에 문제 가 없 을 것 임 을 설명 합 니 다. httpserver 에 문제 가 있 을 수도 있 습 니 다.
 
두서 가 없 으 니 가방 을 잡 고 분석 해 보 세 요.
 
첫 번 째 패키지 (squid 와 httpserver 사이 의 패키지):
squid 는 httpserver 에 GET 를 시 작 했 고 httpserver 는 정 보 를 되 돌려 주 었 습 니 다. httpcode 200. 문제 가 발견 되 지 않 았 습 니 다.
두 번 째 스냅 백 (squid 와 nginx 사이 의 가방):
squid 는 nginx 에 GET 를 시 작 했 습 니 다. nginx 는 200 을 되 돌려 주 는 것 이 아니 라 304 not modified 를 되 돌려 줍 니 다.
http header 를 보 니 squid 가 GET 요청 을 보 냈 을 때 http header 중 하나 가 있 습 니 다. If - Modified - Since: Sat, 15 Feb 2014 08: 36: 33
nginx 가 squid 를 답장 할 때 http header 중 하나 가 있 습 니 다. Last - Modified: Sat, 15 Feb 2014 08: 36: 33 GMT
 
뭔 가 발견 한 것 같 습 니 다.
대 화 는 대체로 이렇다.
squid 질문 nginx: 15 Feb 2014 08: 36: 33 이 시간 부터 이 파일 은 수정 되 었 습 니까?
nginx 정 답 squid: 지난번 수정 시간 은 15 Feb 2014 08: 36: 33
이 파일 이 수정 되 지 않 아 캐 시 확인 과정 이 완료 됐다 는 것 이다.
 
세 번 째 스냅 백 (squid 와 nginx 사이 에 캐 시 되 지 않 은 파일 을 잡 습 니 다):
squid 는 nginx 에 GET 를 시 작 했 고 nginx 는 200 을 되 돌려 주 었 습 니 다. http header 중 하 나 는 Cache - Control: max - age = 25920 입 니 다.
이 http header 는 이 파일 이 캐 시 가능 하고 캐 시 시간 은 25920 임 을 설명 합 니 다.
 
그럼 httpserver 는 이렇게 고 쳐 야 합 니 다.
1. 파일 을 보 낸 http header 에 Cache - Control 추가
2. 요청 한 http header 의 If - Modified - Since 항목 을 처리 합 니 다.
 
Last - Modified 형식 코드 는 다음 과 같 습 니 다.
즉석에서 쓴 것 이 니, 격식 은 고 쳐 야 한다.
1
2
3
4
5 //Last-Modified: Sat, 15 Feb 2014 08:36:33 GMT\r
time_t tNowTime = time(NULL); tm* tTm= localtime(&tNowTime); char achbuff[ 100 ] = { 0 }; strftime(achbuff, 100 , "Last-Modified: %a, %d %b %Y %H:%M:%S GMT\r
\r
"
, tTm);

좋은 웹페이지 즐겨찾기