>  기사  >  php教程  >  JSP 자동 컴파일 메커니즘에 대한 자세한 소개

JSP 자동 컴파일 메커니즘에 대한 자세한 소개

高洛峰
高洛峰원래의
2016-12-03 09:40:111042검색

jsp 자동 컴파일 메커니즘에 대한 자세한 소개

일반적으로 Jasper의 자동 감지 메커니즘은 비교적 간단합니다. JSP 파일과 컴파일된 클래스의 마지막 수정 시간을 지속적으로 감지하기 위해 백그라운드 스레드에 의존합니다. 파일이 동일하면 변경이 없는 것으로 간주하고, 다르면 다시 컴파일해야 합니다. 실제로 Tomcat에 배포된 프로젝트의 JSP는 다른 페이지나 다른 jar 패키지를 도입할 수 있고 이러한 리소스는 원격 리소스일 수 있으므로 실제 처리는 더 복잡해집니다. 수정이 이루어졌습니다.

JSP 자동 컴파일 메커니즘에 대한 자세한 소개

위 그림은 개략적인 다이어그램으로 Tomcat 아키텍처에는 Engine, Host, Context, Wrapper의 네 가지 수준의 컨테이너가 있으며 jsp 컴파일은 이에 해당합니다. 래퍼 수준이므로 StandardWrapper는 Jasper를 호출하는 작업을 지속적으로 수행하고 Jasper는 다양한 로컬 및 원격 리소스를 지속적으로 감지하고 확인하여 재컴파일해야 한다고 판단되면 재컴파일됩니다. 이것이 어떻게 달성되는지 알아보려면 계속 읽어보세요.

먼저 다양한 컨테이너의 백그라운드 작업을 처리하려면 Tomcat에 전용 스레드가 필요합니다. backgroundProcess 메소드를 재정의하려면 JspServlet이 Wrapper 레벨에 해당하므로 BackgroundProcess는 PeriodicEventListener 인터페이스를 구현하는 Servlet을 호출해야 합니다. 이 인터페이스에는 특정 periodicEvent 메소드만 있습니다. 감지 논리는 이 방법으로 구현될 수 있습니다.

둘째, 재컴파일 감지 및 판단 근거는 무엇인가요? 재컴파일이란 jsp를 Java로 변환한 다음 다시 클래스로 변환하는 것이며 이 작업을 트리거하는 조건은 특정 jsp 파일을 수정하거나 특정 jsp 파일에 의해 도입된 리소스가 수정된 후 재컴파일 작업이 트리거된다는 것입니다. 따라서 가장 좋은 판단 기준은 특정 jsp 또는 리소스의 마지막 수정 속성입니다. 일반적인 순서는 jsp를 컴파일하여 클래스 파일을 생성하고 클래스 파일의 마지막 수정 속성을 다음의 마지막 수정 속성으로 설정하는 것입니다. 이때 두 파일의 마지막 수정 속성은 동일하며, jsp 파일을 변경하여 저장하면 jsp의 lastmodified 속성이 현재 시간으로 설정되어 있다고 판단합니다. 두 파일의 lastmodified 속성을 판단하여 재컴파일할지 여부. 재컴파일 후에는 jsp 파일과 클래스 파일의 lastmodified 속성이 다시 동일하게 설정됩니다. 가져온 리소스의 경우 마지막 컴파일 중에 가져온 리소스의 lastmodified 속성을 메모리에 유지하며, 가져온 리소스의 lastmodified 속성을 지속적으로 가져오고 메모리의 해당 lastmodified 속성과 비교하여 재컴파일 여부도 쉽게 판단할 수 있습니다. 필요합니다.

마지막으로 로컬 리소스와 원격 리소스를 각각 감지하는 방법은 무엇입니까? 로컬 리소스의 경우 java.io.File 클래스를 사용하면 JSP 파일이나 기타 파일의 lastmodified 속성을 쉽게 읽을 수 있습니다. jar 패키지와 같은 원격 리소스의 경우 jar에 포함된 속성을 쉽게 처리하려면 java.NET.URL을 사용하는 것이 매우 편리합니다. 여기에는 일반 jar, 파일, ftp 및 기타 프로토콜이 포함되어 있습니다.

URL includeUrl = new URL("jar:http://hostname/third.jar!/");
URLConnection iuc = includeUrl.openConnection();
long includeLastModified = ((JarURLConnection) iuc).getJarEntry().getTime();

3단계만 거치면 원격 jar 패키지 읽기를 완료하고 마지막 수정 시간을 얻을 수 있습니다. 물론 URL은 로컬 파일 리소스 읽기도 지원하므로 리소스 읽기에 좋은 추상 개체입니다. Tomcat에서 가져온 리소스 관리는 URL을 작업 개체로 사용합니다.

이 섹션에서는 Jasper의 자동 감지 메커니즘 구현에 대해 설명합니다. 자동 감지 메커니즘은 우리가 직접 jsp를 수정하지 않아도 되고 Tomcat이 직접 컴파일 작업을 수행할 수도 있습니다. 우리는 Jasper를 통해 정기적으로 컴파일 작업을 감지합니다.

읽어주셔서 감사합니다. 모두에게 도움이 되기를 바랍니다


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.