웹 개발

웹 사이트 최적화

노루아부지 2019. 8. 15. 12:46
반응형

1. HTTP 요청을 줄여라.
우리가 웹에서 URL 입력 후 엔터를 치면 페이지가 보이게 된다.
페이지에 이미지가 3개라고 하면 총 4번의 요청이 생기게 된다.
1번(HTML) + 3번(이미지)
요청이 많으면 많을수록 속도가 느려지는 것은 당연할 것이다.
그럼 어떠한 방법으로 HTTP 요청을 최소화 할 수 있을지 생각해 봐야한다.
제일 간단한 방법중 하나는 여러개의 이미지를 하나의 이미지로 생성한 후 그것을 css 로 사용하는 것이다.
이것을 css sprite 라고 한다.

2. 콘텐츠 전송 네트워크를 이용하라.
한곳에 집중되어 있는 서버 하나를 여러개로 나누는 것으로 생각할 수 있겠다.
한국에서 접속하는 서버가 미국에 있다면 당연히 느릴 것이다.

3. 헤더에 만료기한을 추가하라.
브라우저는 캐시를 이용하여 HTTP의 요청 수를 줄일 수 있다.
이 부분은 조금더 연구해 봐야겠다.

4. Gzip 컴포넌트.
이 부분은 조금더 연구해 봐야겠다.

5. 스타일시트는 위에 넣어라.
css는 무조건 먼저 빨리 받아서 처리해야 한다.
방법은 @import 요소보다는 link 태그를 사용하면 좋겠다.
이유는, 스타일시트가 아직 로딩 중인데 렌더링 트리를 구성하는 것은 상당히 비효율적이다.

6. 스크립트는 아래에 넣어라.

7. css Expression 을 피하라.

8. css와 자바스크립트는 외부 파일에 넣어라.
인라인으로 넣으면 더 빠르지만 자주 방문하는 페이지는 캐시가 되어야 하기 때문에 외부 파일로 넣는것이 적당하다.

9. DNS 조회를 줄여라.
설명은 패스--;;

10. 자바스크립트를 최소화하라.

11. 리다이렉트를 피하라.
리다이렉트(redirect)는 사용자를 한 URL에서 다른 URL로 다시 보내는 것을 말한다.
예를 들면, url 끝에 슬래시(/)를 빼먹는 경우 다시 슬래시(/)를 붙여서 해당 url 로 리다이렉트 한다.
그렇게 되면 성능에 치명적인 영향을 끼치게 된다.

12. 중복되는 스크립트 제거.

13. ETag를 설정하라.

14. 캐시를 지원하는 Ajax 만들기.


위의 내용들은 <웹 사이트 최적화 기법>이라는 책에 실린 내용이다.
저자는 Steve Souders 이다. 

조금더 내용이 추가된 <초고속 웹사이트 구축> 이라는 책도 있다.
예를 들면 이런 것이다.

css 셀렉터는 오른쪽에서 왼쪽으로 읽어들이기 때문에 하위 선택자가 구체적이지 않다면 성능에 문제를 일으킨다.

728x90
반응형
loading