키즈@IT/Online/SW 이슈&리뷰 l 2011/04/14 07:00 | Posted by 라디오키즈
대략 1997년께 내가 써본 첫 브라우저는 시대를 풍미한 넷스케이프였지만 천하를 호령했던 넷스케이프도 마이크로소프트가 인터넷 익스플로러를 인수한 후 끼워팔기 신공으로 배포하기 시작하면서  무너져 내리기 시작했다. 뭐 그런저런 상황을 확인할 수 있는 그래프 하나...

Techking이 정리한 The History of Web Browsers라는 이름의 브라우저 연대기다.
1994년 넷스케이프 0.X 버전 시절부터 출발한 거의 모든 웹브라우저의 역사랄까~


거의 모든 웹브라우저의 역사...



오페라가 저렇게 오래전부터 있었구나를 새삼 느끼게 해주는 90년대 후반.
허나 -_- 오페라는 그때도 그저 한줄기 선에 불과했으니 사양길에 들어서는 넷스케이프와 인터넷 익스플로러의 성장이 돋보인다.

이어지는 2000년대 초. 바야흐로 인터넷 익스플로러의 전성시대다.
끼어팔기로 소송까지 당했지만 어쨌든 인터넷 익스플로러 6를 내놓으며 시장을 본격적으로 호령하기 시작한 마이크로소프트. 사족이지만 벌써 10년이나 된 녀석을 쓰고 있는 당신, 어여 업그레이드 하시라.


짠~ 이런 와중에 등장한게 바로 파이어버드. 파이어폭스의 뿌리가 되는 녀석이다. 
몰락하는 넷스케이프를 대신해 시장을 양분하다시피한 강력한 라이벌의 등장. 사파리도 이 즈음 모습을 드러냈다.

2005년을 넘기며 웹브라우저 시장은 다시 요동친다.
절대 강자로 보였던 인터넷 익스플로러가 조금씩 입지를 잃어가는 반면 파이어폭스는 폭넓은 플러그인과 오픈소스 진영의 지지를 받으며 메이저로 커가기 시작한다.


그렇게 달려온 2011년. 
인터넷 익스플로러는 어느새 9를 찍었고 파이어폭스도 4.0을, 여전히 PC 시장에서 입지가 작은 사파리와 오페라 대신 크롬도 10.0을 찍으며 순항 중이다. 

절대 강자 인터넷 익스플로러의 침체로 다시 춘추전국시대로 들어서고 있는 웹브라우저 시장. 2011년을 넘기며 시장은 또 어떻게 움직이려나. 이 그래프가 앞으로 또 어떤 행보를 보일지 지켜볼 일이다.

더 보기 넷스케이프부터 파이어폭스 4.0까지... 거의 모든 웹브라우저의 역사... :: 라디오키즈@LifeLog http://www.neoearly.net/2464719#ixzz1kHJOIynr
 


==================================================================================


‘넷스케이프부터 크롬까지’ 웹브라우저 15년사 총정리
by IDG Korea | 2009. 10. 09

인터넷 역사에 있어 큰 이정표가 된 웹 브라우저가 2009년 10월 13일로 15해를 맞는다. 그 때 바로 최초의 상용 웹브라우저, 그러니까 결국 넷스케이프 내비게이터라 불린 것이 베타코드로 출시되었다. 월드와이드웹의 창시자 팀 버너스 리와 국립 슈퍼컴퓨터 활용센터에서 일하는 팀을 포함한 연구자들이 1991년과 1994년 사이에 유닉스 브라우저를 만드는 사이 넷스케이프 내비게이터는 이런 작은 데스크톱 소프트웨어를 일반명사처럼 만들어버렸다. 일반 사용자가 웹 사이트에 올라온 텍스트와 이미지를 볼 수 있도록 함으로써 넷스케이프 내비게이터는 무수히 많은 브라우저 전쟁, 정부 주도의 법정소송 및 많은 소프트웨어 혁신과 함께 인터넷 시대를 여는데 일조했다. 웹 브라우저의 역사상 가장  빛나는 사건 15개를 꼽아본다.

최초의 상용 브라우저 출시 (1994년 10월 13일)

후에 넷스케이프 커뮤니케이션으로 개칭한 모자이크 커뮤니케이션은 모자이크 넷스케이프 0.9라는 이름의 웹 브라우저 베타 버전을 출시했다. 그것은 NCSA가 개발한 모자이크 코드에 기초한 것으로 모자이크 공동 창시자인 마크 안드레센이 넷스케이프의 공동 설립자였다. 이 브라우저는 후에 넷스케이프 내비게이터로 개칭되었다. 버전 1.0은 12월 15일 출시되었다. 내비게이터는 엄청난 성공을 거둔 최초의 상용 웹 브라우저로써 마이크로소프트가 이 시장에 진출해 시장을  점유하기 전에 90%의 시장점유율을 재빠르게 달성했다. 2000년까지 넷스케이프의 시장점유율은 1% 이하로 떨어질 것이라고 잔코 어소시에이츠는 말한다.

AP557E.JPG

웹 트래픽, 인터넷 점령 (1995년 4월 30)

넷스케이프가 브라우저를 출시한 지 6개월 후 웹 트래픽은 인터넷 상에서 주도적인 트래픽 타입이 되었다. 일례로 웹 트래픽은 국립과학 재단의 NSFNET 백본에서 트래픽의 21%를 차지한 반면 두 번째로 사용이 많은 파일 전송 프로토콜의 경우 트래픽의 14%를 차지한다고 livinginternet.com에서 밝힌 바 있다. 이는 비즈니스워크에 따르면 등장한 후 처음 2년 동안 5,000만부가 유통되었던 내비게이터가 빠르게 채택되었음을 나타낸다.

AP6B6B.JPG

마이크로소프트, 브라우저 시장 침범 (1995년 8월 24일)

마이크로소프트는 윈도우 95 플러스!팩에서 인터넷 익스플로러를 선보였다. 인터넷 익스플로러는 모자이크 브라우저를 뒷받침하는 기술을 보유한 NCSA의 한 분파인 스파이글래스로부터 라이선스를 받은 소프트웨어를 토대로 만들어졌다. 마이크로소프트는 인터넷 익스플로러를 자사의 운영체제에 번들로 묶어 그것을 무료로 제공했다. 마이크로소프트의 접근은 영악했다. 잔코 어소시에이츠에 따르면 2년 후 마이크로소프트는 49%의 시장 점유율로 넷스케이프의 46%를 앞서면서 선도적인 브라우저 공급업체로써 넷스케이프의 자리를 대신했다.

AP74CD.JPG

오페라, 표적은 모바일 기기 (1997년 1월 1일)노르웨이에 근거를 두고 있는 오페라 소프트웨어는  최초의 윈도우용 웹 브라우저를 출시했고 그 이름은 오페라 2.1였다. 오페라는 그 후 웹 브라우저 시장에선 2류 선수였다. 잔코 어소시에이츠에 따르면 현재는 1.1%의 시장점유율을 보이고 있다. 버전 10은 2009년 9월 1일 출시되었다. 오페라 소프트웨어는 윈도우, 맥, 리눅스 기기에서 4,000만 명의 사용자를 주장하고 있다. 그것의 모바일 버전인 오페라 미니는 많은 블랙베리 사용자를 포함해 3,000만 명이 사용하고 있다고 한다.

AP1C0D.JPG

넷스케이프, 오픈소스 모질라(Mozilla) 프로젝트 창설 (1998년 2월 23일)

넷스케이프는 오픈소스 개발자로써 무료 버전의 브라우저를 제공하게 될 모질라 협회를 창설했다. 1998년 2월까지 28%의 브라우저 시장을 점령했던 넷스케이프는 최초의 브라우저 전쟁에서 69%의 시장점유율을 보인 마이크로소프트에 대파됐다. 2003년 7월, 모질라 협회는 비영리인 모질라 재단으로 탈피했다. 2005년 영리기업인 모질라가 창립되었고 결국 인기 좋은 파이어폭스 브라우저를 내놓게 된다.

AP4929.JPG

브라우저 끼워 팔기에 대한 연방측의 마이크로소프트 소송 (1998년 5월 8일)

미국 법무부는 마이크로소프트가 자사의 인터넷 익스플로러 웹 브라우저를 자사의 윈도우 운영체제에 끼워 팔아 독점적 지배력을 남용했다며 마이크로소프트를 상대로 반독점 소송을 냈다. 법무부를 대변해 변론을 맡은 변호사 (사진의) 데이비드 보이스가 승소했고 평결은 항소심에서 유지되었다. 법무부는 2001년 마이크로소프트와 합의에 도달해 마이크로소프트측에 다른 회사들과 API를 공유토록 명했다. 마이크로소프트는 2009년 11월까지 이런 의무를 충족해야 한다.

AP0078.JPG

AOL, 넷스케이프 인수 (Nov. 24, 1998년 11월 24일)

AOL은 42억 달러에 넷스케이프를 인수하겠다는 계획을 발표했다. 이 거래는 주식교환 거래였고 1999년 인수 체결 당시에는 결국 100억 달러 이상의 가치를 냈다. 이 합병은 반독점을 이유로 미 법무부의 승인을 필요로 했다. 그러나 AOL은 넷스케이프의 내비게이터 시장점유 재탈환을 성공적으로 이끌지는 못했다. 결국 2007년 12월 AOL은 더 이상 넷스케이프 웹 브라우저를 지원하지 않겠다는 발표를 냈다.

AP487C.JPG

애플, 사파리 들고 브라우저 시장 성큼 (2003년 1월 7일)

애플은 사파리 베타 버전을 출시했다. 사파리는 그 해 말 맥 운영체제에 들어가는 표준 웹 브라우저가 되었다. 2007년 6월 애플은 윈도우 XP와 비스타 시스템용 사파리 버전을 출시했다. 또한 사파리는 애플의 아이폰에서도 사용되는 브라우저다. 2009년 6월 애플은 가속화된 성능, 향상된 윈도우와의 통합, 한 번에 볼 수 있는 사용자의 즐겨 찾기 웹사이트를 특징으로 하는 사파리 4를 내놓았다. 출시한 처음 3일 간 사파리 4는 무려 1,100만 카피가 다운로드되었다고 애플측은 밝혔다. 틈새를 비집고 들어간 사파리는 1%미만의 시장점유율을 보이고 있다.

AP577D.JPG

파이어폭스 출시, 컴퓨터광들의 마음 점유율 획득 (2004년 2월 9일)

모질라 재단이 파이어폭스 0.8이라는 파이어폭스 베타 버전을 출시했다. 이것은 곧 인터넷 익스플로러를 빠르게 대체할 대안으로써 빠르게 퍼져나갔다. 잔코에 따르면, 2004년까지 마이크로소프트의 브라우저 시장점유율은 87%를 웃돌았다. 그러나 파이어폭스가 출시된 지 6개월 내에 이것은 컴퓨터광들이 손꼽는 브라우저로 자리잡으면서 리눅스월드 엑스포에서는 수상의 영광을 안았고 와이어드 매거진에서는 인기작으로 불렸다. 파이어폭스는 인기를 먹고 성장했고 오늘날 이 오픈소스 브라우저는 19.2%라는 시장점유율을 보유하고 있다.

AP7707.JPG

오페라, 마이크로소프트를 상대로 반독점 소송 제기 (2007년 12월 13일)

오페라는 마이크로소프트가 인터넷 익스플로러를 윈도우 운영체제에 통합하고 열린 웹 표준을 준수하지 않아 반독점법을 위반하고 있다고 주장하며 (사진의 네일리 크루스가 수장으로 있는) 유럽집행위원회에 소송을 냈다. 마이크로소프트는 자사의 고객에게 윈도우 7에 인터넷 익스플로러를 기본으로 설치하는 것보다 다운로드할 수 있는 브라우저 목록으로 제공하는 방안을  제안했다. EC는 연말 전 이 소송이 합의되길 바란다는 입장을 표명하고 있다.

AP4DA3.JPG

웹 브라우저, 취약한 인터넷 목록에서 최고 자리 올라 (2008년 1월 14일)

처음으로 웹 브라우저 공격이 SANS 협회가 수집한 2009년 10대 사이버보안 골치거리 목록에서 최고의 자리를 차지했다. 정보보안 조사단에 따르면 신뢰성 있고 인기 있는 웹사이트에 배치된 악성 코드는 플래시나 퀵타임 같은 웹 브라우저의 구성요소를 이용하는 추세다. 이러한 공격은 정교화 및 일반화되고 있다. 2008년 12월 마이크로소프트는 인터넷 익스플로러의 공격이 “엄청나게 증가”했다. 그래서 마이크로소프트는 수차례 중 한 번 꼴로 브라우저 취약성에 대한 패치를 발빠르게 단행해야 했다.

AP1D2D.JPG

구글, 크롬 선보여 (2008년 9월 2일)

구글은 마이크로소프트 윈도우 시스템용 오픈소스 크롬 브라우저의 베타 버전을 발표했다. 구글은 2009년 6월 리눅스와 애플 매킨토시 시스템을 지원하는 개발자 버전을 제공했다. 현재 구글은 더욱 선명해진 레이아웃과 디자인으로 경쟁사보다 더욱 빠른 버전 제공을 목적으로 하는 크롬 버전 3을 작업 중에 있다. 지금까지 구글은 크롬으로 사용자보다는 언론의 주목을 끌어왔다. 잔코 어소시에이츠에 따르면 최근 크롬의 시장점유율은 3.7%다.

AP21D3.JPG

마이크로소프트, 경쟁사에 대응해 IE 개선 (2009년 3월 19일)

파이어폭스, 사파리, 오페라 및 크롬의 혁신작에 대응해 마이크로소프트는 인터넷 익스프롤러 버전 8을 출시했다. 이번 버전은 가장 빠르고 안정적이며 안전한 웹 브라우저라는 것이 마이크로소프트측의 설명이다. 혁신적 요소 한 가지는 웹 슬라이스다. 이것은 사용자에게 즐겨 찾는 사이트가 언제 갱신되는지를 통보한다. 향상된 또 다른 사항은 사용자가 더욱 쉽게 다수의 탭을 관리할 수 있게 된 점. 또한 IE는 “성인용 버전”이라는 별칭의 인프라이빗 브라우징을 제공한다. 마이크로소프트는 잔코 어소시에이츠에 따르면 68%까지 떨어진 시장점유율 때문에 자사의 웹 브라우저를 향상시켜야 한다는 압력을 받았다.

AP4376.JPG

모질라, 더 빠른 파이어폭스 출시 (2009년 6월 30일)

모질라는 최신 파이어폭스 버전을 출시했다. 이번 버전은 특히 웹 개발자를 위한 몇 가지 성능 개선을 제공한다. 가장 빠른 브라우저는 아니지만 파이어폭스 3.5는 크롬과 사파리와 비교할 때 상대적으로 경쟁력이 있다. 파이어폭스 3.5는 위치 인식 브라우징을 특징으로 하기 때문에 사용자가 더욱 쉽게 근처의 소매점이나 음식점을 찾을 수 있다. 또한 이미 크롬, 사파리 그리고 인터넷 익스플로러에서 도입했던 프라이빗 브라우징을 지원한다. 모질라측에 따르면 전세계 3억 명이 파이어폭스를 사용하고 있다고 한다.

AP64C4.JPG

넷스케이프 창립자, 브라우저 신생회사 지원 밝혀 (2009년 8월 13일)

NCSA 모자이크 프로젝트의 수장이자 넷스케이프 설립자인 마크 안드레센이 뉴욕타임즈에 록멜트(RockMelt)라는 신생 브라우저 회사의 지원이 나선다는 뜻을 밝혔다. 이 기사로 인해 이 신생회사가 페이스북 같은 사회적 관계망 사이트에 최적화된 브라우저를 만들어낼 것이라고 믿는 사람들이 많은 가운데 기술관련 언론에선 록멜트의 정체가 과연 무엇이냐에 대한 추측이 무수하게 쏟아져 나왔다.

AP385F.JPG

원문보기 : http://www.idg.co.kr/newscenter/common/newCommonView.do?newsId=59682

Posted by linuxism
,

역어셈블러

역컴파일은 클래스 파일을 가지고 원래 소스로 변환하는 것을 말하지만, 역어셈블은 클래스 파일의 내부의 기본 구조와 역어셈블코드(JVM의 바이너리 코드)만을 나오게 됩니다.

 

특정 클래스의 내부 전체를 보고 싶은 경우는 역컴파일러를 이용하셔야 하고, 클래스 내부의 상수/함수들의 목록을 간단히 보고자 할때는 javap를 이용하는 것이 대부분입니다
 

[출처] javap의유용성|작성자 하자두
 

javap -c HelloWorld1 -> 역어셈블한 결과를 화면에 출력 
javap -c HelloWorld1 > HelloWorld1.txt -> 역어셈블한 결과를 text File에 기록
javap -private HelloWorld1  -> All Class&Member  



역컴파일러
jad -r -8 -d ./src -s java /home/*.class

-r : 해당 패키지 형태로 디렉토리 구조를 만듬( restore package directory structure)
-d : 디컴파일될 디렉토리(-d <dir> - directory for output files)
-s java : 디컴파일된 파일의 확장자를 java로 하라
-8 : 유니코드를 ascii 코드로 변환하는것이다. 
/home/*.class : /home 디렉토리 아래의 모든 클래스들 지정

* jad 실행파일

jad.exe






Java 언어의 단점이자 장점이 바로 역컴파일(Decompile)이 쉽다는 겁니다. 특히 개발자 입장에서는 남의 소스를 API만 보고 이해하기가 쉽지 않은데(특히나 한국 개발자가 만든 API는... ㅡㅡ;) JAD를 활용하면 아주 쉽게 소스를 볼 수 있습니다.

Eclipse 개발환경을 사용한다면 딱 2 가지만 있으면 됩니다.

  • JAD Decompiler  : 역컴파일러
  • JadClipse Plugin : JAD를 사용할 수 있는 Eclipse Plugin

※ 가끔 오해하시는 경우가 있는데, JadClipse에는 역컴파일 기능이 없습니다. 그리고 JAD는 command 창에서 실행되는 프로그램입니다. 반드시 2개를 다 설치해야 작동이 되요.

1. 다운로드


2. 설치
  • JAD는 원하는 위치에 압축을 품면 끝입니다. Eclipse에서만 사용한다면 Path 등록도 필요없습니다.
  • JadClipse는 Update Site 를 통해 설치합니다. : http://jadclipse.sourceforge.net/update
    (Help > Install New Softwares)



Next > Next > Accept > Finish > Ok > Yes > Restart


3. 설정
설치가 잘 되었다면 아래그림처럼 Window > Preference 에서 좌측과 같이 'Decompiler' 메뉴가 나옵니다.
Decompiler로 Jad 선택하시고 formatter 사용 체크하세요.


제일중요한 거... Jad 메뉴의 'Path to decompiler'부분에 위에서 압축 풀었던 jad의 위치를 적어줍니다.

그 외에 특별히 설정해줄 건 없습니다. 

여기 까지 했는데 잘 안되는 경우가 있습니다. 파일 연결이 잘 안되어 있거나, Editor Viewer의 캐쉬가 남아 있는 경우인데 아래 그림 처럼 .class 파일의 기본에디터로 Decompiled Class File Viewer가 선택되어 있는지 확인해 봅니다. 그리고 이미 열려 있던 파일말고 다른 .class 파일을 열거나 eclipse를 다시 시작해보시면 잘 되요.



4. FAQ
  • JAD에는 치명적인 단점이 하나 있습니다. 바로 jar 를 지원하지 않습니다. jar 라이브러리의 압축이 풀려있어야 하는데, Eclipse의 Project Explorer에는 jar 라이브러리를 볼수 있도록 내부에서 압축을 풀어줍니다. 여기서 .class파일을 열면 정상 작동됩니다.
  • 두번 째 문제는... 개발이 중단된것 같습니다. JAD 개발자(Pavel Kouznetsov) 홈페이지가 없어졌습니다. 현재까지의 완성도만으로도 충분하긴 하지만, 향후 java 7 이 나오고 하면 문제가 될 수 있겠네요.
  • Java 역컴파일러는 JAD만 있는게 아닙니다. JD(Java Decompiler)JODE(Java Optimize and Decompile Environment) 라는 것도 있습니다. JAD를 보편적으로 많이 사용하네요. 
    JD-Eclipse Update site : http://java.decompiler.free.fr/jd-eclipse/update


출처 : http://powerhan.tistory.com/116










[Java] Java Decompiler (역컴파일러, 디컴파일러)
 by Sigel

그동안 Java 코드의 역컴파일(decompile)이 필요할 때면 jad를 찾아서 쓰곤 했다. 그다지 많지 않은 빈도로 사용하기 때문에 가지고 있지도 않고 필요할 때 마다 받아서 썼는데.. 내 머리에는 지우개가 있다. 어쩌면 메멘토를 찍고 있을지도 =ㅅ= 어디서 jad를 받아서 사용했는지 전혀 기억이 나질 않는다.

그래서 검색 도중.. 오~~ 이클립스에서 편하게 역컴파일을 할 수 있는 녀석을 발견했다. JadClipse라는 것인데.. 이클립스에서 class 파일을 더블클릭하면 jad를 실행해서 지정된 임시폴더로 역컴파일을 해서 넣고, 그 파일을 보여주는 것이다. 원래는 무료였으나, 지금은 상용으로 변경되었고 비상업적으로 이용하는 경우는 무료라고 한다.

첨부된 파일(jadnt158-rogerrb.zip)은 Eclipse 3.3(Europa)에서만 동작한다고 한다. 다른 버전의 JadClipse는 sourceforge(http://jadclipse.sourceforge.net/)에서 찾아보자.
Eclipse 3.4(Ganymede)에서도 동작한다.(2008. 11. 19. 수정)



설치 방법은 간단하다.
1. jad와 jadclipse JAR 파일을 받는다.
2. 받은 jadclipse JAR 파일을 이클립스의 plugins 폴더에 넣는다.
3. jad 파일을 적당한 위치에 넣는다. (앞으로 역컴파일이 필요할 때 마다 이 파일을 실행시키니 삭제되지 않을 수 있는 폴더로 결정한다. e.g. C:\Program Files\Jad\jad.exe)
4. 이클립스를 실행하여 Window > Preferences... > Java > JadClipse > Path to Decompiler의 설정값을 jad 파일로 설정한다. (e.g. C:\Program Files\Jad\jad.exe)
5. 역컴파일된 java 파일을 넣을 임시폴더를 Window > Preferences... > Java > JadClipse > Directory for temporary files에서 설정한다. (이 부분은 굳이 바꿔주지 않아도 된다.)

6. Window > Preferences... > General > Editors > File Associations 중 "*.class"의 설정값이 "JadClipse Class File Viewer"로 설정되었는지 확인한다. 끌-*




+ 한글이 깨지는 경우 Window > Preferences... > Java > JadClipse > Misc > Convert Unicode strings into ANSI strings를 체크해 주자.

+ 더블클릭 시 마다 역컴파일하는 수고를 덜기 위해 Window > Preferences... > Java > JadClipse > Reuse code buffer를 체크해 주자. 그러면 class 파일을 처음 더블클릭했을 때만 역컴파일을 하여 임시 폴더에 넣고, 다음부터는 그 폴더의 내용을 가져와서 보여준다.
jadnt158-rogerrb.zip : Eclipse 3.3 Europa용 JadClipse + jad

+ 소식 접한 곳
http://blog.naver.com/rogerrb/100041261641
http://blog.naver.com/ddoll22/10015500677 



출처 -  http://blog.naver.com/hazard11?Redirect=Log&logNo=80028989392 

http://standcode.blog.me/10005305787 






이클립스에서 자바 클래스 decompile 결과 보기


1. Help -> Install New Software... 를 누릅니다


Add 버튼을 눌러 Location에 http://jadclipse.sf.net/update 을 적고 OK를 누릅니다.

밑 플러그인 목록에 JDT Decompiler Features를 체크 하여 설치합니다.

이클립스를 재시작합니다.



2. Window -> Preferences

General -> Editors -> File Associations 에서

*.class를 선택하고 밑에서 편집기를 Decompiled Class File Viewer를 선택하여 Default 로 지정합니다.



Java -> Decompilers 에서

Decompiler를 Jad를 선택합니다.



3. http://www.varaneckas.com/jad 에서 jad를 다운받습니다.


압축을 풀어 이클립스 실행파일이 있는 폴더에 복사합니다.



4. 이제 편집기에서 소스가 궁금한 클래스명을 선택하고 F3을 누르면..

디컴파일된 소스가 보이게 됩니다.. 클래스에 따라서.. 결과가 제대로 나오지 않을 수도있습니다.. 

참고로 실제 소스와 완전히 같지 않기 때문에 디버깅시에 전혀 엉뚱한 라인을 가리킵니다..ㄱ-



출처 - http://zsoo.net/68











Posted by linuxism
,

tomcat - server.xml 설정

Web/WAS 2012. 1. 20. 23:32
  • Apache Tomcat 개요

  • Apache Tomcat Server7
    • 최신 톰캣 7.0은 현재 서블릿 API 3.0의 레퍼런스 구현입니다
    • servlet 그리고 JSP 웹 어플리케이션을 구동하기 위해 java 기반으로 개발 되었다.
    • Tomcat  메이저 버전은  Java Servlet 명세서 버전에 따라 간다.

  • The Tomcat Manager Web Application
    • Tomcat 서버와 함께 패키징 되어 배포된다.
    • / conext path에 설치되어 배포되어 지며 웹 어플리케이션을 관리하기 위한 기본적인 기능을 제공한다.
  • Specialized Realm Implementations
    • realms?  컨테이너에 의해 인증되어진 사용자 데이터베이스를 relams라고 부른다.
    • 톰캣은 두가지 타입의 realms을 제공한다. MemoryRealm, JDBCRealm
  • Tomcat Valves
    • Tomcat은 밸브 톰캣 4 소개된 기술이며, 모든 이후 버전에서 사용할 수있는.
    • 밸브는 특정 카탈리 컨테이너와 자바 클래스의 인스턴스를 연결할 수 있습니다.
    • 구성된 밸브의 클래스는 다음 컨테이너에 오는 모든 요청을위한 전처 리기 역할을하고 있습니다.
  • The Architecture of Tomcat
    • 톰캣 인스턴스, 또는 서버는 톰캣의 컨테이너 계층 구조에서 최상위 요소입니다.
    • 오직 하나의 톰캣 인스턴스만이 하나의 자바 가상 머신 (JVM)에 살고 있습니다.
    • 이러한 접근 방식은 케이스 톰캣 및 / 또는 JVM 충돌 안전, Tomcat 서버와 동일한 물리적 머신에서 실행하는 다른 모든 Java 응용 프로그램을 만듭니다.
    • 톰캣 인스턴스는 잘 정의된 계층에 존재하는 응용 프로그램 컨테이너의 그룹화로 구성되어 있습니다.
    • 그 계층의 주요 구성 요소는 카탈리나의 서블릿 엔진입니다.
    • 자바 서블릿 API에 명시된대로 카탈리나는 실제 자바 서블릿 컨테이너의 구현입니다.
    • Tomcat은 7 서블릿 API 3.0 Sun에서 최신 사양을 구현합니다.
    • Tomcat7의 아키텍처는 아래 XML 구조와 일치 한다.

  • The Server

그것은 전체 카탈리나의 서블릿 엔진을 상징하며 단일 톰캣 인스턴스의 최상위 요소로 사용됩니다.
<server>를 요소는 하나 이상의 <Service> 컨테이너를 포함할 수 있습니다.

  • The Service

단일 <Engine> 요소를 공유하는 하나 이상의 <Connector> 요소의 컬렉션을 보유하고 있다.
N개의 <Service>엘리먼트는 단일 <Server> 엘리먼트 안에 중첩될 수 있다.

  • The Connector

클라이언트으로 부터 호출 된 실제 request 및 response를 핸들링하는 클래스를 정의한다.

  • The Engine

<Service> 는 오직 하나의  Engine를 가진다.

 단일 <Engine> 컴포넌트는 <connector>컴포넌트에서 수신받은 모든 요청을 처리한다.

  • The Host

<Host> 요소는 카탈리나의 <Engine>의 각 인스턴스에 포함된 가상 호스트를 정의합니다.
각 <Host>는 하나 이상의 웹 어플리케이션의 부모가 될수 있다.

  • The Context

<Context> 요소는 Tomcat 인스턴스에서 가장 일반적으로 사용되는 컨테이너입니다.

각 <Context> 요소는 정의된 <Host> 내에서 실행되는 개별 웹 응용 프로그램을 나타냅니다.
<Host> 내에서 정의할 수 <Context> 수에는 제한이 없습니다

톰캣 인스턴스가 구동 되었다면 http://localhost:8080 에 접속한다.

port를 변경하기 위해서는 CATALINA_HOME/conf/server.xml 파일에 다음 내용을 수정한다.

<Connector port=”8080″ protocol=”HTTP/1.1″ connectionTimeout=”20000″ redirectPort=”8443″ />

<Connector port=”80″ protocol=”HTTP/1.1″ connectionTimeout=”20000″ redirectPort=”8443″ />

  • Tomcat에 웹 어플리케이션 배치

  • The Tomcat Directory Structure
    • /bin
      • startup, shutdown 스크립트를 포함하고 있다. 또한 톰캣을 구동하기 위해 필요한 jars 파일도 포함한다.
    • /conf
      • 톰캣을 위한 configuration 파일들을 가지고 있다.(server.xml, web.xml)
    • /lib
      • jar 파일들을 가지고 있으며 모든 톰캣 컴포넌트가 공유한다
      • 톰캣에 배치되는 모든 웹 어플리케이션은 여기에 저장된 라이브러리를 액세스 할 수 있다.
      • Servlet API 또는 JSP API 라이브러리를 포함한다.
    • /logs
      • 톰캣 로그 파일이 저장된다.
    • /temp
      • 임시 파일이 저장된다.
    • /webapps
      • 모든 웹 어플리케이션이 저장되는 디렉토리 (war)
    • /work
  • Executing Tomat scripts
    • catalina.sh or catalina.bat
      • 톰캣을 구동 또는 종료하는 스크립트
      • catalina arguments
        • catalina start
          • 새로운 분리 프로세스로서 톰캣 서버를 구동한다.
        • catalina stop
          • 톰캣 서버 중단
        • catalina run
          • 현재 윈도우 또는 터미널에서 톰캣을 구동한다 .현재 세션 또는 터머널에서만 유지
        • catalina debug
        • catalina version
        • catalina configtest
          • 현재 톰캣 구성이 정상적인지 테스트
        • catalina jpda start
          • JPDA 디버깅 모드로 구동
  • Passing Runtime Options to Catalina Script
    • 자바 어플리케이션을 구동할 때 JVM에 다른 옵션을 필요할 경우 도 있다. 가령 메모리 셋팅, 인코딩, 호스트네임, 포트
    • export JAVA_OPTS=”-Dfile.encoding=utf-8″
      • 위 옵션은 같은 로컬 머신에 구동하는 톰캣 뿐만 아니라 모든 자바 프로세스에 영향을 미친다.
    • export CATALINA_OPTS=” -Xms256m -Xmx1g -XX:MaxPermSize=256m”
      • 오직 톰캣 프로세스에만 영향을 미친다.
  • Tomcat Configuration Files(/conf)
    • 톰캣의 메인 설정 파일은 server.xml파일이다.
      • 톰캣의 주요한 engeines, hosts, conetext 설정 정보가 저장되어 있다.
    • context.xml은 default context 설정 정보가 저장되어 있다.
      • 톰캣의 모든 context가 설정 정보를 공유한다.
    • 각 context는 자신만의 고유한 설정 정보를 가질수 있다. 가령,
      • CATALINA_HOME/conf/ENGINE_NAME/HOST_NAME/CONTEXT_NAME.xml
  • JAVA Web Applications
    • 톰캣의 가장 중요한 기능은 자바 웹 어플리케이션의 컨테이너 기능을 수행하는 것이다.
    • Web Applications의 정의
      • 웹 어플리케이션은 서블릿, html 페이지, 클래스 그리고 다른 리소스 자원들의 집합이다.
      • 웹 어플리케이션은 다음 오브젝트 리스트의 결합을 담을수 있는 컨테이너(그릇)이다.
        • Servlets
        • Java Server Pages(JSPs)
        • Utility Classes
        • Static documents, including HTML, images, JavaScript libraires, CSS, 기타등등
        • Client side classes
        • Meta-informatin describing the web application
      • 각 웹 어플리케이션은 오직 하나의 서블릿 컨텍스트를 가진다.
  • Directory Structure
    • 기본 어플리케이션 디렉토리 위치
      • CATALINA_HOME/webapps
      • /apps
        • 웹 어플리케이션의 루트 디렉토리. JSP 그리고 HTML 파일이 저장된다.
        • root 디렉토리이다.
      • /apps/WEB-INF
        • root 디렉토리에 포함되지 않은 어플리케이션 리소스를 포함하고 있다.
        • 클라이언트에 의해 직접 액세스 되는 파일은 여기에 저장하면 안된다.
      • /apps/WEB-INF/classes
        • servlet 그리고 유틸리티 classes 저장 위치
      • /apps/WEB-INF/lib
        • Java Archive Filse(jar) 파일 저장 위치
    • 자바 클래스 로더는 classes 디렉토리의 클래스를 먼저 로드한 다음 lib 디렉토리의 jar 파일을 로드 한다.
    • classes와 lib에 동일한 오브젝트가 존재할 때 classes 디렉토리 위치의 오브젝트가 우선 한다.
  • Deployment Descriptor(배치 기술자) – web.xml
    • web.xml 파일은 WEB-INF/ 디렉토리에 위치한다.
    • 웹 어프리케이션의 전체 설정 정보를 가지고 있다.
    • 배치 기술자는 다음 내용을 포함하고 있다.
      • Servlet 정의
      • Servlet 초기화 파라메터
      • Session 설정 파라메터
      • Servlet/JSP 매핑
      • MIME type 매핑
      • 보안 설정
      • Welcome file list
      • 에러 페이지 리스트
      • 리소스 그리고 환경 변수
    • sample
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<?xml version="1.0" encoding="UTF-8"?>
    id="admin" version="2.5">
 
    <display-name>admin</display-name>
 
    <welcome-file-list>
        <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>
 
    <!-- ~~~~~~~~ application name ~~~~~~~~ -->
    <context-param>
        <param-name>webAppRootKey</param-name>
        <param-value>admin</param-value>
    </context-param>
 
    <!-- ~~~~~~~~ spring context loader ~~~~~~~~ -->
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <listener>
        <listener-class>
            org.springframework.web.context.request.RequestContextListener
        </listener-class>
    </listener>
 
    <!-- ~~~~~~~~ spring web dispatcher ~~~~~~~~ -->
    <servlet>
        <servlet-name>webDispatcher</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>
                classpath*:/META-INF/spring/admin.mvc.xml
            </param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
 
    <servlet-mapping>
        <servlet-name>webDispatcher</servlet-name>
        <url-pattern>*.jsp</url-pattern>
    </servlet-mapping>
 
    <!-- ~~~~~~~~ error page setting ~~~~~~~~ -->
    <error-page>
        <error-code>400</error-code>
        <location>/WEB-INF/views/error/error_400.jsp</location>
    </error-page>
 
    <!-- ~~~~~~~~ UTF-8 encoding ~~~~~~~~ -->
    <filter>
        <filter-name>encodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>UTF-8</param-value>
        </init-param>
        <init-param>
            <param-name>forceEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
 
</web-app>
  • Tomcat에 웹 어플리케이션 수동 설치
    • 새로운 웹 어플리케이션을 만들 때 가장 먼저 해야하는 일은 디렉토리 구조를 만드는 것이다.
    • 디렉토리 구조
      • /apps
      • /apps/WEB-INF/
      • /apps/images/
      • /apps/scripts/
      • /apps/styles/
    • /apps/WEB-INF/ 디렉토리는 오직 서블릿 컨테이너만 접근 가능 하다.
  • 서블릿 추가
    • javac HelloWorld.java -cp CATALINA_HOME/lib/servelet-api.jar
  • War Archive 배치
    • war 파일은 표준 자바 웹 어플리케이션 패키징 메소드이다.
    • java cvf apps.war .
    • 마지막에 period(.)  은 현재 디렉토리를 참조한다.
    • war 파일을 배치하기 위해서 /CATALINA_HOME/webapps 디렉토리에 복사한다.
    • war 파일을 unpack 하지 않기 위해서는 &lt;Context&gt; 엘리먼트를 다음과 같이 지정한다.  하지만 performance를 위해서라면 unpack 하는 것이 좋다.
    • <Context path=”/apps” docBase=”apps” unpackWar=”false”> =>  CATALINA_HOME/conf/server.xml


출처 - https://jonghwasu.wordpress.com/2013/02/01/apache-tomcat7/








C:\Tomcat 5.0\conf에 server.xml를 열어봅시다.

무쟈게 복잡하죵? ㅎㅎ

 

일단 하나하나씩 알아 봅시다.

 

server.xml는 다음과 같은 구조로 구성되어있습니다.

-. Top level Elements : <server>는 설정파일 전체에서 Root Element이며 반면에

    <service>는 하나의 Engine과 연관된 Connector들의 집합을 말합니다.

    top level elements에는 <server>, <service>등이 있습니다.

 

-. Connector : 외부 Client와 요청을 주고 응답을 받는 Interface를 말합니다.

    connector에는 <HTTP>, <AJP>등이 있습니다. 오호~ 프로토콜과 관계된 것들이군요

 

-. Containers : 요청을 받아 응답을 처리하는 기능들의 Component를 말합니다.

     하나의 Engine은 하나의 Service에대한 모든 요청을 처리하며,

     하나의 Host는 하나의 Virtual Host에 대한 모든 요청을 처리하며,

     하나의 Context는 하나의 Web Appliction에 대한 모든 요청을 처리합니다.

    container에는 <Context>, <Engine>, <Host>등이 있습니다.

 

-. Nested Component : Nested Component는  Container의 어느 Element안에 중첩될 수도

    있으며 어떤 Element들은 Container안에도 중첩될 수 있는 반면에 다른것들은

     Context안에만 중첩될 수 있다.

    <Logger>, <Realm>, <Resources>, <Loader>등이 있습니다.

 

위에서 보니 볼것이 생각외로 많습니다.

하지만 머니머니 해도 젤 중요한건 Context이겠죠. 요 Context만 살작 보겠습니다.

 

Context가 그럼 멀까요?

Context는 특별한 Viertual Host에서 작동하는 하나의 Web Application입니다.

각 Web Application은 하나의 Web Application Archive(WAR) file나,

이에 대응하는 unpacked된 Content를 가지는 directory를 말합니다.

 

Tomcat 4.x 대 까지만 해도 context는 server.xml에 기술할 수 있었습니다.

하지만 Tomcat 5.x대 부터는 달라졌더군요.

<Host> elements안에 contenxt를 추가할 수 있지만 xml형식의 개별적인 파일로 저장 할 수도 있습니다.

개별적으로 저장하려면 위치는 $CATALINA_HOME/conf/[enginename]/[hostname]/ directory 가 됩니다.

실제로 이 위치에 가보면 admin.xml등의 파일이 있는 것을 볼 수 있습니다.

디폴트로 된 context의 xml를 만들려면 ROOT.xml로 만드시면 됩니다.

참고로 tomcat문서에서는 <Context>를 server.xml에 직접 기술하는것을 강력히 비추천 하는군요 -ㅠ-

 

예제) ROOT.xml 입니다. (reloadable="true"를 추가했군요~)

<Context path="" docBase="${catalina.home}/webapps/ROOT"
        debug="0" privileged="true" reloadable="true">

  <Logger className="org.apache.catalina.logger.FileLogger"
                 directory="logs"  prefix="localhost_log." suffix=".txt"
            timestamp="true"/>

</Context>

Logger를 잠시보면 로거로 FileLogger라는 클래스를 사용할 것이며

디렉토리는 톰캣의 logs디렉토리를, 파일명은 localhost_log.yyyy-mm-dd.txt로 하겠다는 겁니다.

 

여기에 test라는 Context를 하나 더 추가해 봅시다.

우선 test.xml을 다음과 같이 만들어 봅시다.

<Context path="/test" docBase="${catalina.home}/webapps/test"
        debug="0" privileged="true" reloadable="true">

  <Logger className="org.apache.catalina.logger.FileLogger"
                 directory="logs"  prefix="localhost_log." suffix=".txt"
            timestamp="true"/>

</Context>

path에는 context 경로를 적습니다. 각 요청 URI의 시작부분이 context 경로와 같을 때 해당 웹어플리케이션이 그 요청을 처리하게 됩니다. docBase는 이 웹어플리케이션에 대한 파일 경로입니다

설정 끝~

http://localhost:8080/test 를 요청하게 되면 해당 /webapps/test 밑에 있는 파일을 요청하게 됩니다

 

그럼 Context의 속성을 알아봅시다.

 

속성설명
backgroundProcessorDelay이 값은 컨텍스트와 그 자식 컨테이너에서 background process method가 invoke되는 delay 시간을 나타낸다.
이 값을 양수로 설정하면 어떤 쓰레드가 분기되어 일정 시간 후에 이 쓰레드가 해당 host와 자식 컨테이너에서 background process method를 실행시킵니다
만약 설정하지 않으면 디폴트값인 -1을 가지며 음수의 값은 부모 host의 background processing 정책을 사용한다는 것입니다.
참고로 컨텍스트는 세션을 종료하거나 클래스 리로딩을 위한 모니터링등을 위해 background processing을 사용합니다.
className

사용할 Java 구현체 클래스의 이름. 이 클래스는 반드시 org.apache.catalina.Context 인터페이스를 구현해야 합니다. 지정하지 않으면 표준값 (아래에 정의됩니다)이 사용됩니다

cookies

true(디폴트)로 지정하면 클라이언트가 쿠키를 지원하는 경우 세션확인의 통신수단(session identifier communication)으로 쿠키를 사용합니다. false로 지정하면 세션확인의 통신수단으로 쿠키 사용을 하지 않고, 어플리케이션에 의한 URL 다시쓰기(URL rewriting)에만 의존한다는 의미입니다.

crossContext

true로 지정하면 이 어플리케이션에서 ServletContext.getContext() 호출을 통해, 이 가상호스트에서 실행중인 다른 웹어플리케이션에 대한 요청디스패쳐(request dispatcher)를 성공적으로 얻을 수 있습니다. 보안상의 이유로 false(디폴트)로 지정하면 getContext()는 언제나 null을 반환하게 됩니다.

docBase

이 웹어플리케이션에 대한 Document Base (Context Root로도 알려져 있습니다) 디렉토리, 또는 웹어플리케이션 아카이브 파일의 경로명(웹어플리케이션을 WAR 파일로 직접 실행하는 경우)을 나타냅니다. 이 디렉토리나 WAR 파일에에 대한 절대경로명을 지정할 수도 있고, 이 Context가 정의된 Host의 appBase 디렉토리에 대한 상대경로명을 지정할 수도 있습니다

overridetrue로 설정하면 DefaultContext element를 관련된 host에서 명백하게 상속받아 사용합니다
기본값으로 Defaultcontext element가 사용됩니다
privileged

true로 설정하면 이 컨텍스트는 관리자서블릿(manager servlet) 같은 컨테이너 서블릿을 사용할 수 있습니다.

path

이 웹어플리케이션의 컨텍스트 경로(context path)를 나타내며, 각 요청 URI의 시작부분이 컨텍스트 경로와 같을 때 해당 웹어플리케이션이 그 요청을 처리하게 됩니다. 하나의 특정 Host 내의 컨텍스트 경로들은 모두 각각 유일해야 합니다. 만약 컨텍스트 경로를 빈 스트링("")으로 지정하면, 이 Context는 이 Host에 대한 디폴트 웹어플리케이션으로 정의된 것입니다. 디폴트 웹어플리케이션은 다른 Context 들에 해당되지 않는 모든 요청을 처리할 것입니다.

reloadable

true로 지정하면, Catalina는 /WEB-INF/classes/와 /WEB-INF/lib 안 클래스 들의 변경여부를 감시하다가, 변경이 발견되면 웹어플리케이션을 자동으로 재적재(reload)합니다. 이 기능은 개발중에는 매우 유용하지만 얼마간의 실행부하(runtime overhead)가 발생하므로, 실제 운영할 용도로 어플리케이션을 배치(deploy)할 때는 사용하지 않도록 합니다. 그러나 이미 배치가 끝난 어플리케이션이라도 Manager 웹어플리케이션을 이용하면 필요할 때 재적재 하도록 할 수 있습니다

wrapperClass

이 Context로 관리할 서블릿 들에 대해 사용할 org.apache.catalina.Wrapper 구현체 클래스의 Java 클래스명입니다. 지정하지 않으면 표준값이 사용됩니다

 

from http://jakarta.apache.org

 

=============================================

본문서는 자유롭게 배포/복사 할수 있지만

이문서의 저자에 대한 언급을 삭제하시면 안됩니다

저자 : GoodBug (unicorn@jakartaproject.com)

최초 : http://www.jakartaproject.com 

=============================================


출처 -  http://www.jakartaproject.com/board-read.do?boardId=jakarta&boardNo=1102844820026&command=READ&t=1328133167517 









▣ server.xml 파일이란?

1. 말그대로.. server에 대한 설정 파일이다.

 

▣ 디렉토리 위치?

:%CATALINA_HOME%\conf\server.xml         //CATALINA_HOME은 톰캣의 홈디렉토리!~

 

▣ 구조

톰캣을 설치한 후, 가장 기본적 형태!~ parent-children 관계이다..

 

Server는 전체 JVM을 대표하는 단 하나의 요소이다.
Server는 한개 이상의 Service 객체를 가지고 지정된 포트로 shutdown 커맨드를 listen한다.

Server는 그 자체가 Container가 아니므로 'Valves'나 'Loggers'같은 것은 정의할 수 없다.

<Server port="8005" shutdown="SHUTDOWN">

    필요한 리스너 등록!~

    <Listener className="org.apache.catalina.core.AprLifecycleListener" />

    Global JNDI resources!~
    <GlobalNamingResources>
        <Environment name="simpleVal!ue" ... />
        <Resource name="UserDatabase" ... />
    </GlobalNamingResources>

    Service는 하나의 Container를 공유하는 한개 이상의 Connectors의 모임이다.
    일반적으로.. 위에서 호칭한 Container를 'Engine'이라 한다.
    Service태그에서 톰캣의 독립 서비스를 정의하자

    <Service name="Catalina">

        Connector는 요청을 받고 응답을 리턴하는 endpoint이다.
        각 Connector는 요청을 처리하기 위해 연관된 Container에게 요청을 넘긴다.

        <Connector port="8080" ... />
        <Connector port="8009" ... />

        Engine은 적절한 Host(virtual host)로 처리를 넘기는 entry point이다.
        <Engine name="Catalina" defaultHost="localhost">
            <Realm className="org.apache.catalina.realm.UserDatabaseRealm" .../>

            default virtual Host 정의
            <Host name="localhost" appBase="webapps">
            </Host>
        </Engine>
    </Service>
</Server>

 

 

▣ 기타 설명


1. HTTP 포트를 80으로 바꾸면 http://localhost:8080을 안 써도 된다.

즉 http://localhost 만 쓰면 된다는 말!~

<!-- Define a non-SSL HTTP/1.1 Connector on port 8080 -->
<Connector port="8080" maxHttpHeaderSize="8192"              // 8080 -> 80
           maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
           enableLookups="false" redirectPort="8443" acceptCount="100"
           connectionTimeout="20000" disableUploadTimeout="true" />

 

2. Context ?

: Context는 특별한 Viertual Host에서 작동하는 하나의 Web Application 이다..

 

3. Web Application을 추가 하기 위해서(deploy)

Application Context를 추가해야 하는데..

위에서 설명한 <Host></Host> 사이에 <Context>를 추가하는 것이 예전 방법 이었다.(Tomcat 4.x 이하)

 

그러나!!

 

자카르타에서는 더이상 server.xml 내에 Context를 추가하는 것을 권장하지 않는다..

(그것도 강력히 비추한다 -ㅇ-..)

그러면 방법은??

 

다음 글에 써 놓았다.... - -..

톰캣에 어플리케이션 추가하기! 

▣ 톰캣(tomcat)에 어플리케이션을 추가하는 방법은 두가지가 있다.

하나씩 알아보도록 하자.

 

1. webapps 디렉토리 밑에 넣는 방법

장점 : 웹 어플리케이션의 폴더구조만 가지고 있다면 자동으로 웹어플리케이션이 설정된다.

단점 : 지정된 디렉토리(톰캣\webapps\'어플리케이션명')의 하위 이외에는 설정이 불가하다.

방법 :

  기본 설치된 톰캣 디렉토리에서 '톰캣\webapps\어플리케이션명' 이렇게 넣어주기만 하면..

  바로.. http://localhost/어플리케이션명 ........ 으로 접근 가능하다.

 

참고1) 웹 어플리케이션의 폴더구조

어플리케이션명\WEB-INF                 ----------> 이 디렉토리 필수!

어플리케이션명\WEB-INF\web.xml  ----------> 이 파일 필수!

 

참고2) web.xml의 최소내용

<?xml version="1.0" encoding="euc-kr"?>

<web-app xmlns="http://java.sun.com/xml/ns/j2ee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
    version="2.4">
</web-app>


참고3) index.html이 있어야 되겠죠?

  web.xml에 설정한 welcome파일이 있어야 해당 context가 정상적으로 호출이 된답니다

  ----> web.xml중 <welcome-file-list>태그에 적은 거 기억나시죠?


참고4) 어플 추가후 톰캣서버리부팅없이 바로 접근가능하답니다 ㅎㅎ

 

2. 임의의 디렉토리에 웹어플리케이션을 위치시키고 싶을 때.

장점 : '톰캣\webapps\' 디렉토리에 구속될 필요가 없다.

방법 :

이전에 설명한.. server.xml에서 설정하는 방법도 있으나 이것은 자카르타에서 비추하는 방법이기 때문에

설명은 생략토록 한다.

 

앞으로는 xml형식의 파일로 Application Context를 저장하라고 하고 있다.

아래처럼!~

 

%CATALINA_HOME%\conf\Catalina\localhost\컨텍스트명.xml

 

기존에 존재하는 host-manager.xml, manager.xml 등의 파일을 저장해서 이름을 바꾸고

안에 내용중 docBase와 path만 바꾸면 끝!~

설정이 훨씬 쉽게 되었다!!! ㅎㅎ

 

- path : 웹어플리케이션의 경로명(http://localhost/'요기 붙을 내용')

- docBase : 웹어플리케이션이 위치한 폴더의 경로명(실제 경로)

 

<Context path="/myTest" docBase="C:\myTest"
              debug="0" privileged="true" reloadable="true">
    <Logger className="org.apache.catalina.logger.FileLogger"
                 directory="logs"  prefix="localhost_log." suffix=".txt"
                 timestamp="true"/>
</Context>

 

 

※ROOT로 만들고 싶다면 ROOT.xml로 만들면 됨.

※server.xml의 HOST 항목중 appbase 속성값과 위의 docBase가 동일하면 톰캣 콘솔에..

에러가 발생하므로 경로를 다르게 해주자!~

 


▣ Context 속성(참조 : http://www.jakartaproject.com/article/jakarta/110284482002600 )

 속성

설명

 backgroundProcessorDelay   이 값은 컨텍스트와 그 자식 컨테이너에서 background process method가 invoke되는 delay 시간을 나타낸다.
이 값을 양수로 설정하면 어떤 쓰레드가 분기되어 일정 시간 후에 이 쓰레드가 해당 host와 자식 컨테이너에서 background process method를 실행시킵니다
만약 설정하지 않으면 디폴트값인 -1을 가지며 음수의 값은 부모 host의 background processing 정책을 사용한다는 것입니다.
참고로 컨텍스트는 세션을 종료하거나 클래스 리로딩을 위한 모니터링등을 위해 background processing을 사용합니다.
 className  

사용할 Java 구현체 클래스의 이름. 이 클래스는 반드시 org.apache.catalina.Context 인터페이스를 구현해야 합니다. 지정하지 않으면 표준값 (아래에 정의됩니다)이 사용됩니다

 cookies  

true(디 폴트)로 지정하면 클라이언트가 쿠키를 지원하는 경우 세션확인의 통신수단(session identifier communication)으로 쿠키를 사용합니다. false로 지정하면 세션확인의 통신수단으로 쿠키 사용을 하지 않고, 어플리케이션에 의한 URL 다시쓰기(URL rewriting)에만 의존한다는 의미입니다.

 crossContext  

true 로 지정하면 이 어플리케이션에서 ServletContext.getContext() 호출을 통해, 이 가상호스트에서 실행중인 다른 웹어플리케이션에 대한 요청디스패쳐(request dispatcher)를 성공적으로 얻을 수 있습니다. 보안상의 이유로 false(디폴트)로 지정하면 getContext()는 언제나 null을 반환하게 됩니다.

 docBase  

이 웹어플리케이션에 대한 Document Base (Context Root로도 알려져 있습니다) 디렉토리, 또는 웹어플리케이션 아카이브 파일의 경로명(웹어플리케이션을 WAR 파일로 직접 실행하는 경우)을 나타냅니다. 이 디렉토리나 WAR 파일에에 대한 절대경로명을 지정할 수도 있고, 이 Context가 정의된 Host의 appBase 디렉토리에 대한 상대경로명을 지정할 수도 있습니다

 override  true로 설정하면 DefaultContext element를 관련된 host에서 명백하게 상속받아 사용합니다
기본값으로 Defaultcontext element가 사용됩니다
 privileged  

true로 설정하면 이 컨텍스트는 관리자서블릿(manager servlet) 같은 컨테이너 서블릿을 사용할 수 있습니다.

 path  

이 웹어플리케이션의 컨텍스트 경로(context path)를 나타내며, 각 요청 URI의 시작부분이 컨텍스트 경로와 같을 때 해당 웹어플리케이션이 그 요청을 처리하게 됩니다. 하나의 특정 Host 내의 컨텍스트 경로들은 모두 각각 유일해야 합니다. 만약 컨텍스트 경로를 빈 스트링("")으로 지정하면, 이 Context는 이 Host에 대한 디폴트 웹어플리케이션으로 정의된 것입니다. 디폴트 웹어플리케이션은 다른 Context 들에 해당되지 않는 모든 요청을 처리할 것입니다.

 reloadable  

true 로 지정하면, Catalina는 /WEB-INF/classes/와 /WEB-INF/lib 안 클래스 들의 변경여부를 감시하다가, 변경이 발견되면 웹어플리케이션을 자동으로 재적재(reload)합니다. 이 기능은 개발중에는 매우 유용하지만 얼마간의 실행부하(runtime overhead)가 발생하므로, 실제 운영할 용도로 어플리케이션을 배치(deploy)할 때는 사용하지 않도록 합니다. 그러나 이미 배치가 끝난 어플리케이션이라도 Manager 웹어플리케이션을 이용하면 필요할 때 재적재 하도록 할 수 있습니다

 wrapperClass  

이 Context로 관리할 서블릿 들에 대해 사용할 org.apache.catalina.Wrapper 구현체 클래스의 Java 클래스명입니다. 지정하지 않으면 표준값이 사용됩니다


 

출처 

http://blog.daum.net/_blog/BlogTypeView.do?blogid=090sk&articleno=5494233&_bloghome_menu=recenttext#ajax_history_home

 



 





Apache Tomcat 7

More about the Cat

This article is meant for advanced programmers who is interested to know more about Tomcat; or using Tomcat for production. For novices, read "How to Install and Get Started with Tomcat".

The authoritative source of information on Tomcat is the Tomcat's documentation, available under Tomcat's "webapps\docs" directory. You may also refer to the Java Servlet, JSP and JSF specifications, as Tomcat is the Reference Implementation for these technologies.

I shall assume that Tomcat is installed in d:\myproject\tomcat, and shall denote this directory as <TOMCAT_HOME> or <CATALINA_HOME> - "Catalina" is the codename for Tomcat 5 and above.

1.  Tomcat Architecture and Configuration

1.1  Tomcat's Installed Directory Structure

Tomcat installation provides these directories:

  • bin: for Tomcat's binaries and startup scripts.
  • conf: global configuration applicable to all the webapps. The default installation provides:
    • One Policy File: catalina.policy for specifying security policy.
    • Two Properties Files: catalina.properties and logging.properties,
    • Four Configuration XML Files: server.xml (Tomcat main configuration file), web.xml (global web application deployment descriptors), context.xml (global Tomcat-specific configuration options) and tomcat-users.xml (a database of user, password and role for authentication and access control).
    The conf also contain a sub-directory for each engine, e.g., Catalina, which in turn contains a sub-sub-directory for each of its hosts, e.g., localhost. You can place the host-specific context information (similar to context.xml, but named as webapp.xml for each webapp under the host).
  • lib: Keeps the JAR-file that are available to all webapps. The default installation include servlet-api.jar (Servlet), jasper.jar (JSP) and jasper-el.jar (EL). You may also keep the JAR files of external package here, such as MySQL JDBC driver (mysql-connector-java-5.1.{xx}-bin.jar) and JSTL (jstl.jar and standard.jar).
  • logs: contains the engine logfile Catalina.{yyyy-mm-dd}.log, host logfile localhost.{yyyy-mm-dd}.log, and other application logfiles such as manger and host-manager. The access log (created by the AccessLogValve) is also kept here.
  • webapps: the default appBase - web applications base directory of the host localhost.
  • work: contains the translated servlet source files and classes of JSP/JSF. Organized in hierarchy of engine name (Catalina), host name (localhost), webapp name, followed by the Java classes package structure.
  • temp: temporary files.

1.2  Tomcat Architecture

Tomcat is an HTTP server. Tomcat is also a servlet container that can execute Java Servlet, and converting JavaServer Pages (JSP) and JavaServerFaces (JSF) to Java Servlet. Tomcat employs a hierarchical and modular architecture as illustrated:



1.3  Main Configuration File "server.xml"

Tomcat's main configuration file is the "server.xml", kept under the <CATALINA_HOME>\conf directory. The default "server.xml" is reproduced as follows (after removing the comments and minor touch-ups):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
<?xml version='1.0' encoding='utf-8'?>
<Server port="8005" shutdown="SHUTDOWN">
  <Listener className="org.apache.catalina.core.JasperListener" />
  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
 
  <GlobalNamingResources>
    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
  </GlobalNamingResources>
 
  <Service name="Catalina">
    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
 
    <Engine name="Catalina" defaultHost="localhost">
 
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
               resourceName="UserDatabase"/>
      </Realm>
 
      <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log." suffix=".txt"
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />
      </Host>
    </Engine>
  </Service>
</Server>
Server

Server (Line 2) is top component, representing an instance of Tomcat.It can contains one or more Services, each with its own Engines and Connectors.

<Server port="8005" shutdown="SHUTDOWN"> ...... </Server>
Listeners

The Server contains several Listeners (Lines 3-7). A Listener listens and responses to specific events.

  • The JasperListener enables the Jasper JSP engine, and is responsible for re-compiling the JSP pages that have been updated.
    <Listener className="org.apache.catalina.core.JasperListener" />
  • The GlobalResourcesLifecycleListener enables the global resources, and makes possible the use of JNDI for accessing resources such as databases.
    <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
Global Naming Resources

The <GlobalNamingResources> element (Line 9-15) defines the JNDI (Java Naming and Directory Interface) resources, that allows Java software clients to discover and look up data and objects via a name.

The default configuration defines a JNDI name called UserDatabase via the <Resource> element (Line 10-14), which is a memory-based database for user authentication loaded from "conf/tomcat-users.xml".

<GlobalNamingResources>
  <Resource name="UserDatabase" auth="Container"
            type="org.apache.catalina.UserDatabase"
            description="User database that can be updated and saved"
            factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
            pathname="conf/tomcat-users.xml" />
</GlobalNamingResources>

You can define other global resource JNDI such as MySQL database to implement connection pooling.

Services

Service associates one or more Connectors to a Engine. The default configuration defines a Service called "Catalina", and associates two Connectors: HTTP and AJP to the Engine.

<Service name="Catalina"> ...... </Service>
Connectors

Connector is associated with a TCP port to handle communications between the Service and the clients. The default configuration defines two Connectors:

  • HTTP/1.1: Handle HTTP communication and enable Tomcat to be an HTTP server. Clients can issue HTTP requests to the server via this Connector, and receive the HTTP response messages.
    <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />
    The default chooses TCP port 8080 to run the Tomcat HTTP server, which is different from the default port number of 80 for HTTP production server. You can choose any number between 1024 to 65535, which is not used by any application, to run your Tomcat server.
    The connectionTimeout attribute define the number of milliseconds this connector will wait, after accepting a connection, for the request URI line (request message) to be presented. The default is 20 seconds.
    The redirect attribute re-directs the SSL requests to TCP port 8443.
  • AJP/1.3: Apache JServ Protocol connector to handle communication between Tomcat server and Apache HTTP server.
    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
    You could run Tomcat and Apache HTTP servers together, and let the Apache HTTP server handles static requests and PHP; while Tomcat server handles the Java Servlet/JSP. Read "How To Configure Tomcat to work with Apache".
Containers

Tomcat refers to EngineHostContext, and Cluster, as container. The highest-level is Engine; while the lowest-level is Context. Certain components, such as Realm and Valve, can be placed in a container.

Engine

Engine is the highest-level of a container. It can contains one or more Hosts. You could configure a Tomcat server to run on several hostnames, known as virtual host.

<Engine name="Catalina" defaultHost="localhost">

The Catalina Engine receives HTTP requests from the HTTP connector, and direct them to the correct host based on the hostname/IP address in the request header.

Realm

Realm is a database of user, password, and role for authentication (i.e., access control). You can define Realm for any container, such as EngineHost, and Context, and Cluster.

<Realm className="org.apache.catalina.realm.LockOutRealm">
  <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>
</Realm>

The default configuration defines a Realm (UserDatabaseRealm) for the Catalina Engine, to perform user authentication for accessing this engine. It uses the JNDI name UserDatabase defined in the GlobalNamingResources.

Besides the UserDatabaseRealm, there are: JDBCRealm (for authenticating users to connect to a relational database via the JDBC driver); DataSourceRealm (to connect to a DataSource via JNDI; JNDIRealm (to connect to an LDAP directory); and MemoryRealm (to load an XML file in memory).

Hosts

Host defines a virtual host under the Engine, which can in turn support many Contexts (webapps).

<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true">

The default configuration define one host called localhost. The appBase attribute defines the base directory of all the webapps, in this case, <CATALINA_HOME>\webapps. By default, each webapp's URL is the same as its directory name. For example, the default Tomcat installation provides four webapps: docsexampleshost-manager and manager under the webapps directory. The only exception is ROOT, which is identified by an empty string. That is, its URL is http://localhost:8080/.

The unpackWARs specifies whether WAR-file dropped into the webapps directory shall be unzipped. For unpackWARs="false", Tomcat will run the application from the WAR-file directly, without unpacking, which could mean slower execution.

The autoDeploy attribute specifies whether to deploy application dropped into the webapps directory automatically.

Cluster

Tomcat supports server clustering. It can replicate sessions and context attributes across the clustered server. It can also deploy a WAR-file on all the cluster.

Valve

Valve can intercept HTTP requests before forwarding them to the applications, for pre-processing the requests. A Valve can be defined for any container, such as EngineHost, and Context, and Cluster.

In the default configuration, the AccessLogValve intercepts an HTTP request and creates a log entry in the log file, as follows:

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
       prefix="localhost_access_log." suffix=".txt"
       pattern="%h %l %u %t &quot;%r&quot; %s %b" />

Other valves include:

  • RemoteAddrValve: which blocks requests from certain IP addresses,
  • RemoteHostValve: which blocks request based on hostnames,
  • RequestDumperValve: which logs details of the requests,
  • SingleSignOn Valve: when placed under a <host>, allows single sign-on to access all the webapp under the host.

1.4  Other Configuration Files: web.xmlcontext.xmltomcat-users.xml

[TODO]

They are so many things that you can configured in Tomcat. I describe some of the configurations that I found useful in this section.

Enabling Directory Listing

When the request URL refers to a directory instead of a file, e.g., http://host:port/hello/, you can configure Tomcat to serve the directory listing, or a welcome file, or issue error "404 Page Not Found". Enabling directory listing is handy for test server but NOT desire for production server (as it reveal the directory structure and expose the entire directory hierarchy).

Enabling Directory Listing for ALL Webapps

To enable directory listing for all the web applications, you could modify the <CATALINA_HOME>\conf\web.xml, by changing "listings" from "false" to "true" for the "default" servlet, as follows:

<!-- The default servlet for all web applications, that serves static     -->
<!-- resources.  It processes all requests that are not mapped to other   -->
<!-- servlets with servlet mappings.                                      -->
<servlet>
  <servlet-name>default</servlet-name>
  <servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>
  <init-param>
    <param-name>debug</param-name>
    <param-value>0</param-value>
  </init-param>
  <init-param>
    <param-name>listings</param-name>
    <param-value>true</param-value>
  </init-param>
  <load-on-startup>1</load-on-startup>
</servlet>
    
<!-- The mapping for the default servlet -->
<servlet-mapping>
  <servlet-name>default</servlet-name>
  <url-pattern>/</url-pattern>
</servlet-mapping>
   
<!-- ==================== Default Welcome File List ===================== -->
<!-- When a request URI refers to a directory, the default servlet looks  -->
<!-- for a "welcome file" within that directory and, if present,          -->
<!-- to the corresponding resource URI for display.  If no welcome file   -->
<!-- is present, the default servlet either serves a directory listing,   -->
<!-- or returns a 404 status, depending on how it is configured.          -->
<welcome-file-list>
  <welcome-file>index.html</welcome-file>
  <welcome-file>index.htm</welcome-file>
  <welcome-file>index.jsp</welcome-file>
</welcome-file-list>

The above configuration maps URL "\" (root directory of the web context) (in <url-pattern>) to Java class DefaultServlet (in <servlet-class>) via the common servlet name of default (in <servlet-name>). We enable directory listing by changing the servlet's initialization parameter listings to true.

If a user requests for a directory, and the directory listing is enabled and it contains one of the files in the <welcome-file> list, the welcome file will be served; otherwise, the directory listing will be served. On the other hand, if a directory request is received and the directory listing is not enabled, the server returns an error "404 Page Not Found".

Enabling Directory Listing for a particular Webapp

If you wish to allow directory listing of a particular web application only, you could disable the directory listing in "<CATALINA_HOME>\conf\web.xml" globally, and define the following <servlet> and <servlet-mapping> in your application-specific WEB-INF\web.xml, as follows. You need to use another <servlet-name> in place of DefaultServlet.

<servlet>
  <servlet-name>DirectoryListing</servlet-name>
  <servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>
  <init-param>
    <param-name>debug</param-name>
    <param-value>0</param-value>
  </init-param>
  <init-param>
    <param-name>listings</param-name>
    <param-value>true</param-value>
  </init-param>
</servlet>
   
<servlet-mapping>
  <servlet-name>DirectoryListing</servlet-name>
  <url-pattern>/</url-pattern>
</servlet-mapping>
Automatic Servlet Reload

To enable automatic servlet reload (whenever a servlet is re-compiled), you need to specify <Context reloadable="true">...</Context>, in "<CATALINA_HOME>\conf\context.xml" for all web applications, or the <Context> element in "<CATALINA_HOME>\conf\server.xml" for a particular web application.

The following messages appear on the Tomcat's console if you re-compile a servlet:

XXX X, XXXX XX:XX:XX XX org.apache.catalina.core.StandardContext reload
INFO: Reloading Context with path [/hello] has started
XXX X, XXXX XX:XX:XX XX org.apache.catalina.core.StandardContext reload
INFO: Reloading Context with path [/hello] is completed

Enabling automatic servlet reload is handy during application development, but it requires significant runtime overhead to listen to the changes, and is not recommended for production systems. Instead, you could use the "manager" to trigger reloads on demand.

Setting the Context Root Directory and Request URL of a Webapp

A server could run many web applications. A webapp is also called a web context. The context root (or document base directory) refers to the base directory of a webapp. They are a few ways to configure a context root and its request URL of a webapp:

  1. (RECOMMENDED) Create a directory under <CATALINA_HOME>\webapps for your webapp. A context will be created with request URL set to the name of the directory. For example, if you create a directory called "hello" under Tomcat's "webapps". This application can be accessed by web users via URL http://host:port/hello.
    To change the request URL of the webapp, create a "context.xml" configuration file, as follows, and place it under "ContextRoot\META-INF":
    <Context path="/yourURLPath" />
  2. Alternatively, you can write a <Context> element in <CATALINA_HOME>\conf\server.xml, under the <Host> element. You can specify both the URL and the base directory. For example,
            ......
            ......
            <Context path="/ws" docBase="d:/workshop" reloadable="true">
            </Context>
          </Host>
        </Engine>
      </Service>
    </Server>
    In the above example, we define a web context with URL "/ws", with context root (docBase or document base directory) at "d:\workshop". This application can be accessed via URL http://host:port/ws.
    Take note that:
    • The configuration creates a mapping from the "URL Path" issued by the web users to the "document base directory" in the server's file system, where you store your webapp resources.
    • Place the <Context> element before the ending tag of the <Host> element.
    • Use Unix-style forward slash '/' as the directory separator in the configuration file, instead of Window-style back slash '\'.
    • The attribute reloadable="true" asks Tomcat to monitor your servlets for changes, and automatically reload the servlets if changes is detected. This is handy for a development system, but inefficient in a production system.
  3. Write a configuration file with a <Context> element and place it under Tomcat's "conf\Catalina\localhost". For example, suppose we wish to create a webapp with URL "hello" in base directory "d:\myproject\myHello", create the following file "hello.xml":
    <?xml version="1.0" encoding="UTF-8"?>
    <Context docBase="D:\myproject\myHello" path="/hello" />
Changing the Default "webapps" Directory

The default directory for deploying web applications is <CATALINA_HOME>\webapps. You could change the default by modifying the configuration file "conf\server.xml" <Host> element's "appBase" attribute as follows:

<Host name="localhost" appBase="webapps"
      unpackWARs="true" autoDeploy="true"
      xmlValidation="false" xmlNamespaceAware="false">
   ......
</host>

2.  Deploying Webapps

web context is a single web application (webapp). It is the lowest-level container, that you can define components such as Realm and Valve. By default, all webapps are kept under the <CATALINA_HOME>\webapps directory (as configured in the <host> element appBaseattribute.

A Java webapp may contain many types of files, such as HTML, CSS, Scripts, images, JSP, servlet, utility classes, external library jar-files. A Java webapp must follow a strict directory structure as depicted in the Servlet/JSP specifications. This enables deployment in a Java-capable web server (such as Apache Tomcat and Glassfish). The resources must be kept in the correct directories and sub-directories.

The URL of a webapp, by default, is the same as the base directory name (or context root) of the webapp.

2.1  Webapp's Directory Structure



The directory structure of a webapp is as follows:

  • "ContextRoot": contains the resources that are visible and accessible by the web clients, such as HTML, CSS, Scripts and images. These resources will be delivered to the clients as it is. You could create sub-directories such asimagescss and scripts, to further categories the various resources.
  • "ContextRoot\WEB-INF": This directory, although under the context root, is NOT visible to the web users. In other words, it is NOT accessible by the clients directly (for security reason). This is where you keep your application-specific configuration files such as "web.xml". It's sub-directories contain program classes, source files, and libraries.
  • "ContextRoot\WEB-INF\src": Keeps the Java program source files. It is optional but a good practice to separate the source files and classes to facilitate deployment.
  • "ContextRoot\WEB-INF\classes": Keeps the Java classes (compiled from the source codes). Classes defined in packages must be kept according to the Java package directory structure.
  • "ContextRoot\WEB-INF\lib": Keeps the libraries (jar-files), which are provided by other packages, specific and available to this webapp only.
  • "ContextRoot\META-INF\": This is also a hidden directory, to keep resources and configurations (e.g., "context.xml") related to the server. In contrast, "WEB-INF" is for resources related to this web application, independent of the server.

2.2  Webapp-Specific Configuration Files

These are the configuration files specific to a webapp: (a) WEB-INF\web.xml; (b) META-INF\context.xml.

You can configure a webapp in many ways: (a) Write a <context> element in server.xml under <Host> element, (b) contextRoot\META-INF\context.xml, and (c) conf\Catalina\localhost\webapp.xml, and (d)conf\context.xml. See "Setting the Context Root Directory and Request URL of a Webapp".

2.3  Web Application Deployment Descriptors - "web.xml"

The "web.xml" contains the deployment descriptors. There are two sets of web.xml:

  1. <CATALINA_HOME>\conf\web.xml: applicable to ALL webapps.
  2. ContextRoot\WEB-INF\web.xml: applicable to the specific web context. It overrides the global setting, if any.

The complete specification for "web.xml" can be found in the "Java Servlet Specification" under "Deployment Descriptor".

A sample configuration of a servlet with most of its sub-elements is as follows:

<web-app ......>
  ......
  <servlet>
    <icon>
      <small-icon>/images/icon.jpg</small-icon>
    </icon>
    <servlet-name>MyServlat</servlet-name>
    <display-name>My Servlet Display Name</display-name>
    <description>My Testing Servlet long description</description>
    <servlet-class>MyServletClassname</servlet-class>
    <init-param>
      <param-name>myParmName</param-name>
      <param-value>myParmValue</param-value>
    </init-param>
    <load-on-startup>25</load-on-startup>
  </servlet>
  ......
 
  <servlet-mapping>
    <servlet-name>MyServlat</servlet-name>
    <url-pattern>/sayhello</url-pattern>
  </servlet-mapping>
  ......
</web-app>

2.4  Deploying a Web Application in a WAR file

You could use the JDK's jar utility to "zip" up all the files of a web application to produce a so-called WAR (Web Application Archive) file for deployment, or distribution.

.... Change current directory to the web application's context root
contextRoot> jar cvf test.war .

Drop the test.war into <CATALINA_HOME>\webapps. A context called test will be created automatically. You can access the web application via URL http://host:port/test.

Tomcat actually unpacks the test.war into a "test" directory in <CATALINA_HOME>\webapps. You need to remove this directory, if you reload a new version.

3.  Running Tomcat

3.1  Tomcat's Manager

References:

  1. "Tomcat Web Application Manager How To" @ "webapps/docs/html-manager-howto.html".
  2. "Tomcat Manager App How-To" @ "webapps/docs/manager-howto.html".

Tomcat "manager" webapp allows you to deploy a new web application; start, stop, reload or un-deploy an existing one, without having to shut down and restart the server, in a production environment.

To enable Tomcat's manager, edit "<CATALINA_HOME>\conf\tomcat-users.xml" to include a role called "manager-gui" and a user with this role. You may also assign other roles, such as admin-gui for accessing the Tomcat "Host Manager".

<role rolename="manager-gui" />
<role rolename="manager-status" />
<role rolename="manager-script" />
<role rolename="manager-jmx" />

<role rolename="admin-gui" />
<role rolename="admin-script" />
 
<user username="mymanager" password="xxxx" roles="manager-gui, admin-gui"/>

To invoke manager web application, use http://localhost:8080/manager/html. You can use Tomcat's manager to:

  1. List all webapps.
  2. Start/Stop/Reload a particular webapp.
  3. Deploy a new webapp remotely, and undeploy a webapp without restarting the container.
  4. Terminate (or Invalidate) sessions - a session has a pre-set expiry time (e.g., 30 sec).
  5. Analyze memory leaks.
  6. View JVM status and Server status.

Tomcat 7 provides separate manager roles for the GUI (manager-gui), status (manager-status), scripting (manager-script) and JMX proxy (manager-jmx), defined in "webapps/manager/WEB-INF/web.xml". This allows for fine-grained access control to management tasks.

  • manager-gui - Access to the HTML "web" interface, via:
    http://{host}:{port}/manager/html
  • manager-status - Access to the "Server Status" page only, via:
    http://{host}:{port}/manager/status
  • manager-script - Access to the "plain-text" interface, and to the "Server Status" page, via command in the form of:
    http://{host}:{port}/manager/text/{command}?{parameters}
     
    // Examples
    http://{host}:{port}/manager/text/list                  // List all webapps
    http://{host}:{port}/manager/text/deploy?path=/testapp  // Deploy webapp
  • manager-jmx - Access to JMX proxy interface and to the "Server Status" page, via:
    http://{host}:{port}/manager/jmxproxy/?{command}={parameter}

For security reason, a user should NOT be given more than one of the following roles: manager-guimanager-script, and manager-jmx.

Tomcat's "Administration Tool"

The Tomcat "Adminstrative Tool" (or "Administrator Console") has been removed since Tomcat 6. Use JMX manager instead.

3.2  Automatic Startup at Boot-time

(Windows) Running Tomcat as a Windows Service

You need to download the Windows-specific version of Tomcat (from Tomcat's download, choose 32-bit or 64-bit Windows' zip version, e.g., apache-tomcat-7.0.{xx}-windows-x86.zip).

Read "Windows service How-To" in the Tomcat documentation (<CATALINA_HOME>\webapps\docs\windows-service-howto.html).

In a production environment, it is more convenient to run Tomcat as a service, so that it can start automatically whenever the system is started (or re-start automatically after an unexpected interruption).

To install Tomcat as a service, start a CMD shell (with administrator right) and run the <CATALINA_HOME>\bin\service.bat with install option:

... Change directory to <CATALINA_HOME>\bin ...
<CATALINA_HOME>\bin> service install
Installing the service 'Tomcat7' ...
......
The service 'Tomcat7' has been installed.

The Tomcat service called "Apache Tomcat 7" is installed and will start automatically whenever the system is started. Check the "Services" under "Control Panel" ⇒ "Administrative Tools".

A GUI application called Tomcat7w is available for monitoring and configuring Tomcat services. Launch Tomcat7w:

<CATALINA_HOME>\bin> Tomcat7w

You could put the Tomcat icon in the system tray via the MS (Monitor Service) option:

<CATALINA_HOME>\bin> Tomcat7w //MS//

You can start/stop the Tomcat service now via:

  1. Tomcat7w;
  2. "Control Panel" ⇒ "Administrator Tools" ⇒ "Services" ⇒ "Apache Tomcat 7" ⇒ "Start";
  3. From CMD shell, Issue "net" command:
    prompt> net start tomcat7
    The Apache Tomcat 7 service is starting..
    The Apache Tomcat 7 service was started successfully.
    ......
    ......
    prompt> net stop tomcat7
    The Apache Tomcat 7 service is stopping..
    The Apache Tomcat 7 service was stopped successfully.

To uninstall Tomcat Service, run the <CATALINA_HOME>\bin\service.bat with remove option:

<CATALINA_HOME>\bin> service remove
The service 'Tomcat7' has been removed

You can also use Microsoft Management Console (MMC) to manage the services: Go to "Start" ⇒ ⇒ Run ⇒ enter "services.msc".

A flip side of running Tomcat as a service is you need to read the error messages from <CATALINA_HOME>\logs instead of the Tomcat console.

(Linux and Mac OS) Automatic Startup on Reboots

To start Tomcat automatically when the machine boots up, you need to create a init script in /etc/init.d, e.g., /etc/init.d/tomcat, as follows:

#!/bin/sh
# Tomcat init script for Linux.
#
JAVA_HOME={path-to-java-installed-directory}
CATALINA_HOME={path-to-Tomat-installed-directgory}
export JAVA_HOME CATALINA_HOME
exec $CATALINA_HOME/bin/catalina.sh $*

Save the script as "tomcat" in /etc/init.d.

$ cd /etc/init.d
$ sudo chown root.root tomcat   // change owner to user root, group root
$ sudo chmod 755 tomcat         // change mode u+rwx, g+rx, a+rx

You can start|stop|restart Tomcat via:

$ service tomcat start|stop|restart

3.3  Tomcat's Startup Script

To start tomcat server, you could invoke the batch file "startup.bat" (for Windows) or "startup.sh" (for Linux/Mac) (in directory "<CATALINA_HOME>\bin", where <CATALINA_HOME> refers to the Tomcat installed directory). The "startup.bat|startup.sh" invokes "catalina.bat start|catalina.sh start".

Alternatively, you could call the "catalina.bat|catalina.sh" directly, which provides more options of starting Tomcat. Enter "catalina" to view the options:

<CATALINA_HOME>/bin> catalina
Using CATALINA_BASE:   D:\xxx\tomcat7.0.{xx}
Using CATALINA_HOME:   D:\xxx\tomcat7.0.{xx}
Using CATALINA_TMPDIR: D:\xxx\tomcat7.0.{xx}\temp
Using JRE_HOME:        d:\xxx\jdk1.6
Usage:  catalina ( commands ... )
commands:
  debug             Start Catalina in a debugger
  debug -security   Debug Catalina with a security manager
  jpda start        Start Catalina under JPDA debugger
  run               Start Catalina in the current window
  run -security     Start in the current window with security manager
  start             Start Catalina in a separate window
  start -security   Start in a separate window with security manager
  stop              Stop Catalina
  configtest        Run a basic syntax check on server.xml
  version           What version of tomcat are you running?

Study the source codes of "catalina.bat|catalina.sh". Take note that the environment variable JAVA_HOME is needed in this script.

The other scripts provided are:

  • shutdown.bat|shutdown.sh: for shuting down the Tomcat server.
  • configtest.bat|configtest.sh: for checking the configuration file server.xml, same as "catalina configtest".
  • version.bat|version.sh: for displaying the versions, same as "catalina version".
  • digest.bat|digest.sh: making password hash and encrypting password.
  • Internal used: setclasspath.bat|setclasspath.shcpappend.bat (classpath append), tool-wrapper.bat|tool-wrapper.shdaemon.sh.

4.  Security

4.1  Realm and User Authentication in Tomcat

References:

  1. "Realm Configuration HOW-TO" (@ "<CATALINA_HOME>\webapps\docs\realm-howto.html").
  2. "Java EE 5 Tutorial", Part IV "Services", Chapters 28-30 on Security.

In Information Security:

  • Access control deals with identifying which resources require protection, and which users (roles) are authorized to access the protected resources.
  • Authentication deals with verifying users' credential, i.e., ensuring the user is "who he said he is". User's credential is typically provided in the form of username/password and possibly IP address (hostname). Other means include biometrics (finger-print, face recognition, retina) and digital certificates.
  • Confidentiality deals with the encryption of the transmitted data over the network. This is often carried out via employing HTTP over SSL (Secure Socket Layer), known as HTTPS.
  • Message Integrity ensures that messages are not tempered during transmission. This is done via message digest or hash.
  • Non-repudiation: If he/she has sent a message, he/she cannot deny. This is done via digital certificate and public/private keys.

Security can be managed by the webapps themselves (called application-managed security) or via the Tomcat container (called container-managed security). In container-managed security, security is handled by the server. The server-side programs (servlets, JSPs) do not need any security-aware code. That is, the security control is totally transparent to the server-side programs. This section shall deal with container-managed security for access control and authentication.

In Tomcat, a user is identified via username/password. A user is assigned role(s) (e.g., manager, admin, user, etc). Tomcat grants access for webapps to role(s), instead of individual users.

realm is a collection of usernames/passwords and roles. Tomcat supports the following types of realms:

  • UserDatabaseRealm: kept in a XML file "conf\tomcat-users.xml", accessed via JDNI (Java Naming and Directory Interface).
  • JDBCRealm: kept in a relational database such as MySQL, accessed via JDBC.
  • others: JNDIRealm (uses LDAP directory), JAASRealm (Java Authentication and Authorization Service).

You can used the <realm> element to configure a realm in "conf\server.xml". <realm> element can be placed in <engine><host>, or <context>, which determines the scope of the realm: all virtual hosts under the engine, a particular host, or a particular web application.

4.2  UserDatabaseRealm

UserDatabaseRealm stores user information in a XML file and accessed via JNDI (Java Naming and Directory Interface). By default, the XML file is "<CATALINA_HOME>\conf\tomcat-users.xml". UserDatabaseRealm is loaded into memory from the specified file, and kept in memory until Tomcat is shut down.

Tomcat provide a JSP example called "FORM Authentication" (@ http://localhost:8080/examples/jsp/security/protected/index.jsp"), which uses UserDatabaseRealm. Let us study this example. But before we get into the codes, let's look at the Tomcat's configurations.

"conf\server.xml"

You can specify the type of realm to be used via <Realm> element in server.xml. In this case, UserDatabaseRealm. The <Realm> is defined within the <Engine> elements, and thus applicable to all the virtual hosts and webapps, under this server.

To specify the file used in UserDatabaseRealm, a JDNI resource named "UserDatabase" is defined, which maps to the file "conf\tomcat-users.xml".

<Server ...... >
  <!-- Global JNDI resources -->
  <GlobalNamingResources>
    <!-- Editable user database that can also be used by
         UserDatabaseRealm to authenticate users -->
    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
  </GlobalNamingResources>
  
  <Service name="Catalina">
    <Engine name="Catalina" defaultHost="localhost">
      <!-- Use the LockOutRealm to prevent attempts to guess user passwords
           via a brute-force attack -->
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
             resourceName="UserDatabase" />
      </Realm>
      <Host name="localhost" ......
        ......
      </Host>
    </Engine>
  </Service>   
</Server>
"conf\tomcat-users.xml"

Recall that a user is identified via username/password. A user is assigned role(s). Accesses for web applications are granted to role(s) instead of individual users. "Tomcat-users.xml" contains the following roles and username/password, but commented-out. Uncomment them for testing the example. Two roles, tomcat and role1, and three users, tomcatrole1 and both are defined.

<?xml version="1.0" encoding="ISO-8859-1" ?>
<tomcat-users>
  <role rolename="tomcat" />
  <role rolename="role1" />
 
  <user username="tomcat" password="tomcat" roles="tomcat" />
  <user username="both" password="tomcat" roles="tomcat,role1" />
  <user username="role1" password="tomcat" roles="role1" />
</tomcat-users>

Take note that the passwords are stored in clear text, which is not really desirable.

"ContextRoot\WEB-INF\web.xml"

For Tomcat's webapp called "examples", the security roles are defined using <security-constraint> element in "webapps\examples\WEB-INF\web.xml" as follows. The URL patterns /jsp/security/protected/* are accessible by users having roles of tomcat androle1 only.

<web-app ......>
  ......
  <security-constraint>
    <display-name>Example Security Constraint</display-name>
    <web-resource-collection>
      <web-resource-name>Protected Area</web-resource-name>
      <!-- Define the context-relative URL(s) to be protected -->
      <url-pattern>/jsp/security/protected/*</url-pattern>
      <!-- If you list http methods, only those methods are protected -->
      <http-method>DELETE</http-method>
      <http-method>GET</http-method>
      <http-method>POST</http-method>
      <http-method>PUT</http-method>
    </web-resource-collection>
    <auth-constraint>
      <!-- Anyone with one of the listed roles may access this area -->
      <role-name>tomcat</role-name>
      <role-name>role1</role-name>
    </auth-constraint>
  </security-constraint>
  
  <!-- Default login configuration uses form-based authentication -->
  <login-config>
    <auth-method>FORM</auth-method>
    <realm-name>Example Form-Based Authentication Area</realm-name>
    <form-login-config>
      <form-login-page>/jsp/security/protected/login.jsp</form-login-page>
      <form-error-page>/jsp/security/protected/error.jsp</form-error-page>
    </form-login-config>
  </login-config>
        
  <!-- Security roles referenced by this web application -->
  <security-role>
    <role-name>role1</role-name>
  </security-role>
  <security-role>
    <role-name>tomcat</role-name>
  </security-role>    

4.3  HTML FORM-based Authentication Method

The example uses HTML FORM-based authentication method, defined in element <login-config>. All accesses to the protected URLs (http://localhost:8080/examples/jsp/security/protected/*) will be redirected to the login.jsp page (defined in <form-login-page>), which prompts user for the credential. For example, if a user requests for http://localhost:8080/examples/jsp/security/protected/index.jsp, the login.jsp will be displayed.

The login.jsp page contain a html <form> (thus called FORM-based authentication):

<html>
<head><title>Login Page for Examples</title></head>
<body>
<form method="POST" action='<%= response.encodeURL("j_security_check") %>' >
  Username:<input type="text" name="j_username">
  Password:<input type="password" name="j_password">
  <input type="submit" value="Log In">
</form>
</body>
</html>

The login page submits the username and password in parameters j_username and j_password to j_security_check<input type="password" ...> is used for password text field, which displays the password as *'s. The response.encodeURL(URL) encodes the URL j_security_check by including the session ID if URL-rewriting is used for session tracking; it returns the URL unchanged if cookie is used. For robust session tracking, all URLs emitted by server-side programs (servlet/JSP) should be run through this method.

If login fails, user will be redirected to error.jsp page, as follows,

<html>
<head><title>Error Page For Examples</title></head>
<body>
Invalid username and/or password, please try again
<a href='<%= response.encodeURL("index.jsp") %>'>again</a>.
</body>
</html>

If login succeeds, the user will get the page he requested for. Study the "examples\jsp\security\protected\index.jsp" source.

  • To logoff, terminate the current session via session.invalidate().
  • You can use request.getRemoteUser() to get the authenticated login username; request.getUserPrincipal() to get a java.security.Principal object containing the name of the current authenticated user; request.isUserInRole(role) to check if the authenticated user is included in the specified role.

4.4  HTTPS

In FORM-based authentication, the username/password are sent in clear text, and susceptible to eavesdropping. Hence, it is important to encrypt the transport by turning on SSL (HTTPS). Read "Tomcat with SSL" on how to setup Tomcat with SSL.

To enforce user to use secure transport (HTTPS), add a <transport-guarantee>CONFIDENTIAL</transport-guarantee>, inside the <security-constraint>, as follows:

<security-constraint>
  <display-name>Example Security Constraint</display-name>
  <web-resource-collection>
    <web-resource-name>Protected Area</web-resource-name>
    <url-pattern>/jsp/security/protected/*</url-pattern>
    ......
  </web-resource-collection>
  <auth-constraint>
    <role-name>tomcat</role-name>
    ......
  </auth-constraint>
  <!-- must use SSL for secure transport -->
  <user-data-constraint>
    <transport-guarantee>CONFIDENTIAL</transport-guarantee>
  </user-data-constraint>
</security-constraint>

All accesses to HTTP at port 8080 (e.g., http://localhost:8080/examples/jsp/security/protected/index.jsp) will be redirected to HTTPS at port 8443 (e.g., https://localhost:8443/examples/jsp/security/protected/index.jsp).

4.5  HTTP BASIC Authentication

HTTP defines two access authentication schemes to request for username/password: Basic and Digest. Read "HTTP Authentication".

To use BASIC authentication, change the <login-config>'s <auth-method> to BASIC.

<login-config>
   <auth-method>BASIC</auth-method>
   <realm-name>Basic Authentication Area</realm-name>
   <!-- Removed, no applicable for BASIC authentication
   <form-login-config>
      <form-login-page>/jsp/security/protected/login.jsp</form-login-page>
      <form-error-page>/jsp/security/protected/error.jsp</form-error-page>
    </form-login-config>
    -->
</login-config>

In BASIC authentication, Tomcat uses the HTTP Basic Authentication to ask for username and password. Try http://localhost:8080/examples/jsp/security/protected/index.jsp, you will be prompted for username/password automatically. There is no redirect tologin.jsp and no need to write the login.jsp.

Again, the HTTP Basic Authentication sends the username and password in clear text (password is encoded in Base64, but not encrypted). It is totally insecure, unless you use a secure transport (HTTPS) or VPN (Virtual Private Network).

The Tomcat's webapp manager (under webapps/manager) uses BASIC authentication.

4.6  HTTP DIGEST Authentication

To use DIGEST authentation, change the <login-config>'s <auth-method> to DIGEST. In DIGEST authentication, Tomcat uses HTTP Digest Authentication Scheme to ask for username/password. Instead of sending password in clear text, the digest of password is send to the server. Although DIGEST authentication is more secure than BASIC authentication, HTTPS is much more secure.

<login-config>
   <auth-method>DIGEST</auth-method>
   <realm-name>Digest Authentication Area</realm-name>
</login-config>

4.7  JDBCRealm

UserDatabaseRealm is not meant for serious production environment, as it is hard to maintain. JDBCRealm is more appropriate.

In JDBCRealm, user information is kept in a relational database, such as MySQL, accessed via JDBC, instead of an XML file. The information can be secured thruough proper database security.

Setting up Database

We shall set up our user database in MySQL. Read "How to Install MySQL and Get Started" if you are new to MySQL.

The following script can be used to set up the user database. Two tables are required: a users table containing username and password, and a user_roles containing username and the role assigned.

create database tomcat_users;
  
use tomcat_users;
  
create table users (
  username varchar(15) not null,
  password varchar(15) not null,
  primary key (username)
);
  
create table user_roles (
  username varchar(15) not null,
  role     varchar(15) not null,
  primary key (username, role)
);
  
insert into users values 
  ('tomcat', 'tomcat'), 
  ('both', 'tomcat'), 
  ('role1', 'tomcat');
  
insert into user_roles values 
  ('tomcat', 'tomcat'), 
  ('role1', 'role1'), 
  ('both', 'tomcat'), 
  ('both', 'role1');
JDBC Driver

Next, copy the MySQL's JDBC driver ("mysql-connector-java-5.1.{xx}-bin.jar") into Tomcat's lib ("<CATALINA_HOME>\lib"). Read "How to Install MySQL and Get Started"

"conf\server.xml"

Again, the realm is defined in server.xml via a <Realm> element. In this case, a JDBCRealm, with a connectionURL providing a MySQL database connection.

<Realm className="org.apache.catalina.realm.JDBCRealm"
   driverName="com.mysql.jdbc.Driver"
   connectionURL="jdbc:mysql://localhost:{port}/tomcat_users"
   connectionName="{dbuser}"
   connectionPassword="{dbpassword}"
   userTable="users" userNameCol="username" userCredCol="password"
   userRoleTable="user_roles" roleNameCol="role" />

Replace the {port} with your MySQL server port number, and {dbuser} and {dbpass} with an authorized MySQL username/password.

"ContextRoot\WEB-INF\web.xml"

Same as UserDatabaseRealm.

Authentication Methods

Same as UserDatabaseRealm, you can use FORMBASIC or DIGEST authentication method.

Testing

You need to start MySQL server before starting the Tomcat Server.

4.8  Single Login

By default, each protected webapp would request for login during the first access. You can enable single login to all webapps under the host by uncommenting the single-login valve, as follows:

<Host ......>
  <!-- SingleSignOn valve, share authentication between web applications
       Documentation at: /docs/config/valve.html -->
  <Valve className="org.apache.catalina.authenticator.SingleSignOn" />
</Host>

4.9  Tomcat with SSL

SSL (Secure Socket Layer), allows web browsers and web servers to communicate over a secured (encrypted) connection. Tomcat provides built-in support for SSL.

Read:

  • "SSL Configuration How-to" of Tomcat Documentation @ "<CATALINA_HOME>\webapps\docs\ssl-howto.html".
  • "keytool - Key and Certificate Management Tool" @ JDK documentation.

The steps to turn on SSL support are:

Step 1: Check your JDK version. Tomcat's SSL uses Java Secure Socket Extension (JSSE), which has been integrated into JDK since 1.4.

Step 2: Prepare the Tomcat's server certificate, using the JDK's Key and Certificate Management Tool called "keytool" (in "<JAVA_HOME>\bin" ), as follows:

> keytool
... display the help menu ...
 
// Generate a self-signed certificate for Tomcat
> keytool -genkey -alias tomcat -keyalg RSA -keystore {TOMCAT_HOME}\conf\.keystore
Enter keystore password: xxxxxxxx
Re-enter new password: xxxxxxxx
What is your first and last name?
  [Unknown]:
What is the name of your organizational unit?
  [Unknown]:
What is the name of your organization?
  [Unknown]:
What is the name of your City or Locality?
  [Unknown]:
What is the name of your State or Province?
  [Unknown]:
What is the two-letter country code for this unit?
  [Unknown]:
Is CN=Unknown, OU=Unknown, O=Unknown, L=Unknown, ST=Unknown, C=Unknown correct?
  [no]:  y
Enter key password for <tomcat>
        (RETURN if same as keystore password):
  • The "-genkey" option is used to generate a public-private key pair. The public key is wrapped into an X.509 v1 self-signed certificate. The certificate and the private key are stored in a new keystore entry identified by the alias. In our case, the alias name must be "tomcat".
  • The "-keyalg" option specifies the key generation algorithm. RSA public key algorithm is used in this case.
  • The "-keystore" option specifies the name and location of the key store file.
  • The password for alias tomcat must be the same as the keystore (i.e., hit enter for the last question).

Step 3: Enable SSL support for Tomcat. SSL is built into Tomcat. The Tomcat's configuration file commented out the SSL configuration directive. Uncomment them by removing the <!-- and --> around the SSL Coyote HTTP/1.1 Connector as follows:

<!-- Define a SSL HTTP/1.1 Connector on port 8443
     This connector uses the JSSE configuration, when using APR, the 
     connector should be using the OpenSSL style configuration
     described in the APR documentation -->
<Connector port="8443" protocol="org.apache.coyote.http11.Http11Protocol"
     SSLEnabled="true" maxThreads="150" scheme="https" secure="true"
     clientAuth="false" sslProtocol="TLS" 
     keystoreFile="{TOMCAT_HOME}\conf\.keystore"
     keystorePass="passwordOfKeyStore" />

Note that the SSL (or HTTPS) is running on port 8443 instead of its default port number 443.

Add in the keystoreFile and keyStorePass attributes. The keystoreFile attribute specified the location of the keystore file. The keyStorePass provides the password for accessing the keystore file.

Step 4: Start your tomcat (run "<CATALINA_HOME>\bin\startup.bat"). After that, start a web browser and issue an HTTPS request as follows:

https://localhost:8443

5.  Clustering

[TODO]

5.1  Configuring Virtual Hosts

To set up a virtual host called "www.mytest.com" (suppose that you have registered this hostname with at static IP address). Include the following <Host> element in server.xml under the Engine Catalina:

<Engine name="Catalina" >
  <Host name="localhost .....>
    ......
  </Host>
  <Host name="www.mytest.com" appBase="webapps_mytest.com"
        unpackWARs="true" autoDeploy="true" >
    <Alias>mytest.com</Alias>
    <Valve className="org.apache.catalina.valves.AccessLogValve"
           directory="logs"
           prefix="mytest.com_access_log." suffix=".log"
           pattern="%h %l %u %t &quot;%r&quot; %s %b"
           resolveHosts="false" />
  </Host>
</Engine>

The above lines configure a virtual host with hostname "www.mytest.com", with webapps base directory at "<CATALINA_HOME>\webapps_mytest.com". We also define a alias called "mytest.com". That is, this host can be accessed via http://www.mytest.com:port orhttp://mytest.com:port. We also define a Valve, which intercepts the request message to write a log entries (similar to localhost).

Next:

  1. Create a directory "webapps_mytest.com" under <CATALINA_HOME>, according to the appBase.
  2. Create a web application called ROOT, by creating a directory ROOT under the "webapps_mytest.com". Recall that ROOT was configured with an empty string URL. In other words, http://www.mytest.com:port/ accesses the ROOT application.
  3. Create a directory "www.mytest.com" under "conf\Catalina".
  4. Write a welcome page called "index.html" and save it in "webapps_mytest.com\ROOT".
    <html>
    <head><title>Testing Virtual Host</title></head>
    <body>
      <h1>It's work on virtual host</h1>
    </body>
    </html>

To test the virtual host, without registering the hostname with an ISP, edit "C:\Windows\System32\drivers\etc\hosts" to include the following lines (required administrative authority):

127.0.0.1   www.mytest.com
127.0.0.1   mytest.com

These lines maps host names www.mytest.com and mytest.com to IP address 127.0.0.1, which is the localhost. As the IP software checks the host file before asking Domain Name Service (DNS) to resolve a host name, you willl be able to test your virtual host.

Now, you are ready to test the virtual hosts. Start the Tomcat server and issue these URL:

http://www.mytest.com:8080
http://mytest.com:8080
http://www.mytest.com:8080/
http://mytest.com:8080/
http://www.mytest.com:8080/index.html
http://mytest.com:8080/index.html

5.2  Tomcat Host Manager for Clustering and Admin Roles

Reference: "Clustering/Session Replication HOW-TO" @ "webapps/docs/cluster-howto.html".

The Tomcat "host-manager" webapp allows you to manage Tomcat clusters. To access host-manager, you need to define a user with admin role.

The admin role has been separated out as admin-gui and admin-script, in Tomcat 7, as defined in webapps/host-manager/WEB-INF/web.xml.

The "Host Manager" web application can be accessed via http://{host}:{port}/host-manager/html.

6.  Performance Tuning

[TODO]

REFERENCES & RESOURCES

  1. Tomcat mother site @ http://tomcat.apache.org
  2. Tomcat's Documentation @ "<CATALINA_HOME>\webapps\docs".
  3. Java Servlet, JavaServer Pages (JSP), and JavaServer Faces (JSF) specifications.




source - http://www3.ntu.edu.sg/home/ehchua/programming/howto/Tomcat_More.html


Posted by linuxism
,