sitelink1 http://blog.pages.kr/255 
sitelink2  
sitelink3  
sitelink4  
extra_vars5  
extra_vars6  

ETag는 Http1.1 에서 새롭게 등장한 header값인데 브라우져 캐쉬에 저장된 파일과 웹서버의 파일이 일치하는지를 판단하기 위한 방법중에 하나이다.

 

보통 ETag는 파일을 구분하기 위해 inode 값을 사용하는데 이게 여러대의 웹서버를 운영하는 환경에서는 접근하는 서버에 따라 inode 값이 다르기때문에 ETag 값도 달라기게 된다.

 

브라우져는 캐쉬된 파일의 갱신여부를 확인하기 위해서 수정일자와 ETag값을 사용하게 되는데 (이중에서 ETag값을 먼저 비교하고 수정일자를 나중에 비교한다.) 위와 같이 여러대의 서버를 사용하는 환경에서는 ETag값이 다르게 인식되어 다른 서버에 접근하게 되면 캐쉬를 지우고 새로 받게 된다.

 

많은 웹서버를 쓰는 환경에서는 캐쉬효율이 떨어져서 응답 속도가 느려질수 있다.
하여 보통 Inode 값을 빼던지 아예 ETag를 제거하든지 하는데..
우리는 ETag를 제거하여 사용하고 있다.

아래는 제거하는 설정이다.
이때 주의할점은 아파치 options의 -Indexes 설정을 추가하게 되면
ETag가 지워지지 않는다는 것이다. 반드시 Indexes 속성을 제거해줘야한다.

 

<vhost *>

...

 

FileETag None

#  <Directory "/env/tomcat4/webapps/section">
#    Options FollowSymLinks MultiViews #-Indexes 삭제해야함.
#    AllowOverride None
#    Order deny,allow
#    Allow from all
#    DirectoryIndex SectionMain.nhn
#  </Directory>

 

# expire 설정

 

#  <FilesMatch "\.(js|css|swf|gif|jpg)$">
#    ExpiresActive On
#    ExpiresDefault "access plus 1 years"
#  </FilesMatch>

 

# contents 압축설정
#  <Location />

 

#   AddOutputFilterByType DEFLATE text/html text/css application/x-javascript
#  </Location>

 

</vhost>

Apache 웹서버의 기본 ETag 값은 INode, MTime, Size 입니다. 한대의 웹서버로 운영을 할 경우는 문제가 없으나,  L4 장비를 통하여 로드밸런싱을 할 경우는 각 서버별로 INode 값이 다르기에 동일 이미지에 대하여 ETag 값이 다르기에 클라이언트에서 캐쉬된 정보를 사용하는 것이 아닌 서버에 재 요청을 하게 됩니다.

 

httpd.conf 에 아래와 같이 FileETag 값을 변경 후에 이미지서버의 네크워크 사용량이 아주 급격하게 줄어든 것을 확인 하실 수 있습니다. ( CVN 서비스를 사용할 경우는 반드시 설정하여 사용하시길 )

 

 

 

FileETag MTime Size

 

etag.png

 

 

참고

  • http://httpd.apache.org/docs/2.0/mod/core.html#fileetag
번호 제목 글쓴이 날짜 조회 수
125 div와 span의 차이점 (from Bing) 황제낙엽 2023.06.16 2
124 flexbox (flexible box layout) 황제낙엽 2023.02.27 0
123 characters from ISO 8859-1 황제낙엽 2020.11.10 28609
122 HTML FRAMESET 태그 예제 황제낙엽 2020.11.06 13
121 스마트 기기에서 여러 단말기의 해상도에 대응하기 위해 사용하는 HTML viewport meta tag 황제낙엽 2020.11.06 41
120 네이버의 무료 나눔 글꼴 황제낙엽 2020.05.06 1110
119 서버의 이미지나 txt 파일을 웹브라우저에서 다운로드하기 황제낙엽 2019.05.13 82
118 When to encode space to plus (+) or %20? (application/x-www-form-urlencoded) 황제낙엽 2019.04.15 99
117 HTTP/2 소개 황제낙엽 2018.10.12 59
116 글자, 문자, 텍스트, 글꼴, 서체, 폰트와 관련한 속성들 / font-size , 크기 단위(em, px, pt, rem), 절대 단위, 상대 단위 황제낙엽 2018.04.18 147
115 Pragma와 Cache-Control 황제낙엽 2018.03.28 61
» 로드밸런싱(L4)+아파치를 운영시 etag제거로 캐시 성능 최적화 file 황제낙엽 2018.03.28 226
113 HTTP 요청 헤더 III - If-Match, If-Modified-Since, If-None-Match file 황제낙엽 2018.03.27 87
112 재미난 로그인 페이지 만들기 file 황제낙엽 2018.03.26 202
111 HTTP Cache-Control 요청 지시어 황제낙엽 2018.03.09 67
110 내 웹사이트의 속도를 빠르게! file 황제낙엽 2018.03.07 183
109 성능을 위한 초간단 HTTP 304 Not Modified 구현 방법 file 황제낙엽 2018.03.07 97
108 accept 와 Content-type의 차이는? 황제낙엽 2018.03.07 59
107 [MIME type/content type/media type] text/javascript와 application/javascript의 차이점 황제낙엽 2017.11.23 166
106 User Agent 에 관련된 링크 황제낙엽 2017.11.20 595