개발서적

패턴과 아키텍처는 잘 구성되어 있는가?너무 많은 패턴을 사용하지 않았는가?너무 많은 패턴을 적용하면 유지보수성이 떨어지고, 문제가 발생했을 때 추적하기가 어려워진다.좋은 패턴이라고 무작정 적용하기보다는 꼭 필요한 패턴만을 사용해야 한다.데이터를 리턴할 때 TO(혹은 VO) 패턴을 사용하였는가? 아니면 Collection 관련 클래스를 사용하였는가?데이터를 주고 받는 시간을 절약하기 위해서 일반적으로 TO 패턴을 사용한다.그리고 때에 따라서는 Collection 관련 클래스를 사용하기도 한다.이러한 패턴을 적용하지 않았거나 관련 표준을 정하지 않고 개발을 할 경우 시스템의 응답 시간도 영향이 있겠지만, 유지 보수성이 떨어진다.게다가 HashMap으로 데이터를 주고 받으면, 소스를 완전히 뜯어 보지 않는 이..
암달의 법칙1 Core에서 20시간 소요되는 작업 중 1시간은 절대 개선할 수 없다면, 20배 이상의 성능 향상은 불가능성능 개선율1/((1-P) + P/S)P는 개선 가능한 부분의 비율 / 개선 가능한 부분이 100% => 1S는 개선된 정도 / 2배의 성능 향상이 이루어 졌다면 S = 2  성능 튜닝 step by step원인 파악어디가 병목인지 확실히 파악목표 설정성능 개선뿐만 아니라, 향후 유지보수까지 모두 고려해서 목표를 설정튜닝 실시코드를 최적화하며 튜닝개선율 확인결과가 만족스럽지 않은 경우에는 '튜닝 실시' 단계록 다시 넘어가서 진행결과 정리 및 반영되도록 꼭 필요한 사항들만 정리  성능 튜닝의 비법하나만 보지 말아라병목의 대상대상세부 대상서버 장비CPU, Network, Disk, Memo..
대상 찾기상위 20%의 화면을 분석 및 튜닝 대상으로 선정기존 시스템 모니터링 툴의 통계 기능을 사용하여 찾기기존 시스템의 웹 로그를 분석하기 예시구분화면명초기 화면로그인원무환자 접수 신청진료환자조회처방전 지정치료 일수 입력처방 내림외래 기록지 저장원무수납 조회수납 처리CASE1안내원은 환자의 이름을 '김'으로만 조회했다그런데 시스템의 응답이 없어서 안내원은 계속 검색 버튼을 누르기 시작했다안내원이 검색을 누른 후부터 해당 애플리케이션이 DB의 CPU 대부분을 점유했고DB쿼리의 문제로 오픈이 연기되었다CASE2한 시스템이 매일 14~16시 사이에만 다운되는 현상이 있어 진단이 시스템은 내부용 시스템이 아니라 대외로 오픈된 시스템임시스템의 로그 분석을 해서 하나의 화면이 한 시간에 10만 번 이상 호출되는..
자바의 Runtime data areaPC 레지스터JVM 스택힙(Heap) => GC 발생메서드 영역런타임 상수(constant) 풀네이티브 메서드 스택Class Loader Subsystem클래스나 인터페이스르 JVM으로 로딩하는 기능을 수행 Execution Engine로딩된 크래스의 메서드들에 포함되어 있는 모든 인스트럭션 정보를 실행  Heap 메모리클래스 인스턴스, 배열공유(shared) 메모리여러 스레드에서 공유하는 데이터들이 저장 Non-heap 메모리Method Area메서드 영역은 모든 JVM 스레드에서 공유한다.Java Stacks스레드가 시작할 때 JVM 스택이 생성된다.메서드가 호출되는 정보인 프레임(frame)이 저장된다.지역 변수와 임시 결과, 메서드 수행과 리턴에 관련된 정보들..
HotSpot VMSun에서 만든 성능 개선을 위한 JIT(Just In Time) 컴파일러 (HotSpot)프로그램의 성능에 영향을 주는 지점에 대해 지속적으로 분석 VM 런타임JIT 컴파일러메모리 관리자 JIT OptimizerJIT 애플리케이션에서 각각의 메서드를 컴파일할 만큼 시간적 여유가 많지 않음따라서 모든 코드는 초기에 인터프리터에 의해서 시작되고해당 코드가 충분히 많이 사용될 경우에 컴파일할 대상이 된다HotSpot Vm에서는 메서드에 있는 두 개의 카운터에 의해 통제수행 카운터메서드를 시작할 때마다 증가CompileThreshold : 한계칙벡에지 카운터높은 바이트 코드 인덱스에서 낮은 인덱스 컨트롤 흐름이 변경될 때마다 증가메서드가 루프가 존재하는지를 확인카운터들이 인터프리터에 의해 증..
아파치 웹 서버의 설정MPM 사용 (Multi-Processing-Module)여러 개의 프로세싱 모듈 기반의 서비스를 제공httpd.confThreadsPerChild 250웹 서버가 사용하는 스레드의 개수 지정만약 이 수치가 적게 지정되어 있다면, 이 수치를 늘려 주어야 함그래야 서버가 더 많은 사용자의 요청을 처리할 수 있음MaxRequestsPerChild 0 최대 요청 개수를 지정0이면 그 수에 제한을 두지 않겠다가급적 기본값인 0으로 할 것"Include conf/extr/httpd-mpm.conf" 주석 해제세밀한 스레드 설정 정보를 지정할 수 있게 됌 httpd-mpm.confStartServers 2서버를 띄울 때 프로세스의 개수를 지정한다MaxClients 150최대 처리 가능한 클라이..
JSP 라이프 사이클JSP URL 호출페이지 번역JSP 페이지 컴파일클래스 로드인스턴스 생성jspInit 메서드 호출_jspService 메서드 호출jspDestroy 메서드 호출 JSP 적절한 include 사용하기정적인 방식: JSP의 라이프 사이클 중 JSP 페이지 번역 및 컴파일 단계에서 필요한 JSP를 읽어서 메인 JSP의 자바 소스 및 클래스에 포함 시키는 방식동적인 방식: 페이지가 호출될 때마다 지정된 페이지를 불러들여서 수행느림따라서 막 쓰지 말고 상황에 맞는 include 방식을 사용해야 함 서블릿 라이프 사이클Servlet 객체가 자동으로 생성되고 초기화 되거나사용자가 해당 Servlet을 처음으로 호출했을 때 생성되고 초기화 된다.그 다음 계속 '사용 가능' 상태로 대기한다중간에 예외..
결론 : 로그를 System.out으로 찍지 말아라 필요 로그를 클래스로 관리하는 방법public clas SimpleLogger { pricate static final boolean printFlag=false; public static void log(String message) { if (printFlag) { logger.info(message); } }}public class Logger { final Logger logger = LoggerFactory.getLogger(Logger.class); Integer t; Integer oldT; public void setTemperature(Integer temperature) { ..
하드 디스크 데이터 읽을 때의 프로세스 진행 과정파일을 읽으라는 메서드를 자바에 전달파일명을 전달 받은 메서드가 운영체제의 커널에게 파일을 읽어 달라고 요청커널이 하드 디스크로부터 파일을 읽어서 자신의 커널에 있는 버퍼에 복사 (DMA에서 작업)DMA (Direct Message Access)CPU의 개입 없이 주변장치와 주기억장치와의 데이터 직접 전송자바에서는 마음대로 커널의 버퍼를 사용하지 못하므로, JVM으로 그 데이터를 전달JVM에서 메서드에 있는 스트림 관리 클래스를 사용하여 데이터를 처리 NIO (New Input/Output)  / Java 4 [Java] IO와 NIO의 차이점? / IO와 NIO의 선택NIO ? 자바 4부터 새로운 입출력(New Input/Output)이라는 뜻에서 jav..
static이거 정처기 문제에 대표적으로 나오는 내용public static int value = 0a = new StaticEx();a.value++;b = new StaticEx();b.value++;c = new StaticEx();c.value++;print(a, b, c) // 3, 3, 3// 서로 다른 객체를 생성했지만 최종적으로 static 값은 3이므로  static 초기화 블록static { staticVal = "Value"; staticVal = StaticEx.staticInt;}  자주 사용하고 절대 변하지 않는 변수는 final static으로 선언하자설정 파일 정보도 static으로 관리하자코드성 데이터는 DB에서 한 번만 읽자  Static 주의해야 하는 상황publi..
Stringfinal String aValue = "abcde"for(int i = 0; i 위와 같이 테스트를 진행할 때 아래와 같이 시간이 소요가 됩니다.a95초b0.24초c0.17초  Stringabcdeabcde  abcdeabcdeabcde 위와 같이 새로운 객체가 계속 생성되면서 이전 객체를 쓰레기로 만듭니다.많은 GC를 하게 하여 시간이 많이 소요됩니다. StringBuffer, StringBuilderabcdeabcdeabcde위와 같이 새로운 객체를 생성하지 않고 기존에 있는 객체의 크기를 증가시키면서 값을 더하기 때문에 시간이 조금 소요됩니다.  Charsequence인터페이스구현 객체로 CharBuffer, String, StringBuffer, StringBuilder가 있음Stri..
프로파일링 툴 / APM 툴 프로파일링 툴소스 레벨의 분석을 위함애플리케이션의 세부 응답 시간까지 분석 가능메모리 사용량을 객체나 클래스, 소스의 라인 단위까지 분석 가능가격이 APM 툴에 비해 저렴보통 사용자수 기반으로 가격이 정해짐자바 기반의 클라이언트 프로그램 분석을 할 수 있음 응답시간 프로파일링 기능하나의 클래스 내에서 사용되는 메서드 단위의 응답 시간 측정메모리 프로파일링잠깐 사용하고 GC의 대상이 되는 부분을 찾거나 메모리 부족 현상이 발생하는 부분을 찾기 위함  APM 툴애플리케이션의 장애 상황에 대한 모니터링 및 문제점 진단이 주 목적서버의 사용자 수나 리소스에 대한 모니터링이 가능실시간 모니터링을 위한 툴가격이 프로파일링 툴에 비해 비쌈보통 CPU 수를 기반으로 가격이 정해짐자바 기반의..
류가든
'개발서적' 카테고리의 글 목록