How to find bottleneck in J2ee application_first_print
|
|
- 영희 서문
- 6 years ago
- Views:
Transcription
1 How to find bottleneck in J2EE application 작성자 : 자바스터디네트워크조대협 (bcho@bea.com) J2ee application 을운영하다보면, 시스템이극도로느려지거나, 멈춰버리는현상이생기고는한데, 분명히개발하면서테스트할때는문제가없었는데, 왜이런일이생기고, 어떻게대처해야하는지에대해서알아보도록하자. 일반적으로 J2ee application 을서비스하기위해서는아래와같은구조를가지게된다. client Web Server User Application WAS OR Servlet Engine RDBMS N/W JVM < 그림 1. 일반적은 J2ee application 의구조 > J2ee application 의동작에필요한구성요소를나눠보면위와같이 Network, User Application ( 이하 User AP), WAS 또는 Servlet Engine( 이하통칭해서 WAS),JVM 과 RDBMS 이렇게크게다섯가지조각으로나뉘어진다. 물론 JCA 를이용해서 Legacy 와연결할수도있고, RMI/CORBA 를이용하여다른 Architecture 를구현할수는있으나, 이강좌는어디까지나일반론을설명하고자하는것임으로범위에서는제외하겠다. 1. Hang up 과 slow down 현상의정의 먼저용어를정의하도록하자.. 시스템이느려지거나멈추는현상에대해서아래와같이용어를정의하자
2 - Hang up : Server Instance 는실행되고있느나, 아무런응답이없는상황 ( 멈춤상태 ) - Slowdown : Server Instance 의 response time 이아주급격히떨어지는상태 ( 느려짐 ) 이 Hangup 과 slowdown 현상은, 대부분이그림 1 에서설명한다섯가지요소중하나이상의병목으로인해서발생한다. 즉, 이병목구간을발견하고, 그구간을제거하면정상적으로시스템을운영할수있게되는것이다. 2. Slow down analysis in WAS & User AP 1. WAS 의기본구조 이병목구간을발견하는방법에앞서서, 먼저 WAS 시스템의기본적인내부구조를이해할필요가있다. * Thread Pooling < 그림 2. WAS 시스템의구조 > < 그림 2> 는일반적인 WAS 의구조이다.
3 WAS 는 Client 로부터 request 를받아서, 그 Request 의내용을분석한다 JMS 인지, HTTP, RMI request 인지를분석한후 (Dispatcher) 그내용을 Queue 에저장한다. Queue 에저장된내용은 WAS 에서 Request 를처리할수있는 Working Thread 들이있을때각각의 Thread 들이 Queue 에서 Request 를하나씩꺼내서각각의 Thread 들이그기능을수행한다. 여기서우리가주의깊게봐야하는것은 Thread pooling 이라는것인데. Thread 를미리만들어놓고, Pool 에저장한체로필요할때그 Thread 를꺼내서사용하는방식이다. (Connection Pooling 과같은원리이다.) WAS 에서는일반적으로업무의성격마다이 Thread Pool 을나누어서만들어놓고사용을한다. 즉예를들어서금융시스템의예금시스템과보험시스템이하나의 WAS 에서동작할때, 각각의업무를 Thread Pool 을나누어서분리하는방식이다. 이방식을사용하면업무의부하에따라서각 Thread Pool 의 Thread 수를조정할수있으며, 만약에 Thread 가모자르거나 deadlock 등의장애사항이생기더라도그것은하나의 Thread Pool 에만국한되는이야기이기때문에, 다른업무에영향을거의주지않는다. 2. Thread Dump 를통한 WAS 의병목구간분석 위에서살펴봤듯이, WAS 는기본적으로 Thread 기반으로작동하는 Application 이다. 우리가 hang up 이나 slow down 은대부분의경우가 WAS 에서현상이보이는경우가많다. (WAS 에원인이있다는소리가아니라.. 다른요인에의해서라도 WAS 의처리속도가느려질수있다는이야기다.) 먼저이 WAS 가내부적으로어떤 Application 을진행하고있는지를알아내면병목구간에한층쉽게접근할수가있다. 1) What is thread dump? 이를위해서 JVM 에서는 Java Thread Dump 라는것을제공한다. Thread Dump 란 Java Application 이작동하는순간의 X-Ray 사진, snapshot 을의미한다. 즉이 Thread dump 를연속해서수번을추출한다면, 그당시에 Application 이어떻게동작하고진행되고있는가를살펴볼수있다. Thread dump 를추출하기위해서는 - Unix 에서는 kill 3 pid - Windows 계열에서는 Ctrl + break
4 를누르면 stdout 으로 thread dump 가추출된다. Thread dump 는 Application 을구성하고있는현재구동중인모든 Thread 들의각각의상태를출력해준다. "ExecuteThread: '42' for queue: 'default'" daemon prio=5 tid=0x3504b0 nid=0x34 runnable [0x9607e000..0x9607fc68] at java.net.socketinputstream.socketread(native Method) at java.net.socketinputstream.read(socketinputstream.java:85) at oracle.net.ns.packet.receive(unknown Source) at oracle.net.ns.netinputstream.getnextpacket(unknown Source) at oracle.net.ns.netinputstream.read(unknown Source) at oracle.net.ns.netinputstream.read(unknown Source) at oracle.net.ns.netinputstream.read(unknown Source) at oracle.jdbc.ttc7.marengine.unmarshalub1(marengine.java:730) at oracle.jdbc.ttc7.marengine.unmarshalsb1(marengine.java:702) at oracle.jdbc.ttc7.oall7.receive(oall7.java:373) at oracle.jdbc.ttc7.ttc7protocol.dooall7(ttc7protocol.java:1427) at oracle.jdbc.ttc7.ttc7protocol.fetch(ttc7protocol.java:911) at oracle.jdbc.driver.oraclestatement.doexecutequery(oraclestatement.java:1948) at oracle.jdbc.driver.oraclestatement.doexecutewithtimeout(oraclestatement.java:2137) at oracle.jdbc.driver.oraclepreparedstatement.executeupdate(oraclepreparedstatement.java:404) at oracle.jdbc.driver.oraclepreparedstatement.executequery(oraclepreparedstatement.java:344) at weblogic.jdbc.pool.preparedstatement.executequery(preparedstatement.java:51) at weblogic.jdbc.rmi.internal.preparedstatementimpl.executequery(preparedstatementimpl.java:56) at weblogic.jdbc.rmi.serialpreparedstatement.executequery(serialpreparedstatement.java:42) Thread name Program stack of this thread Thread id (signature) < 그림 3-2. Thread dump > Thread Status Sun JVM 그림 3-2 는전체 Thread dump 중에서하나의 Thread 를나타내는그림이다. Thread Dump 에서각각의 Thread 는 Thread 의이름과, Thread 의 ID, 그리고 Thread 의상태와, 현재이 Thread 가실행하고있는 Prorgam 의스택을보여준다. - Thread name 각쓰레드의이름을나타낸다. WAS 나 Servlet Engine 에따라서는이이름에 Thread Queue 이름등을배정하는경우가있다. - Thread ID 쓰레드의 System ID 를나타낸다. 이강좌나중에이 ID 를이용해서각 Thread 별 CPU 사용률을추적할수있다. - Thread Status
5 매우중요한값중의하나로각 Thread 의현재상태를나타낸다. 일반적으로 Thread 가사용되고있지않을때는 wait 를, 그리고사용중일때는 runnable 을나타내는게일반적이다. 그외에, IO Wait 나 synchronized 등에걸려있을때 Wait for monitor entry, MW (OS 별 JVM 별로틀림 ) 등의상태로나타난다. - Program stack of thread 현재해당 Thread 가어느 Class 의어느 Method 를수행하고있는지를나타낸다. 이정보를통해서현재 WAS 가어떤작업을하고있는지를유추할수있다. 2) How to analysis thread dump 앞에서 Thread dump 가무엇이고, 어떤정보를가지고있는지에대해서알아봤다. 그러면이 Thread dump 를어떻게분석을하고, System 의 Bottle neck 을찾아내는데이용할지를살펴보기로하자. System 이 Hangup 이나 slowdown 에걸렸을때, 먼저 Thread dump 를추출해야한다. 이때한개가아니라 3~5 초간격으로 5 개정도의 dump 를추출한다. 추출한여러개의 dump 를연결하면각 Thread 가시간별로어떻게변하고있는지를판별할수있다. 먼저각각의 Thread 덤프를비교해서보면, 각각의 Thread 는적어도 1~2 개의덤프내에서연속된모습을보여서는안되는게정상이다. 일반적으로 Application 은내부적으로매우고속으로처리되기때문에, 하나의 Method 에 1 초이상머물러있는다는것은거의있을수없는일이다. Thread Dump 의분석은각각의 Thread 가시간이지남에따라서진행되지않고멈춰있는 Thread 를찾는데서부터시작된다. 예를들어서설명해보자. 아래 < 그림 3-3> 의프로그램을보면 MY_THREAD_RUN() 이라는메소드에서부터 MethodA() MethodB() MethodC() 를차례로호출하는형태이다. MYTHREAD_RUN(){ call methoda(); } methoda(){ //dosomething(); call methodb(); } methodb(){ //call methodc(); } methodc(){ // dosomething for(;;){// infinite loop } } < 그림 3-3. sample code >
6 이프로그램을수행하는중에처음부터 Thread Dump 를추출하면대강다음과같은형태일것임을예상할수있다. 함수호출에따라서 Stack 이출력되다가 의단계즉 MethodC 에서무한루프에빠지게되면더이상프로그램이진행이없기때문에똑같은덤프를유지하게된다. MYTHREAD runnable at MYTHREAD_RUN() : MYTHREAD runnable at methoda() at MYTHREAD_RUN() : MYTHREAD runnable at methodb() at methoda() at MYTHREAD_RUN() : MYTHREAD runnable at methodc() at methodb() at methoda() at MYTHREAD_RUN() : MYTHREAD runnable 이덤프모양이반복됨 at methodc() at methodb() at methoda() at MYTHREAD_RUN() : 우리는이덤프만을보고 methodc 에서무엇인가잘못되었음을유추할수있고, methodc 의소스코드를분석함으로써문제를해결할수있다. 그렇다면이제부터 Slow down 과 Hang up 현상을유발하는일반적인유형과그 Thread Dump 의모양에대해서알아보도록하자. - CASE 1. lock contention 잘알다싶이 Java 는 Multi Threading 을지원한다. 이경우공유영역을보호하기위해서 Synchronized method 를이용하는데, 우리가흔히들말하는 Locking 이이것이다. 예를들어 Thread1 이 Synchronized 된 Method A 의 Lock 을잡고있는경우, 다른쓰레드들은그 Method 를수행하기위해서, 앞에서 Lock 을잡은쓰레드가그 Lock 을반환하기를기다려야한다. 그림 3-4 Thread 1 Thread 2
7 Synchronized MethodA Thread 3 Thread 4 Wait for Lock < 그림 3-4. Thread 간에 Lock 을기다리는형태 > 만약에이 Thread 1 의 MethodA 의수행시간이아주길다면 Thread 2,3,4 는마냥이수행을아주오랜시간기다려야하고, 다음 2 번이 Lock 을잡는다고해도 3,4 번 Thread 들은 1 번과 2 번쓰레드가끝난시간만큼의시간을누적해서기다려야하기때문에, 수행시간이매우느려지는현상을겪게된다. 이처럼여러개의 Thread 가하나의 Lock 을동시에획득하려고하는상황을 Lock Contention 이라고한다. Threads Thread dump Lock 을기다리는쓰레드 (Thread 2) Lock 을잡고있는쓰레드 (Thread 1) Time < 그림 3-5. Lock Contention 상황에서 Thread 의시간에따른진행상태 > 이런상황에서 Thread Dump 를추출해보면 < 그림 3-6> 과같은형태를띠게된다. "ExecuteThread: '12' for queue: 'weblogic.kernel.default'" daemon prio=10 tid=0x0055ae20 nid=23 lwp_id= waiting for monitor entry [0x2fb6e000..0x2fb6d530] at sun.misc.launcher$appclassloader.loadclass(launcher.java:258) - waiting to lock <0x38819a18> (a sun.misc.launcher$appclassloader) at java.lang.classloader.loadclass(classloader.java:292) - locked <0x38db9ea8> (a weblogic.utils.classloaders.genericclassloader) at java.lang.classloader.loadclass(classloader.java:292) - locked <0x38f520f8> (a weblogic.utils.classloaders.genericclassloader) at java.lang.classloader.loadclass(classloader.java:292) - locked <0x3941af18> (a weblogic.utils.classloaders.genericclassloader) at java.lang.classloader.loadclass(classloader.java:292) - locked <0x3941b6b0> (a weblogic.utils.classloaders.changeawareclassloader)
8 at java.lang.classloader.loadclass(classloader.java:255) : at org.apache.xerces.jaxp.saxparserfactoryimpl.newsaxparser(unknown Source) at org.apache.axis.utils.xmlutils.getsaxparser(xmlutils.java:252) - locked <0x329fcf50> (a java.lang.class) "ExecuteThread: '13' for queue: 'weblogic.kernel.default'" daemon prio=10 tid=0x0055bde0 nid=24 lwp_id= waiting for monitor entry [0x2faec000..0x2faec530] at org.apache.axis.utils.xmlutils.getsaxparser(xmlutils.java:247) - waiting to lock <0x329fcf50> (a java.lang.class) at org.apache.axis.encoding.deserializationcontextimpl.parse(deserializationcontextimpl.java:239 "ExecuteThread: '14' for queue: 'weblogic.kernel.default'" daemon prio=10 tid=0x0061d680 nid=25 lwp_id= waiting for monitor entry [0x2fa6b000..0x2fa6b530] at org.apache.axis.utils.xmlutils.releasesaxparser(xmlutils.java:283) - waiting to lock <0x329fcf50> (a java.lang.class) at org.apache.axis.encoding.deserializationcontextimpl.parse(deserializationcontextimpl.java:254) "ExecuteThread: '15' for queue: 'weblogic.kernel.default'" daemon prio=10 tid=0x0061dc20 nid=26 lwp_id= waiting for monitor entry [0x2f9ea000..0x2f9ea530] at org.apache.axis.utils.xmlutils.releasesaxparser(xmlutils.java:283) - waiting to lock <0x329fcf50> (a java.lang.class) at < 그림 3-6. Lock Contention 에서 Lock 을기다리고있는상황의 Thread Dump> 그림 3-6 의덤프를보면 12 번 Thread 가 org.apache.axis.utils.xmlutils.getsaxparser 에서 Lock 을잡고있는것을볼수있고, 36,15,14 번쓰레드들이이 Lock 을기다리고있는것을볼수있다. 해결방안이런 Lock Contention 상황은 Multi Threading 환경에서는어쩔수없이발생하는상황이기는하지만, 이것이문제가되는경우는 Synchronized Method 의실행시간이불필요하게길거나, 불필요한 Synchronized 문을사용했을때발생한다. 그래서이문제를해결하기위해불필요한 Sychronized Method 의사용을자제하고, Synchronized block 안에서의최적화된 Algorithm 을사용하는것이필요하다. - CASE 2. dead lock 이 Locking 으로인해서발생할수있는또다른문제는 dead Lock 현상이다. 두개이상의쓰레드가서로 Lock 을잡고기다리는 환형대기조건 이성립되었을때, 서로 Lock 이풀리지않고무한정대기하는현상을이야기한다.
9 Time 그림 3-7 을보면 Thread1 은 MethodA 를수행하고있는데, sychronized methodb 를호출하기전에 Thread2 가 methodb 가끝나기를기다리고있다. 마찬가지로 Therad2 는 Thread3 가수행하고있는 methodc 가끝나기를기다리고있고, methodc 에서는 Thread1 에서수행하고있는 methoda 가끝나기를기다리고있다. 즉각각의메소드들이서로끝나기를기다리고있는 환형대기조건 이기때문에이 Application 의 3 개의쓰레드들은프로그램이진행이되지않게된다. Thread 1 Synchronized MethodA Waitting Thread 3 Synchronized MethodC Waitting Thread 2 Synchronized MethodB Waitting sychronized methoda(){ call methodb(); } sychronized methodb(){ call methodc(); } sychronized methodc(){ call methoda(); } < 그림 3-7. 환형대기조건에의한 deadlock > 이러한 환형대기조건 에의한 deadlock 은 Thread Dump 를추출해보면 < 그림 3-8> 과같은패턴을띠우고있으며시간이지나도풀리지않는다. Threads Thread dump
10 서로 Lock 을잡고있음 < 그림 3-8. Deadlock 이걸렸을때시간진행에따른 Thread 의상태 > "ExecuteThread-6" (TID:0x , sys_thread_t:0x39658e50, state:mw, native ID:0xf10) prio=5 at oracle.jdbc.driver.oraclestatement.close(oraclestatement.java(compiled Code)) at weblogic.jdbc.common.internal.connectionenv.cleanup(connectionenv.java(compiled Code)) at weblogic.jdbc.common.internal.connectionpool.release(connectionpool.java(compiled Code)) at weblogic.jdbcbase.pool.connection.close(connection.java(compiled Code)) at sis.ao.svao0400r.svao0400rq.mainprocess(svao0400rq.java(compiled Code)) at sis.ao.svao0400r.svao0400rq.doget(svao0400rq.java(compiled Code)) at javax.servlet.http.httpservlet.service(httpservlet.java(compiled Code)) at javax.servlet.http.httpservlet.service(httpservlet.java(compiled Code)) at weblogic.servlet.internal.servletstubimpl.invokeservlet(servletstubimpl.java(compiled Code)) : "ExecuteThread-8" (TID:0x , sys_thread_t:0x396eb890, state:mw, native ID:0x1112) prio=5 at oracle.jdbc.driver.oracleconnection.commit(oracleconnection.java(compiled Code)) at weblogic.jdbcbase.pool.connection.commit(connection.java(compiled Code)) at sis.as.svas0900e.svas0902es.mainprocess(svas0902es.java(compiled Code)) at sis.as.svas0900e.svas0902es.doget(svas0902es.java(compiled Code)) at javax.servlet.http.httpservlet.service(httpservlet.java(compiled Code)) at javax.servlet.http.httpservlet.service(httpservlet.java(compiled Code)) at weblogic.servlet.internal.servletstubimpl.invokeservlet(servletstubimpl.java(compiled Code)) : ( 중략 ) sys_mon_t:0x39d75b38 infl_mon_t: 0x39d6e288: oracle.jdbc.driver.oracleconnection@310bc380/310bc388: owner "ExecuteThread-8" (0x396eb890) 1 entry 1) Waiting to enter: "ExecuteThread-10" (0x3977e2d0) "ExecuteThread-6" (0x39658e50) sys_mon_t:0x39d75bb8 infl_mon_t: 0x39d6e2a8: \ oracle.jdbc.driver.oraclestatement@33aa1bd0/33aa1bd8: owner "ExecuteThread-6" (0x39658e50) 1 entry 2) Waiting to enter: "ExecuteThread-8" (0x396eb890
11 IBM AIX JVM IBM AIX 의 JVM 의경우에는 Lock 의정보가각 Thread 의 Stack 에나타나는것이아니라. 별도로 Thread 별 Locking 정보를따로나타내주기때문에.. Lock 정보를별도로확인해야한다. < 그림 3-9. Deadlock 이걸린 IBM AIX Thread Dump > DeadLock 의검출은 Locking Condition 을비교함으로써검출할수있으며, 최신 JVM (Sun 1.4 이상등 ) 에서는 Thread Dump 추출시만약 Deadlock 이있다면해당 Deadlock 을찾아주는기능을가지고있다. 그림 3-9 를보자. IBM AIX 의 Thread 덤프이다. 1) 항목을보면현재 8 번쓰레드가잡고있는 Lock 은 10 번과 6 번쓰레드가기다리고있음을알수있으며. Lock 은 OracleConnection 에의해서잡혀있음을확인할수있다. ( 아래 ) sys_mon_t:0x39d75b38 infl_mon_t: 0x39d6e288: oracle.jdbc.driver.oracleconnection@310bc380/310bc388: owner "ExecuteThread-8" (0x396eb890) 1 entry 1) Waiting to enter: "ExecuteThread-10" (0x3977e2d0) "ExecuteThread-6" (0x39658e50) 그림 3-9 의 2) 번항목을보면이 6 번쓰레드는 OracleStatement 에서 Lock 을잡고있는데, 이 Lock 을 8 번쓰레드가기다리고있다. ( 아래 ) sys_mon_t:0x39d75bb8 infl_mon_t: 0x39d6e2a8: \ oracle.jdbc.driver.oraclestatement@33aa1bd0/33aa1bd8: owner "ExecuteThread-6" (0x39658e50) 1 entry 2) Waiting to enter: "ExecuteThread-8" (0x396eb890 결과적으로 6 번과 8 번은서로 Lock 을기다리고있는상황이되어 Lock 이풀리지않는 Dead Lock 상황이된다. 해결방안 Dead Lock 의해결방안은서로 Lock 을보고있는것을다른 Locking Object 를사용하거나 Lock 의방향 (Synchronized call 의방향 ) 을바꿔줌으로써해결할수있다.
12 User Application 에서발생한경우에는 sychronized method 의호출순서를 환형대기조건 이생기지않도록바꾸도록하고. 위와같이 Vendor 들에서제공되는코드에서문제가생긴경우에는 Vendor 에패치를요청하도록하여해결한다. - CASE 3. wait for IO response 다음으로많이볼수있는패턴은각각의 Thread 들이 IO Response 를기다리는데 IO 작업에서 response 가느리게와서시스템처리속도가느려지는경우가있다. Threads Thread dump DB 로부터응답을기다리고있음 Time < 그림 Thread 들이 IO Wait 를할때시간에따른 Thread Dump 상황 > "ExecuteThread: '42' for queue: 'default'" daemon prio=5 tid=0x3504b0 nid=0x34 runnable [0x9607e000..0x9607fc68] at java.net.socketinputstream.socketread(native Method) at java.net.socketinputstream.read(socketinputstream.java:85) at oracle.net.ns.packet.receive(unknown Source) at oracle.net.ns.netinputstream.getnextpacket(unknown Source) at oracle.net.ns.netinputstream.read(unknown Source) at oracle.net.ns.netinputstream.read(unknown Source) at oracle.net.ns.netinputstream.read(unknown Source) at oracle.jdbc.ttc7.marengine.unmarshalub1(marengine.java:730) at oracle.jdbc.ttc7.marengine.unmarshalsb1(marengine.java:702) at oracle.jdbc.ttc7.oall7.receive(oall7.java:373) at oracle.jdbc.ttc7.ttc7protocol.dooall7(ttc7protocol.java:1427) at oracle.jdbc.ttc7.ttc7protocol.fetch(ttc7protocol.java:911) at oracle.jdbc.driver.oraclestatement.doexecutequery(oraclestatement.java:1948) at oracle.jdbc.driver.oraclestatement.doexecutewithtimeout(oraclestatement.java:2137) at oracle.jdbc.driver.oraclepreparedstatement.executeupdate(oraclepreparedstatement.java:404) at oracle.jdbc.driver.oraclepreparedstatement.executequery(oraclepreparedstatement.java:344) at weblogic.jdbc.pool.preparedstatement.executequery(preparedstatement.java:51) at weblogic.jdbc.rmi.internal.preparedstatementimpl.executequery(preparedstatementimpl.java:56) at weblogic.jdbc.rmi.serialpreparedstatement.executequery(serialpreparedstatement.java:42) at com.xxxx 생략 at..
13 < 그림 Thread 가 DB Query Wait 에걸려있는 stack > 그림 3-10 상황은 DB 에 Query 를보내고 response 를 Thread 들이기다리고있는상황이다. AP 에서 JDBC 를통해서 Query 를보냈는데, Response 가오지않으면계속기다리게있게되고, 다른 Thread 가같은 DB 로보냈는데. Response 가오지않고, 이런것들이중복되서결국은사용할수없는 Thread 가없게되서새로운 request 를처리하지못하게되고, 기존에 Query 를보낸내용도응답을받지못하는상황이다. < 그림 3-11> 은각각의 Thread 의 stack dump 인데, 그내용을보면 ExecuteQuery 를수행한후에, Oracle 로부터데이타를 read 하기위해대기하는것을확인할수있다. 이런현상은주로 DB 사용시대용량 Query( 시간이많이걸리는 ) 를보냈거나, DB 에 lock 들에의해서발생하는경우가많으며, 그외에도 Socket 이나 File 을사용하는 AP 의경우 IO 문제로인해서발생하는경우가많다. 해결방안이문제의해결방안은 Thread Dump 에서문제가되는부분을발견한후에, 해당소스코드나시스템등에접근하여문제를해결해야한다. - CASE 4. high CPU usage 시스템이느려지거나거의멈추었을때, 우리가초기에해볼수있는조치가무엇인가하면, 현재시스템의 CPU 사용률을체크해볼필요가있다. 해당시스템의 CPU 사용률이높은경우, 문제가되는경우가종종있는데. 이런문제에서는 CPU 를많이사용하는모듈을찾아내는것이관건이다. 이를위해서먼저 top 이나 glance(hp UX) 를통해서 CPU 를많이점유하고있는 Process 를판독한다. 만약 WAS 이외의다른 process 가 CPU 를많이사용하고있다면, 그 Process 의 CPU 과사용원인을해결해야한다. CPU 사용률이외에도, Disk IO 양이많지는않은지.. WAS 의 JVM Process 가 Swap out (DISK 로 SWAP 되는현상 ) 이없는지살펴보도록한다. JVM Process 가 Swapping 이되면실행속도가엄청나게느려지기때문에, JVM Process 는 Swap out 되어버리면안된다.
14 일단 CPU 를과사용하는원인이 WAS Process 임을발견했으면프로그램상에어떤 Logic 이 CPU 를과점유하는지를찾아내야한다. 방식을정리해보면다음과같다. WAS Process 의 Thread 별 CPU 사용률을체크한다. 1) Thread Dump 를추출한다. 2) 1) 과, 2) 에서추출한정보를 Mapping 하여, 2) 의 Thread Dump 상에서 CPU 를과점유하는 Thread 를찾아내어해당 Thread 의 Stack 을분석하여 CPU 과점유하는원인을찾아낸다. 대부분이런요인을분석해보면다음과같은원인이많다. - 과도한 String 연산으로인해서 CPU 사용률이높아지는경우잘알고있다시피 String 연산은 CPU 를아주많이사용한다. String 과 Loop 문 (for,while 등 ) 의사용은 CPU 부하를유발하는경우가많기때문에가급적이면 String Buffer 를사용하도록하자. - 과도한 RMI Cal RMI 호출은 Java Object 를 Serialize 하고 Deserialize 하는과정을수반하는데, 이는 CPU 를많이사용하는작업이기때문에사용에주의를요한다. 특별히 RMI 를따로코딩하지않더라도 EJB 를호출하는것이 Remote Call 일때는기본적으로 RMI 호출을사용하게되고, 부하량이많을때이부분이주로병목의원인이되곤한다. 특히 JSP/Servlet EJB 호출되는것이같은 System 의같은 JVM Process 안이라도 WAS 별로별도의설정을해주지않으면 RMI Call 을이용하는형태로구성이되기때문에, 이에대한배려가필요하다. WebLogic 에서 Call By Reference 를위한호출방법정의 참고로 WebLogic 의경우에는 Servlet/JSP EJB 를호출하는방식을 Local Call 을이용하기위해서는같은 ear 파일내에패키징해야하고, EJB 의 weblogicejb-jar.xml 에 enable-call-by-reference 를 true 로설정해줘야한다. (8.1 이상 ) 자세한내용은 lecture_read.jsp?table=j2ee&db=lecture0201_1&id=1&searchby=subject&searchkey=deploy&block=0&page=0 를참고하시바란다. - JNDI lookup
15 JNDI lookup 은 Server 의 JNDI 에 Binding 된 Object 를읽어오는과정이다. 이과정은위에서설명한 RMI call 로수행이되는데. 특히 EJB 를호출하기위해서 Home 과 Remote Interface 를 lookup 하는과장에서종종 CPU 를과점유하는형태를관찰할수있다. 그래서 JNDI lookup 의경우에는 EJB Home Interface 를 Caller Side(JSP/Servlet 또는 poor Java client) 등에서 Caching 해놓고사용하는것을권장한다. 단. 이경우에는 EJB 의 redeploy 기능을제약받을수있다. 다음은각 OS 별로 CPU 사용률이높은 Thread 를검출해내는방법이다. Solaris 에서 CPU 사용률이높은 Thread 를검출하는방법 1.prstat 명령을이용해서 java process 의 LWP(Light Weight process) CPU 사용률을구한다. % prstat L p [WeblogicPID] 1 1 PID USERNAME SIZE RSS STATE PRI NICE TIME CPU PROCESS/LWPID bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/ bwcho 143M 58M sleep : % java/1 2. pstack 명령어를이용해서 native thread 와 LWP 간의 id mapping 을알아낸다. ( 전에먼저 java process 가 lwp 로돌아야되는데, startweblogic.sh 에 LD_LIBRARY_PATH 에 /usr/lib/lwp 가포함되어야한다.) % pstack [WebLogicPID] lwp# 8 / thread# ff29b3dc lwp_sema_wait (f2481e30) ff _park (f2481e30, ff37e000, 0, f2481d78, 25020, f1c81d78) ff3594f0 _swtch (f2481d78, 0, ff37e000, 5, 1000, e) ff cond_wait (4356, 36dfb0, ff37e000, 36dfc8, f2481d78, 0) + e4 fe514f44 1cNObjectMonitorEwait6MxlpnGThread v_ (fe76fb0c, 36dfc8, 36dfb0, fe
16 3. 1 에서얻은 LWP ID 를 pstack log 를통해서분석해보면어느 Thread 에 mapping 되는지를확인할수있다. 여기서는 LWP 8 이 Thread 24 과 mapping 이되고있음을볼수있다. kill 3 [WebLogicPID] 를해서 ThreadDump 를얻어낸다. "ExecuteThread: '11' for queue: 'default'" daemon prio=5 tid=0x36d630 nid=0x18 w aiting on monitor [0xf xf24819e0] at java.lang.object.wait(native Method) at java.lang.object.wait(object.java:415) at weblogic.kernel.executethread.waitforrequest(executethread.java:114) at weblogic.kernel.executethread.run(executethread.java:138) : Thread dump 에서 nid 라는것이있는데, 2 에서얻어낸 thread id 를 16 진수로바꾸면이값이 nid 값과같다. 즉 2 에서얻어낸 thread 24 는 16 진수로 0x18 이기때문에, thread dump 에서 nid 가 0x18 인쓰레드를찾아서어떤작업을하고있는지를찾아내면된다. AIX Unix 에서 CPU 사용률이높은 Thread 검출해내기 1. ps 명령을이용하여, WebLogic Process 의각시스템 thread 의사용률을구한다. % ps mp [WeblogicPID] 0 THREAD USER PID PPID TID ST CP PRI SC WCHAN F TT BND COMMAND usera A * pts/0 - /wwsl/sharedinstalls/aix/jdk130/ Z c S f c020e S f c0213a S f S f S f S f Z c S f f Z c S f S f S f S f S f S f S f a S f b S f c
17 S f d S f e S f f S f a S f a S f a S f c020f S f a 여기서 CP 가가장높은부분을찾는다. 이시스템쓰레드가 CPU 를가장많이점유하고있는시스템쓰레드이다. ( 여기서는 이다.) 2. dbx 명령을이용해서 1. 에서찾은시스템쓰레드의 Java Thread ID 를얻어온다. 1) % dbx a [WebLogicPID] 2) dbx 에서 thread 명령을치면 Thread ID 를 Listing 할수있다. thread state-k wchan state-u k-tid mode held scope function... $t15 wait 0xf a140 blocked k no sys _event_sleep $t16 wait 0xf a240 blocked k no sys _event_sleep $t17 run running k no sys JVM_Send $t18 wait 0xf a440 blocked k no sys _event_sleep $t19 wait running k no sys poll $t20 wait 0xf a640 blocked k no sys _event_sleep k-tid 항목에서 1 에서찾은 Thread ID 를찾고, 그 k-tid 에해당하는 thread id 를찾는다. ( 여기서는 $t17 이된다.) 3) dbx 에서 $t17 번쓰레드의 Java Thread ID 를얻는다. dbx 에서 th info 17 이라고치면 $t17 번쓰레드의정보를얻어온다. (dbx) th info 17 thread state-k wchan state-u k-tid mode held scope function $t17 run running k no sys JVM_Send general: pthread addr = 0x3ea55c68 size = 0x244 vp addr = 0x3e69e5e0 size = 0x2a8 thread errno = 2 start pc = 0x300408b0 joinable = no pthread_t = 1011 scheduler: kernel = user = 1 (other) event : event = 0x0 cancel = enabled, deferred, not pending stack storage: base = 0x3ea15000 size = 0x40000 limit = 0x3ea55c68 sp = 0x3ea55054 pthread_t 항목에서 Java Thread ID 를얻는다. 여기서는 1011 이된다.
18 3. Java Thread Dump 에서 2 에서얻어온 Java Thread ID 를이용해서해당 Java Thread 를찾아서 Java Stack 을보고 CPU 를많이사용하는원인을찾아낸다. 1) kill 3 [WebLogicPID] 2) Thread dump 를보면 native ID 라는항목이있는데, 2. 에서찾은 Java Thread ID 와이항목이일치하는 Execute Thread 를찾으면된다. "ExecuteThread: '11' for queue: 'default'" (TID:0x31cf86d8, sys_thread_t:0x3e5ea108, state:r, native ID:0x1011) prio=5 at java.net.socketoutputstream.socketwrite(native Method) at java.net.socketoutputstream.write(socketoutputstream.java(compiled Code)) at weblogic.servlet.internal.chunkutils.writechunktransfer(chunkutils.java(compiled Code)) at weblogic.servlet.internal.chunkutils.writechunks(chunkutils.java(compiled Code)) at weblogic.servlet.internal.chunkoutput.flush(chunkoutput.java(compiled Code)) at weblogic.servlet.internal.chunkoutput.checkforflush(chunkoutput.java(compiled Code)) at weblogic.servlet.internal.chunkoutput.write(chunkoutput.java(compiled Code)) at weblogic.servlet.internal.chunkoutput.write(chunkoutput.java(compiled Code)) at weblogic.servlet.internal.chunkoutputwrapper.write(chunkoutputwrapper.java(compiled Code)) at weblogic.servlet.internal.chunkwriter.write(chunkwriter.java(compiled Code)) at java.io.writer.write(writer.java(compiled Code)) at java.io.printwriter.write(printwriter.java(compiled Code)) at java.io.printwriter.write(printwriter.java(compiled Code)) at java.io.printwriter.print(printwriter.java(compiled Code)) at java.io.printwriter.println(printwriter.java(compiled Code)) at examples.servlets.helloworldservlet.service(helloworldservlet.java(compiled Code)) at javax.servlet.http.httpservlet.service(httpservlet.java:853) at weblogic.servlet.internal.servletstubimpl$servletinvocationaction.run(servletstubimpl.java: 1058) at weblogic.servlet.internal.servletstubimpl.invokeservlet(servletstubimpl.java:401) at weblogic.servlet.internal.servletstubimpl.invokeservlet(servletstubimpl.java:306) at weblogic.servlet.internal.webappservletcontext$servletinvocationaction.run(webappservle tcontext.java:5445) at weblogic.security.service.securityservicemanager.runas(securityservicemanager.java(comp iled Code)) at weblogic.servlet.internal.webappservletcontext.invokeservlet(webappservletcontext.java: 3105) at weblogic.servlet.internal.servletrequestimpl.execute(servletrequestimpl.java:2588) at weblogic.kernel.executethread.execute(executethread.java(compiled Code)) at weblogic.kernel.executethread.run(executethread.java:189) HP Unix 에서 CPU 사용률이높은 Thread 검출해내기 1 먼저 JVM 이 Hotspot mode 로작동하고있어야한다. (classic 모드가아니어야한다.) 옵션을주지않았으면 Hotspot 모드가 default 이다.
19 2. glance 를실행해서 G 를누르고 WAS 의 PID 를입력한다. 각 Thread 의 CPU 사용률이실시간으로모니터링이되는데. 여기서 CPU 사용률이높은 Thread 의 TID 를구한다. 3. kill 3 을이용해서 Thread dump 를추출해서. 2 에서구한 TID 와 Thread Dump 상의 lwp_id 가일치하는 Thread 를찾으면된다. 지금까지 Thread Dump 를이용하는방법을간단하게살펴보았다. 이방법을이용하면 WAS 와그위에서작동하는 Appllication 의 Slow down 이나 hangup 의원인을대부분분석해낼수있으나, Thread Dump 는어디까지나분석을위한단순한정보이다 Thread Dump 의내용이 Slow down 이나 hang up 의원인이될수도있으나, 반대로다른원인이존재하여그결과로 Thread Dump 와같은 Stack 이나올수있기때문에, 여러원인을동시에살펴보면서분석할수있는능력이필요하다. 3. Slow down in JVM WAS 의성능에큰영향을주는것중의하나가 JVM 이다.
20 JVM 의튜닝여부에따라서 WAS 상에서작동하는 Ap 의성능을크게는 20~30% 까지향상시킬수있는데, 우리가지금살펴보고있는 slow down 과 hangup 을일으키는직접적인요인이되는것은 JVM 의 Full GC 이다. 간단하게 JVM 의메모리구조를검토하고넘어가보도록하자. < 그림 4-1. JVM 의메모리구조 > JVM 은크게 New 영역과 Old 영역, 그리고 Perm 영역 3 가지로분류가된다. Perm 영역은 Class 나 Method 들이로딩되는영역이고성능상의영향을거의미치지않는다. 우리가주목해야할부분은객체의생성과저장에관련되는 New 와 Old 영역인데, 모든객체는생성이되자마자 New 영역에저장되고, 시간이지남에따라이객체들은 Old 영역으로이동이된다. New 영역을 Clear 하는과정을 Minor GC 라하고, Old 영역을 Clear 하는과정은 Major GC 또는 Full GC 라하는데, 성능상의문제는이 Full 영역에서발생한다. Minor GC 의경우는 1 초이내에아주고속으로이뤄지는작업이기때문에, 신경을쓸필요가없지만, Full GC 의경우에는시간이매우오래걸린다. 또한 Full GC 가발생할동안은 Application 이순간적으로멈춰버리기때문에시스템이순간적으로 Hangup 으로보이거나또는 Full GC 가끝나면서갑자기 request 가몰려버리는현상때문에종종 System 의장애를발생시키는경우가있다. Full GC 는통상 1 회에 3~5 초정도가적절하고, 보통하루에 JVM Instance 당 5 회이내가적절하다고여겨진다. ( 절대값은없다.)
21 Full GC 가자주일어나는것이문제가될경우에는 JVM 의 Heap 영역을늘려주면천천히일어나지만반대로 Full GC 에소요되는시간이증가한다. 개당 Full GC 시간이오래걸릴경우에는 JVM 의 Heap 영역을줄여주면빨리 Full GC 가끝나지만반대로 Full GC 가자주일어난다는단점이있다. 그래서이부분에대한적절한 Tuning 이필요하다. 대부분의 Full GC 로인한문제는 JVM 자체나 WAS 의문제이기보다는그위에서구성된 Application 이잘못구성되어메모리를과도하게사용하거나오래점유하는경우가있다. 예를들어대용량 DBMS Query 의결과를 WAS 상의메모리에보관하거나, 또는 Session 에대량의데이타를넣는것들이대표적인예가될수가있다. 좀더자세한튜닝방법에대해서는 ure0401_1&table=j2ee&id=1 를참고하기바란다. 4. Slow down analysis in DBMS Application 이느려지는원인중의많은부분을차지하고있는것은 DBMS 의성능문제가있는경우가많다. 흔히들 DBMS Tuning 을받았더니성능이많이향상되었다고하는경우가많은데, 그건그만큼 DB 설계를제대로하지못했다는이야기가된다. DBMS 자체 Tuning 에대한것은이문서와는논외기때문에제외하기로하고, DBMS 에전송되는각각의 SQL 문장의실행시간을 Trace 할수있는것만으로도많은성능향상을기대할수있는데, 간단하게 SQL 문장을실행시간은아래방법들을이용해서 Trace 할수있다 &start=0&postdays=0&postorder=asc&vote=viewresult &id=5&searchBy=subject&searchKey=sql&block=0&page=0 5. Slow down analysis in Webserver & network
22 WAS 와 DBMS 앞단에는 WebServer 와 Network 이있기때문에이 Layer 에서문제가되면속도저하를가지고올수있다. 필자의경험상대부분의 slow down 이나 hangup 은이부분에서는거의일어나지않지만성능상에종종영향을주는 Factor 가있는데, WebServer 와 Client 간의 KeepAlive 특히 WebServer 의 Keep Alive 설정이그것이다. WebBrowser 와 WebServer 간에는 KeepAlive 설정을하는것이좋은데. 그이유는 WebBrowser 에서하나의 HTML 페이지를로딩하기위해서는 Image 와 CSS 등의여러파일등을로딩하는데, KeepAlive 설정이없으면각각의파일을로딩하는것에각각의 Connection 을 open,request,download,close 를한다. 잘들알고있겠지만 Socket 을 open 하고 close 하는데에는많은자원이소요된다. 그래서한번연결해놓은 Connection 을계속이용해서 HTTP data 를주고받는설정이 KeepAlive 이다. 이 KeepAlive 설정은웹을이용한서비스제공에서많은성능변화를주기때문에특별한이유가없는한 KeepAlive 설정을유지하기바란다. 설정방법은각 WebServer 의메뉴얼을참고하기바란다. Apache2.0 의 Keep Alive 설정은 를참고하기바란다. Default 가 KeepAlive 가 On 으로되어있다. WebServer 와 WAS 간의 KeepAlive WebServer 와 WAS 간에는 WebServer 에서받은 request 를 forward 하기위해서 WebServer Side 에 WAS 와통신을하기위한 plug-in 이라는모듈을설치하게된다. 이역시 WebServer 와 Client 간의통신과의같은원리로 KeepAlive 를설정하게되는데, 이역시성능에영향을줄수있는부분이기때문에가급적이면설정하기를권장한다. WebLogic 에서 Webserver 와의 KeepAlive 설정은 을참고하기바란다. Default 는 KeepAlive 가 True 로설정되어있다
23 OS 에서 Kernel Parameter 설정 OS 의 TCP/IP Parameter 와, Thread 와 Process 등의 Kernel Parameter 설정이운영에있어서영향을미치는경우가있다. 이 Parameter 들은 Tuning 하기가쉽지않기때문에, WAS 또는 OS Vendor 에서제공하는문서를통해서 Tuning 하기바란다. WebLogic 의 OS 별설정정보은 를참고하기바란다. 6. Common mistake in developing J2EE Application 지금까지간단하게나마 J2EE Application 의병목구간을분석하는부분에대해서알아보았다. 대부분의병목은 Application 에서발생하는경우가많은데, 이런병목을유발하는 Application 에자주발생하는개발상의실수를정리해보도록하자. 1) Java Programming - sycnronized block 위에서도설명했듯이 sychronized 메소드는 lock contention 과 deadlock 등의문제를유발할수있다. 꼭필요한경우에는사용을해야하지만, 이점을고려해서 Coding 해야한다. - String 연산이미많은개발자들이알고있는내용이겠지만 String 연산특히 String 연산중 + 연산은 CPU 를매우많이소모하게되고종종 slow down 의직접적인원인이되는경우가매우많다. String 보다는가급적 StringBuffer 를사용하기바란다. - Socket & file handling Socket 이나 File Handling 은 FD (File Descriptor) 를사용하게되는데, 이는유한적인자원이기때문에사용후에반드시 close 명령을이용해서반환해야한다. 종종 close 를하지않아서, FD 가모자르게되는경우가많다. 2) Servlet/JSP Programming
24 - JSP Buffer Size Jsp 에서는 JSP 의출력내용을저장하는 buffer 사이즈를지정할수있다. <% page buffer= 12kb %> 이 buffer size 는출력내용을 buffering 했다가출력하는데, 만약에쓰고자하는내용이 Buffer size 보다클경우에는여러번에걸쳐서 socket write 가일어나기때문에 performance 에영향을줄수있으므로가능하다면 buffersize 를화면에뿌리는내용의크기를예측해서지정해주는것이바람직하다. 반대로너무큰버퍼를지정해버리면메모리가불필요하게낭비될수있기때문에이점을주의하기바란다. 참고로 jsp page buffer size 는지정해주지않는경우 default 로 8K 로지정된다. - member variable Servlet/JSP 는기본적으로 Multi Thread 로동작하기때문에, Servlet 과 JSP 내에서선언된멤버변수들은각 Thread 간에공유가된다. 그래서이변수들을 read/write 할경우에는 sychronized method 로구성해야하는데, 이 synchronized 는속도저하를유발할수있기때문에, member 변수로는 read 만하는객체를사용하는게좋다. 특히 Servlet 이나 JSP 에서 Data Base Connection 을멤버변수로선언하여 Thread 간공유하는예가있는데, 이는별로좋지않은프로그래밍방법이고, 이런형태의패턴은 Servlet 이단하나만실행되거나하는것과같은제약된조건아래에서만사용해야한다. - Out of Memory in file upload JSP 에서 File upload control 을사용하는경우가많다. 이 control 을구현하는과정에서 upload 되는파일내용을몽땅메모리에저장했다가업로드가끝나면한꺼번에 file 에 writing 하는경우가있는데, 이는큰사이즈의파일을업로드할때, 파일사이즈만큼의메모리용량을요구하기때문에, 자칫하면 Out Of Memory 에러를발생시킬수있다. File upload 는 buffer 를만들어서읽고, 파일에쓰는작업을병행하도록해야한다. 3) JDBC Programming - Connection Leak JDBC Programming 에서가장대표적으로발생되는문제가 Connection Leak 이다. Database Connection 을사용한후에 close 않아서생기는문제인데,Exception 이발생하였을때도반드시 Connection 을 close 하도록해줘야한다.
25 conn = getconnection(); try{ do something }catch(exception e){ dosomething(); } }finally{ if(stmt!=null) stmt.close(); if(conn!=null) conn.close(); } < 그림. Connection close 의올바른예 > - Out of memory in Big size query result SQL 문장을 Query 하고나오는 resultset 을사용할때, 모든 resultset 의결과를 Vector 나 hashtable 등을이용해서메모리에저장해놓는경우가있다. 이런경우에는평소에는문제가없지만, SQL Query 의결과가 10 만건이넘는것과같은대용량일때이모든데이타를메모리상에저장할려면 Out Of Memory 가나온다. Query 의결과값을처리할때는 ResultSet 을직접리턴받아서사용하는것이메모리활용면에서좀더바람직하다. - Close stmt & resultset JDBC 에서 Resultset 이나 Statement 객체는기본적으로 Connection 을 close 하게되면자동으로닫히게된다. 그러나 WAS 나 Servlet Container 의경우에는성능향상을위해서 Connection Pooling 기법을이용해서 Connection 을관리하기때문에 Connection Pooling 에서 Connection 을 close 하는것은실제로 close 하는것이아니라 Pool 에반환하는과정이기때문에해당 Connection 에연계되어사용되고있는 Statement 나 ResultSet 이닫히지않는다. Connection Pooling 에서 Statement 와 ResultSet 을사용후에닫아주지않으면 Oracle 에서 too many open cursor 와같은에러가나오게된다. (Statement 는 DB 의 Cursor 와 mapping 이된다.) 4) EJB Programming - When we use EJB? EJB 는분명강력하고유용한개발기술임에는틀림이없다. 그러나 EJB 의장점과용도를모르고사용하면오히려안쓰는것만못한경우가많다. 각 EJB 모델 (Session Bean,Entity Bean) 이어떤때유용한지를알고사용하고, 정확한 Transaction Model 등을결정해서사용해야한다. - Reduce JNDI look up
26 위에서도설명했듯이 EJB 의 Home Interface 를 lookup 해오는과정은객체의 Serialization/DeSerialization 을동반하기때문에, 시스템성능에영향을줄수있다. EJB Home 을한번 look up 한후에는 Hashtable 등에저장해서반복해서 Remote Call(Serialization / DeSerialization) 하는것을줄이는게좋다. - Do not use hot deploy in production mode WAS Vendor 마다 WAS 운영중에 EJB 를 Deploy 할수있는 HotDeploy 기능을제공한다. 그러나이는 J2ee spec 에있는구현이아니라각 vendor 마다개발의편의성을위해서제공하는기능이다. 운영중에 EJB 를내렸다올리는것은위험하다. (Transaction 이수행중이기때문에 ) Hot Deploy 기능은개발중에만사용하도록하자. 5) JVM Memory tuning - Basic Tuning Application 을개발해놓고, 운영환경으로 staging 할때별도의 JVM 튜닝을하지않는경우가많다. 튜닝이아니더라도최소한의메모리사이즈와 HotSpot VM 모델 (server/client) 는설정해줘야지어느정도의 Application 의성능을보장받을수있다. 최소한메모리사이즈와 VM 모델정도는설정을해주고운영을하도록하자. 6. 결론 J2EE Application 의병목구간을확인하기위해서는그문제를발견하고툴과경험을이용해서문제의원인을발견하고제거해야한다. 대부분의 WAS 또는 User Application 의 slow down 이나 hang up 은 Thread dump 를통한분석을통해서대부분발견및해결을할수있다. 그외에부분 JVM 이나 WebServer,Network 등에대해서는별도의경험과 Log 분석등을알아내야하고 DB 에의한 slow down 이나 hang up 현상은 DB 자체의분석이필요하다.
untitled
Memory leak Resource 力 金 3-tier 見 Out of Memory( 不 ) Memory leak( 漏 ) 狀 Application Server Crash 理 Server 狀 Crash 類 JVM 說 例 行說 說 Memory leak Resource Out of Memory Memory leak Out of Memory 不論 Java heap
More information<C0CCBCBCBFB52DC1A4B4EBBFF82DBCAEBBE7B3EDB9AE2D313939392D382E687770>
i ii iii iv v vi 1 2 3 4 가상대학 시스템의 국내외 현황 조사 가상대학 플랫폼 개발 이상적인 가상대학시스템의 미래상 제안 5 웹-기반 가상대학 시스템 전통적인 교수 방법 시간/공간 제약을 극복한 학습동기 부여 교수의 일방적인 내용전달 교수와 학생간의 상호작용 동료 학생들 간의 상호작용 가상대학 운영 공지사항,강의록 자료실, 메모 질의응답,
More informationJVM 메모리구조
조명이정도면괜찮조! 주제 JVM 메모리구조 설미라자료조사, 자료작성, PPT 작성, 보고서작성. 발표. 조장. 최지성자료조사, 자료작성, PPT 작성, 보고서작성. 발표. 조원 이용열자료조사, 자료작성, PPT 작성, 보고서작성. 이윤경 자료조사, 자료작성, PPT작성, 보고서작성. 이수은 자료조사, 자료작성, PPT작성, 보고서작성. 발표일 2013. 05.
More information6주차.key
6, Process concept A program in execution Program code PCB (process control block) Program counter, registers, etc. Stack Heap Data section => global variable Process in memory Process state New Running
More informationPowerPoint 프레젠테이션
Reasons for Poor Performance Programs 60% Design 20% System 2.5% Database 17.5% Source: ORACLE Performance Tuning 1 SMS TOOL DBA Monitoring TOOL Administration TOOL Performance Insight Backup SQL TUNING
More informationNo Slide Title
J2EE J2EE(Java 2 Enterprise Edition) (Web Services) :,, SOAP: Simple Object Access Protocol WSDL: Web Service Description Language UDDI: Universal Discovery, Description & Integration 4. (XML Protocol
More informationIntro to Servlet, EJB, JSP, WS
! Introduction to J2EE (2) - EJB, Web Services J2EE iseminar.. 1544-3355 ( ) iseminar Chat. 1 Who Are We? Business Solutions Consultant Oracle Application Server 10g Business Solutions Consultant Oracle10g
More information[Brochure] KOR_TunA
LG CNS LG CNS APM (TunA) LG CNS APM (TunA) 어플리케이션의 성능 개선을 위한 직관적이고 심플한 APM 솔루션 APM 이란? Application Performance Management 란? 사용자 관점 그리고 비즈니스 관점에서 실제 서비스되고 있는 어플리케이션의 성능 관리 체계입니다. 이를 위해서는 신속한 장애 지점 파악 /
More informationPCServerMgmt7
Web Windows NT/2000 Server DP&NM Lab 1 Contents 2 Windows NT Service Provider Management Application Web UI 3 . PC,, Client/Server Network 4 (1),,, PC Mainframe PC Backbone Server TCP/IP DCS PLC Network
More informationInterstage4 설치가이드
Interstage Application Server V501 Operation Guide Internet 1 1 1 FJApache FJApache (WWW (WWW server) server) - - file file - - 2 2 InfoProviderPro InfoProviderPro (WWW (WWW server) server) - - file file
More informationChap7.PDF
Chapter 7 The SUN Intranet Data Warehouse: Architecture and Tools All rights reserved 1 Intranet Data Warehouse : Distributed Networking Computing Peer-to-peer Peer-to-peer:,. C/S Microsoft ActiveX DCOM(Distributed
More information제11장 프로세스와 쓰레드
제9장자바쓰레드 9.1 Thread 기초 (1/5) 프로그램 명령어들의연속 (a sequence of instruction) 프로세스 / Thread 실행중인프로그램 (program in execution) 프로세스생성과실행을위한함수들 자바 Thread 2 9.1 Thread 기초 (2/5) 프로세스단위작업의문제점 프로세스생성시오버헤드 컨텍스트스위치오버헤드
More informationJ2EE Concepts
! Introduction to J2EE (1) - J2EE Servlet/JSP/JDBC iseminar.. 1544-3355 ( ) iseminar Chat. 1 Who Are We? Business Solutions Consultant Oracle Application Server 10g Business Solutions Consultant Oracle10g
More information목차 BUG offline replicator 에서유효하지않은로그를읽을경우비정상종료할수있다... 3 BUG 각 partition 이서로다른 tablespace 를가지고, column type 이 CLOB 이며, 해당 table 을 truncate
ALTIBASE HDB 6.1.1.5.6 Patch Notes 목차 BUG-39240 offline replicator 에서유효하지않은로그를읽을경우비정상종료할수있다... 3 BUG-41443 각 partition 이서로다른 tablespace 를가지고, column type 이 CLOB 이며, 해당 table 을 truncate 한뒤, hash partition
More informationPowerPoint 프레젠테이션
Synergy EDMS www.comtrue.com opyright 2001 ComTrue Technologies. All right reserved. - 1 opyright 2001 ComTrue Technologies. All right reserved. - 2 opyright 2001 ComTrue Technologies. All right reserved.
More informationC# Programming Guide - Types
C# Programming Guide - Types 최도경 lifeisforu@wemade.com 이문서는 MSDN 의 Types 를요약하고보충한것입니다. http://msdn.microsoft.com/enus/library/ms173104(v=vs.100).aspx Types, Variables, and Values C# 은 type 에민감한언어이다. 모든
More informationNoSQL
MongoDB Daum Communications NoSQL Using Java Java VM, GC Low Scalability Using C Write speed Auto Sharding High Scalability Using Erlang Read/Update MapReduce R/U MR Cassandra Good Very Good MongoDB Good
More informationConnection 8 22 UniSQLConnection / / 9 3 UniSQL OID SET
135-080 679-4 13 02-3430-1200 1 2 11 2 12 2 2 8 21 Connection 8 22 UniSQLConnection 8 23 8 24 / / 9 3 UniSQL 11 31 OID 11 311 11 312 14 313 16 314 17 32 SET 19 321 20 322 23 323 24 33 GLO 26 331 GLO 26
More informationThe Self-Managing Database : Automatic Health Monitoring and Alerting
The Self-Managing Database : Automatic Health Monitoring and Alerting Agenda Oracle 10g Enterpirse Manager Oracle 10g 3 rd Party PL/SQL API Summary (Self-Managing Database) ? 6% 6% 12% 55% 6% Source: IOUG
More informationJ2EE & Web Services iSeminar
9iAS :, 2002 8 21 OC4J Oracle J2EE (ECperf) JDeveloper : OLTP : Oracle : SMS (Short Message Service) Collaboration Suite Platform Email Developer Suite Portal Java BI XML Forms Reports Collaboration Suite
More information1217 WebTrafMon II
(1/28) (2/28) (10 Mbps ) Video, Audio. (3/28) 10 ~ 15 ( : telnet, ftp ),, (4/28) UDP/TCP (5/28) centralized environment packet header information analysis network traffic data, capture presentation network
More informationuntitled
3 IBM WebSphere User Conference WAS (e-mail : cjh@kr.ibm.com ) SWG WebSphere FTSS 2005. 6. 28 날로복잡해져가는 J2EE 환경에대한체계적인관리운영시스템구축을위해 WebSphere Application Server 가제공하는각종툴에대한 Guideline 필요. Request Metrics
More information교육2 ? 그림
Interstage 5 Apworks EJB Application Internet Revision History Edition Date Author Reviewed by Remarks 1 2002/10/11 2 2003/05/19 3 2003/06/18 EJB 4 2003/09/25 Apworks5.1 [ Stateless Session Bean ] ApworksJava,
More informationMicrosoft PowerPoint - Smart CRM v4.0_TM 소개_20160320.pptx
(보험TM) 소개서 2015.12 대표전화 : 070 ) 7405 1700 팩스 : 02 ) 6012 1784 홈 페이지 : http://www.itfact.co.kr 목 차 01. Framework 02. Application 03. 회사 소개 01. Framework 1) Architecture Server Framework Client Framework
More information목 차
Oracle 9i Admim 1. Oracle RDBMS 1.1 (System Global Area:SGA) 1.1.1 (Shared Pool) 1.1.2 (Database Buffer Cache) 1.1.3 (Redo Log Buffer) 1.1.4 Java Pool Large Pool 1.2 Program Global Area (PGA) 1.3 Oracle
More informationuntitled
Push... 2 Push... 4 Push... 5 Push... 13 Push... 15 1 FORCS Co., LTD A Leader of Enterprise e-business Solution Push (Daemon ), Push Push Observer. Push., Observer. Session. Thread Thread. Observer ID.
More information1
1 1....6 1.1...6 2. Java Architecture...7 2.1 2SDK(Software Development Kit)...8 2.2 JRE(Java Runtime Environment)...9 2.3 (Java Virtual Machine, JVM)...10 2.4 JVM...11 2.5 (runtime)jvm...12 2.5.1 2.5.2
More informationORANGE FOR ORACLE V4.0 INSTALLATION GUIDE (Online Upgrade) ORANGE CONFIGURATION ADMIN O
Orange for ORACLE V4.0 Installation Guide ORANGE FOR ORACLE V4.0 INSTALLATION GUIDE...1 1....2 1.1...2 1.2...2 1.2.1...2 1.2.2 (Online Upgrade)...11 1.3 ORANGE CONFIGURATION ADMIN...12 1.3.1 Orange Configuration
More information초보자를 위한 분산 캐시 활용 전략
초보자를위한분산캐시활용전략 강대명 charsyam@naver.com 우리가꿈꾸는서비스 우리가꿈꾸는서비스 우리가꿈꾸는서비스 우리가꿈꾸는서비스 그러나현실은? 서비스에필요한것은? 서비스에필요한것은? 핵심적인기능 서비스에필요한것은? 핵심적인기능 서비스에필요한것은? 핵심적인기능 서비스에필요한것은? 적절한기능 서비스안정성 트위터에매일고래만보이면? 트위터에매일고래만보이면?
More informationInterstage5 SOAP서비스 설정 가이드
Interstage 5 Application Server ( Solaris ) SOAP Service Internet Sample Test SOAP Server Application SOAP Client Application CORBA/SOAP Server Gateway CORBA/SOAP Gateway Client INTERSTAGE SOAP Service
More informationOZ-LMS TM OZ-LMS 2008 OZ-LMS 2006 OZ-LMS Lite Best IT Serviece Provider OZNET KOREA Management Philosophy & Vision Introduction OZNETKOREA IT Mission Core Values KH IT ERP Web Solution IT SW 2000 4 3 508-2
More informationMicrosoft Word - FunctionCall
Function all Mechanism /* Simple Program */ #define get_int() IN KEYOARD #define put_int(val) LD A val \ OUT MONITOR int add_two(int a, int b) { int tmp; tmp = a+b; return tmp; } local auto variable stack
More informationPRO1_02E [읽기 전용]
Siemens AG 1999 All rights reserved File: PRO1_02E1 Information and 2 STEP 7 3 4 5 6 STEP 7 7 / 8 9 10 S7 11 IS7 12 STEP 7 13 STEP 7 14 15 : 16 : S7 17 : S7 18 : CPU 19 1 OB1 FB21 I10 I11 Q40 Siemens AG
More informationJVM Synchronization 엑셈컨설팅본부 /APM 팀김정태 1. 개요 본문서는 JAVA 의특징중하나인 Multi Thread 환경에서공유 Resource 에대한 Thread 경합과 Synchronization 에대한내용들이기술되어있다. 본문내용을통해 Java
JVM Synchronization 엑셈컨설팅본부 /APM 팀김정태 1. 개요 본문서는 JAVA 의특징중하나인 Multi Thread 환경에서공유 Resource 에대한 Thread 경합과 Synchronization 에대한내용들이기술되어있다. 본문내용을통해 Java 의동기화장치인 Monitor 에대해이해하고나아가 Java 의 Synchronization 을적절하게활용할수있는지식을제공할목적으로작성되었다.
More informationOPCTalk for Hitachi Ethernet 1 2. Path. DCOMwindow NT/2000 network server. Winsock update win95. . . 3 Excel CSV. Update Background Thread Client Command Queue Size Client Dynamic Scan Block Block
More informationMicrosoft PowerPoint - GUI _DB연동.ppt [호환 모드]
GUI 설계 6 주차 DB 연동김문정 tops@yd.ac.kr 강의순서강의전환경 JDK 설치및환경설정톰캣설치및환경설정이클립스 (JEE) 설치및환경설정 MySQL( 드라이버 ) 설치및커넥터드라이브연결 DB 생성 - 계정생성이클립스에서 DB에연결서버생성 - 프로젝트생성 DB연결테이블생성및등록 2 MySQL 설치확인 mysql - u root -p MySQL 에데이터베이스추가
More informationRemote UI Guide
Remote UI KOR Remote UI Remote UI PDF Adobe Reader/Adobe Acrobat Reader. Adobe Reader/Adobe Acrobat Reader Adobe Systems Incorporated.. Canon. Remote UI GIF Adobe Systems Incorporated Photoshop. ..........................................................
More information개요오라클과티베로에서 JDBC 를통해접속한세션을구분할수있도록 JDBC 접속시 ConnectionProperties 를통해구분자를넣어줄수있다. 하나의 Node 에다수의 WAS 가있을경우 DB 에서 Session Kill 등의동작수행시원하는 Session 을선택할수있다.
설치및환경설정 JDBC 접속세션구분 / 확인 2013. 11. 01 개요오라클과티베로에서 JDBC 를통해접속한세션을구분할수있도록 JDBC 접속시 ConnectionProperties 를통해구분자를넣어줄수있다. 하나의 Node 에다수의 WAS 가있을경우 DB 에서 Session Kill 등의동작수행시원하는 Session 을선택할수있다. 사용하기 JEUS 에서설정방법
More information슬라이드 1
Pairwise Tool & Pairwise Test NuSRS 200511305 김성규 200511306 김성훈 200614164 김효석 200611124 유성배 200518036 곡진화 2 PICT Pairwise Tool - PICT Microsoft 의 Command-line 기반의 Free Software www.pairwise.org 에서다운로드후설치
More informationCD-RW_Advanced.PDF
HP CD-Writer Program User Guide - - Ver. 2.0 HP CD-RW Adaptec Easy CD Creator Copier, Direct CD. HP CD-RW,. Easy CD Creator 3.5C, Direct CD 3.0., HP. HP CD-RW TEAM ( 02-3270-0803 ) < > 1. CD...3 CD...5
More informationPowerPoint 프레젠테이션
1 2 3 4 5 6-2- - - - - - -3- -4- ( Knowledge Cube, Inc. ) // www.kcube.co.kr -5- -6- (KM)? - Knowledge Cube, Inc. - - Peter Drucker - -7- KM Context KM Context KM Context KM Context KM Context KM KM KM
More informationMicrosoft PowerPoint Android-SDK설치.HelloAndroid(1.0h).pptx
To be an Android Expert 문양세강원대학교 IT 대학컴퓨터학부 Eclipse (IDE) JDK Android SDK with ADT IDE: Integrated Development Environment JDK: Java Development Kit (Java SDK) ADT: Android Development Tools 2 JDK 설치 Eclipse
More informationCorporate PPT Template
Tech Sales Consultant Oracle Corporation What s New in Oracle9iAS Forms? Why upgrade Oracle Forms to the WEB? Agenda Oracle9i Forms Web Oracle9i Forms Oracle9i Forms Oracle9i Forms What s NEW in Oracle
More informationFMX M JPG 15MB 320x240 30fps, 160Kbps 11MB View operation,, seek seek Random Access Average Read Sequential Read 12 FMX () 2
FMX FMX 20062 () wwwexellencom sales@exellencom () 1 FMX 1 11 5M JPG 15MB 320x240 30fps, 160Kbps 11MB View operation,, seek seek Random Access Average Read Sequential Read 12 FMX () 2 FMX FMX D E (one
More information10.ppt
: SQL. SQL Plus. JDBC. SQL >> SQL create table : CREATE TABLE ( ( ), ( ),.. ) SQL >> SQL create table : id username dept birth email id username dept birth email CREATE TABLE member ( id NUMBER NOT NULL
More informationAPI 매뉴얼
PCI-DIO12 API Programming (Rev 1.0) Windows, Windows2000, Windows NT and Windows XP are trademarks of Microsoft. We acknowledge that the trademarks or service names of all other organizations mentioned
More information슬라이드 1
2015( 제 8 회 ) 한국소프트웨어아키텍트대회 OSS 성능모니터링을위한 Open Source SW 2015. 07. 16 LG CNS 김성조 Tomcat & MariaDB 성능모니터링 Passion Open Source Software Open Hadoop IT Service Share Communication Enterprise Source Access
More informationMicrosoft PowerPoint - chap02-C프로그램시작하기.pptx
#include int main(void) { int num; printf( Please enter an integer "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; } 1 학습목표 을 작성하면서 C 프로그램의
More information단계
TIBERO-WAS 연동 Guide 본문서에서는 Tibero RDBMS 에서제공하는 JDBC 통한 JEUS, WEBLOGIC 등다양한 WAS (Web Application Server) 제품과의연동방법을알아본다. Contents 1. Connection Pool 방식... 2 2. JEUS 연동... 3 2.1. JEUSMain.xml 설정 (Thin 방식
More informationIntra_DW_Ch4.PDF
The Intranet Data Warehouse Richard Tanler Ch4 : Online Analytic Processing: From Data To Information 2000. 4. 14 All rights reserved OLAP OLAP OLAP OLAP OLAP OLAP is a label, rather than a technology
More informationPowerPoint Presentation
Class - Property Jo, Heeseung 목차 section 1 클래스의일반구조 section 2 클래스선언 section 3 객체의생성 section 4 멤버변수 4-1 객체변수 4-2 클래스변수 4-3 종단 (final) 변수 4-4 멤버변수접근방법 section 5 멤버변수접근한정자 5-1 public 5-2 private 5-3 한정자없음
More informationOracle9i Real Application Clusters
Senior Sales Consultant Oracle Corporation Oracle9i Real Application Clusters Agenda? ? (interconnect) (clusterware) Oracle9i Real Application Clusters computing is a breakthrough technology. The ability
More informationSlide 1
J2EE 어플리케이션문제해결방법론 차의중 IBM Korea WebSphere Field Technical Sales Support ejcha@kr.ibm.com 선결조건 문제해결에임하는자세 3 침착하라 -심호흡 -Operating은천천히, 또박또박 혼자해결하려하지마라 -물어보라 -찾아보라 -확인하라 필요한최소한의인원만을곁에두어라 -파트별엔지니어, 어플리케이션개발자
More informationuntitled
Embedded System Lab. II Embedded System Lab. II 2 RTOS Hard Real-Time vs Soft Real-Time RTOS Real-Time, Real-Time RTOS General purpose system OS H/W RTOS H/W task Hard Real-Time Real-Time System, Hard
More information最即時的Sybase ASE Server資料庫診斷工具
TOAD 9.5 Toad Oracle 料 SQL 料 行 理 SQLprofile Quest Software 了 Oracle -Toad Tools of Oracle Application Developers Toad 了 DBA DBA 理 易 度 Toad 料 SQL PL/SQL Toad Oracle PL/SQL Toad Schema Browser Schema Browser
More information동기화에의한 Thread Deadlock 엑셈컨설팅본부 /APM 지원팀한승민 개요 Java 객체나 method 의동시성제어를위한동기화기법을잘못사용하였을때나타나는 Thread 간의 Deadlock 으로인한 Transaction 지연상황에대하여살펴보도록하자. 멀티쓰레드환경
동기화에의한 Thread Deadlock 엑셈컨설팅본부 /APM 지원팀한승민 개요 Java 객체나 method 의동시성제어를위한동기화기법을잘못사용하였을때나타나는 Thread 간의 Deadlock 으로인한 Transaction 지연상황에대하여살펴보도록하자. 멀티쓰레드환경에서공유객체의연산을수행하는블럭에 synchronized 를사용하는경우해당객체의 read, write
More informationPoison null byte Excuse the ads! We need some help to keep our site up. List 1 Conditions 2 Exploit plan 2.1 chunksize(p)!= prev_size (next_chunk(p) 3
Poison null byte Excuse the ads! We need some help to keep our site up. List 1 Conditions 2 Exploit plan 2.1 chunksize(p)!= prev_size (next_chunk(p) 3 Example 3.1 Files 3.2 Source code 3.3 Exploit flow
More informationBusiness Agility () Dynamic ebusiness, RTE (Real-Time Enterprise) IT Web Services c c WE-SDS (Web Services Enabled SDS) SDS SDS Service-riented Architecture Web Services ( ) ( ) ( ) / c IT / Service- Service-
More information<49534F20323030303020C0CEC1F520BBE7C8C4BDC9BBE720C4C1BCB3C6C320B9D7204954534D20BDC3BDBAC5DB20B0EDB5B5C8AD20C1A6BEC8BFE4C3BBBCAD2E687770>
ISO 20000 인증 사후심사 컨설팅 및 ITSM 시스템 고도화를 위한 제 안 요 청 서 2008. 6. 한 국 학 술 진 흥 재 단 이 자료는 한국학술진흥재단 제안서 작성이외의 목적으로 복제, 전달 및 사용을 금함 목 차 Ⅰ. 사업개요 1 1. 사업명 1 2. 추진배경 1 3. 목적 1 4. 사업내용 2 5. 기대효과 2 Ⅱ. 사업추진계획 4 1. 추진체계
More information<4D F736F F F696E74202D20B8B6C0CCC5A9B7CEC7C1B7CEBCBCBCAD202839C1D6C2F7207E203135C1D6C2F >
10주차 문자 LCD 의인터페이스회로및구동함수 Next-Generation Networks Lab. 5. 16x2 CLCD 모듈 (HY-1602H-803) 그림 11-18 19 핀설명표 11-11 번호 분류 핀이름 레벨 (V) 기능 1 V SS or GND 0 GND 전원 2 V Power DD or V CC +5 CLCD 구동전원 3 V 0 - CLCD 명암조절
More informationiii. Design Tab 을 Click 하여 WindowBuilder 가자동으로생성한 GUI 프로그래밍환경을확인한다.
Eclipse 개발환경에서 WindowBuilder 를이용한 Java 프로그램개발 이예는 Java 프로그램의기초를이해하고있는사람을대상으로 Embedded Microcomputer 를이용한제어시스템을 PC 에서 Serial 통신으로제어 (Graphical User Interface (GUI) 환경에서 ) 하는프로그램개발예를설명한다. WindowBuilder:
More information(72) 발명자 이동희 서울 동작구 여의대방로44길 10, 101동 802호 (대 방동, 대림아파트) 노삼혁 서울 중구 정동길 21-31, B동 404호 (정동, 정동상 림원) 이 발명을 지원한 국가연구개발사업 과제고유번호 2010-0025282 부처명 교육과학기술부
(19) 대한민국특허청(KR) (12) 등록특허공보(B1) (45) 공고일자 2015년01월13일 (11) 등록번호 10-1480424 (24) 등록일자 2015년01월02일 (51) 국제특허분류(Int. Cl.) G06F 12/00 (2006.01) G11C 16/00 (2006.01) (21) 출원번호 10-2013-0023977 (22) 출원일자 2013년03월06일
More informationJavaGeneralProgramming.PDF
, Java General Programming from Yongwoo s Park 1 , Java General Programming from Yongwoo s Park 2 , Java General Programming from Yongwoo s Park 3 < 1> (Java) ( 95/98/NT,, ) API , Java General Programming
More informationMicrosoft Word - ntasFrameBuilderInstallGuide2.5.doc
NTAS and FRAME BUILDER Install Guide NTAS and FRAME BUILDER Version 2.5 Copyright 2003 Ari System, Inc. All Rights reserved. NTAS and FRAME BUILDER are trademarks or registered trademarks of Ari System,
More informationAPI STORE 키발급및 API 사용가이드 Document Information 문서명 : API STORE 언어별 Client 사용가이드작성자 : 작성일 : 업무영역 : 버전 : 1 st Draft. 서브시스템 : 문서번호 : 단계 : Docum
API STORE 키발급및 API 사용가이드 Document Information 문서명 : API STORE 언어별 Client 사용가이드작성자 : 작성일 : 2012.11.23 업무영역 : 버전 : 1 st Draft. 서브시스템 : 문서번호 : 단계 : Document Distribution Copy Number Name(Role, Title) Date
More informationApplication 에서 Parameter 값을받아 JDBC Interface 로보내게되면적절한 JDBC Driver 를통해 SQL 을 Database 로보내주게되고결과를받아서사용자에게보여주게된다. 2-2 JDBC Interface JDBC 의핵심 Interface
All about JDBC Performance Tuning 엑셈컨설팅본부 /APM 팀임대호 1 개요 JDBC 란 Java Database Connectivity 의약어이며, 데이터베이스표준접근 API(Application Programing Interface) 를말한다. JDBC 를사용하면어떤관계형데이터베이스에서도, 각데이터베이스에맞는접근프로그램을따로생성할필요없이사용할수있다.
More informationuntitled
3 IBM WebSphere User Conference ESB (e-mail : ljm@kr.ibm.com) Infrastructure Solution, IGS 2005. 9.13 ESB 를통한어플리케이션통합구축 2 IT 40%. IT,,.,, (Real Time Enterprise), End to End Access Processes bounded by
More informationMicrosoft Word - s.doc
오라클 백서 2010년 9월 WebLogic Suite를 위해 최적화된 오라클 솔루션 비즈니스 백서 개요...1 들어가는 글...2 통합 웹 서비스 솔루션을 통해 비즈니스 혁신 추구...3 단순화...4 기민한 환경 구축...5 탁월한 성능 경험...6 판도를 바꾸고 있는 플래시 기술...6 오라클 시스템은 세계 최고의 성능 제공...6 절감 효과 극대화...8
More informationPowerPoint 프레젠테이션
Verilog: Finite State Machines CSED311 Lab03 Joonsung Kim, joonsung90@postech.ac.kr Finite State Machines Digital system design 시간에배운것과같습니다. Moore / Mealy machines Verilog 를이용해서어떻게구현할까? 2 Finite State
More informationJerry Held
DB / TSC Oracle Database 10g (Self-Managing Database) (Common Infrastructure) (Automatic Workload Repository) (Server-generated Alerts) (Automated Maintenance Tasks) (Advisory Framework) (ADDM) (Self-Managing
More informationVoice Portal using Oracle 9i AS Wireless
Voice Portal Platform using Oracle9iAS Wireless 20020829 Oracle Technology Day 1 Contents Introduction Voice Portal Voice Web Voice XML Voice Portal Platform using Oracle9iAS Wireless Voice Portal Video
More informationuntitled
(shared) (integrated) (stored) (operational) (data) : (DBMS) :, (database) :DBMS File & Database - : - : ( : ) - : - : - :, - DB - - -DBMScatalog meta-data -DBMS -DBMS - -DBMS concurrency control E-R,
More informationMicrosoft PowerPoint - Tech-iSeminar_9iAS_OAS10g_PBT.ppt
Oracle 9iAS, OracleAS 10g 일반튜닝및문제해결 Getting the most out of MetaLink 오치영 한국오라클 ( 주 ) 제품지원실 목차 Performance Tuning 전고려사항 Performance Tuning Parameter 자주발견되는문제들 많은고객분들이 Oracle 9iAS 나 OAS 10g 를포함한각종 J2EE container
More information62
2 instance database physical storage 2 1 62 63 tablespace datafiles 2 2 64 1 2 logical view control files datafiles redo log files 65 2 3 9i OMF Oracle Managed Files, OMF 9i 9i / / OMF 9i 66 8 1MB 8 10MB
More information김기남_ATDC2016_160620_[키노트].key
metatron Enterprise Big Data SKT Metatron/Big Data Big Data Big Data... metatron Ready to Enterprise Big Data Big Data Big Data Big Data?? Data Raw. CRM SCM MES TCO Data & Store & Processing Computational
More information목차 BUG DEQUEUE 의 WAIT TIME 이 1 초미만인경우, 설정한시간만큼대기하지않는문제가있습니다... 3 BUG [qp-select-pvo] group by 표현식에있는컬럼을참조하는집합연산이존재하지않으면결괏값오류가발생할수있습니다... 4
ALTIBASE HDB 6.5.1.5.10 Patch Notes 목차 BUG-46183 DEQUEUE 의 WAIT TIME 이 1 초미만인경우, 설정한시간만큼대기하지않는문제가있습니다... 3 BUG-46249 [qp-select-pvo] group by 표현식에있는컬럼을참조하는집합연산이존재하지않으면결괏값오류가발생할수있습니다... 4 BUG-46266 [sm]
More informationKYO_SCCD.PDF
1. Servlets. 5 1 Servlet Model. 5 1.1 Http Method : HttpServlet abstract class. 5 1.2 Http Method. 5 1.3 Parameter, Header. 5 1.4 Response 6 1.5 Redirect 6 1.6 Three Web Scopes : Request, Session, Context
More information@ p a g e c o n te n tt y p e = " te x t/ h tm l;c h a rs e t= u tf- 8 " fo r (in t i= 0 ; i< = 1 0 ; i+ + ) { o u t.p rin tln (" H e llo W o rld " + i + " < b r/> " ); = re s u lt + re s u lts u m ()
More informationSMB_ICMP_UDP(huichang).PDF
SMB(Server Message Block) UDP(User Datagram Protocol) ICMP(Internet Control Message Protocol) SMB (Server Message Block) SMB? : Microsoft IBM, Intel,. Unix NFS. SMB client/server. Client server request
More informationOracle Database 10g: Self-Managing Database DB TSC
Oracle Database 10g: Self-Managing Database DB TSC Agenda Overview System Resource Application & SQL Storage Space Backup & Recovery ½ Cost ? 6% 12 % 6% 6% 55% : IOUG 2001 DBA Survey ? 6% & 12 % 6% 6%
More information<4D F736F F F696E74202D203137C0E55FBFACBDC0B9AEC1A6BCD6B7E7BCC72E707074>
SIMATIC S7 Siemens AG 2004. All rights reserved. Date: 22.03.2006 File: PRO1_17E.1 차례... 2 심벌리스트... 3 Ch3 Ex2: 프로젝트생성...... 4 Ch3 Ex3: S7 프로그램삽입... 5 Ch3 Ex4: 표준라이브러리에서블록복사... 6 Ch4 Ex1: 실제구성을 PG 로업로드하고이름변경......
More information목 차 Ⅰ. 일반사항 1 Ⅱ. 특기사항 3 Ⅲ. 물품내역 및 세부규격 8 Ⅳ. 주의사항 11-2 -
대전마케팅공사 경영정보포털 구축 사업 패키지 소프트웨어 2식 구매 설치 시방서 (소프트웨어 2식) 2016. 06. 대전마케팅공사 경 영 지 원 파 트 목 차 Ⅰ. 일반사항 1 Ⅱ. 특기사항 3 Ⅲ. 물품내역 및 세부규격 8 Ⅳ. 주의사항 11-2 - Ⅰ. 일반사항 1. 목적 본 시방서는 대전마케팅공사가 추진하고 있는 경영정보포털 사업의 패키지 소프트웨어 도입을
More information다른 JSP 페이지호출 forward() 메서드 - 하나의 JSP 페이지실행이끝나고다른 JSP 페이지를호출할때사용한다. 예 ) <% RequestDispatcher dispatcher = request.getrequestdispatcher(" 실행할페이지.jsp");
다른 JSP 페이지호출 forward() 메서드 - 하나의 JSP 페이지실행이끝나고다른 JSP 페이지를호출할때사용한다. 예 ) RequestDispatcher dispatcher = request.getrequestdispatcher(" 실행할페이지.jsp"); dispatcher.forward(request, response); - 위의예에서와같이 RequestDispatcher
More information강의10
Computer Programming gdb and awk 12 th Lecture 김현철컴퓨터공학부서울대학교 순서 C Compiler and Linker 보충 Static vs Shared Libraries ( 계속 ) gdb awk Q&A Shared vs Static Libraries ( 계속 ) Advantage of Using Libraries Reduced
More information(SW3704) Gingerbread Source Build & Working Guide
(Mango-M32F4) Test Guide http://www.mangoboard.com/ http://cafe.naver.com/embeddedcrazyboys Crazy Embedded Laboratory www.mangoboard.com cafe.naver.com/embeddedcrazyboys CRZ Technology 1 Document History
More informationPowerPoint Presentation
public class SumTest { public static void main(string a1[]) { int a, b, sum; a = Integer.parseInt(a1[0]); b = Integer.parseInt(a1[1]); sum = a + b ; // 두수를더하는부분입니다 System.out.println(" 두수의합은 " + sum +
More informationPowerPoint 프레젠테이션
@ Lesson 4 (Object) (Class) (Instance) (Method) (Constructor) Memory 1 UML 1 @ & 1 (Real World) (Software World) @ &.. () () @ & 2 (Real World) (Software World) OOA/ Modeling Abstraction Instantiation
More informationISP and CodeVisionAVR C Compiler.hwp
USBISP V3.0 & P-AVRISP V1.0 with CodeVisionAVR C Compiler http://www.avrmall.com/ November 12, 2007 Copyright (c) 2003-2008 All Rights Reserved. USBISP V3.0 & P-AVRISP V1.0 with CodeVisionAVR C Compiler
More informationMicrosoft PowerPoint - polling.pptx
지현석 (binish@home.cnu.ac.kr) http://binish.or.kr Index 이슈화된키보드해킹 최근키보드해킹이슈의배경지식 Interrupt VS polling What is polling? Polling pseudo code Polling 을이용한키로거분석 방어기법연구 이슈화된키보드해킹 키보드해킹은연일상한가! 주식, 펀드투자의시기?! 최근키보드해킹이슈의배경지식
More informationUSER GUIDE
Solution Package Volume II DATABASE MIGRATION 2010. 1. 9. U.Tu System 1 U.Tu System SeeMAGMA SYSTEM 차 례 1. INPUT & OUTPUT DATABASE LAYOUT...2 2. IPO 중 VB DATA DEFINE 자동작성...4 3. DATABASE UNLOAD...6 4.
More information02 C h a p t e r Java
02 C h a p t e r Java Bioinformatics in J a va,, 2 1,,,, C++, Python, (Java),,, (http://wwwbiojavaorg),, 13, 3D GUI,,, (Java programming language) (Sun Microsystems) 1995 1990 (green project) TV 22 CHAPTER
More informationInterstage
Interstage Basic Web Application Development Servlet/JSP Interstage Web -Servlet/JSP >> 1)Servlet EJB (Web-Application) 2) Interstage Apworks 3), 4) >> 1) / Web /PM >> 1) Web Application 2)Interstage >>
More informationPRO1_04E [읽기 전용]
Siemens AG 1999 All rights reserved File: PRO1_04E1 Information and S7-300 2 S7-400 3 EPROM / 4 5 6 HW Config 7 8 9 CPU 10 CPU : 11 CPU : 12 CPU : 13 CPU : / 14 CPU : 15 CPU : / 16 HW 17 HW PG 18 SIMATIC
More informationTHE TITLE
Android System & Launcher Team 8 목차 Android 1) Android Feature 2) Android Architecture 3) Android 개발방법 4) Android Booting Process Dalvik 1) Dalvik VM 2) Dalvik VM Instance Application 1) Application Package
More informationEclipse 와 Firefox 를이용한 Javascript 개발 발표자 : 문경대 11 년 10 월 26 일수요일
Eclipse 와 Firefox 를이용한 Javascript 개발 발표자 : 문경대 Introduce Me!!! Job Jeju National University Student Ubuntu Korean Jeju Community Owner E-Mail: ned3y2k@hanmail.net Blog: http://ned3y2k.wo.tc Facebook: http://www.facebook.com/gyeongdae
More informationMySQL-Ch10
10 Chapter.,,.,, MySQL. MySQL mysqld MySQL.,. MySQL. MySQL....,.,..,,.,. UNIX, MySQL. mysqladm mysqlgrp. MySQL 608 MySQL(2/e) Chapter 10 MySQL. 10.1 (,, ). UNIX MySQL, /usr/local/mysql/var, /usr/local/mysql/data,
More informationuntitled
A Leader of Enterprise e-business Solution FORCS Co., LTD 1 OZ Application Getting Started (ver 5.1) 2 FORCS Co., LTD A Leader of Enterprise e-business Solution FORCS Co., LTD 3 OZ Application Getting
More information歯처리.PDF
E06 (Exception) 1 (Report) : { $I- } { I/O } Assign(InFile, InputName); Reset(InFile); { $I+ } { I/O } if IOResult 0 then { }; (Exception) 2 2 (Settling State) Post OnValidate BeforePost Post Settling
More informationPowerPoint Presentation
Server I/O utilization System I/O utilization V$FILESTAT V$DATAFILE Data files Statspack Performance tools TABLESPACE FILE_NAME PHYRDS PHYBLKRD READTIM PHYWRTS PHYBLKWRT WRITETIM ------------- -----------------------
More informationuntitled
PowerBuilder 連 Microsoft SQL Server database PB10.0 PB9.0 若 Microsoft SQL Server 料 database Profile MSS 料 (Microsoft SQL Server database interface) 行了 PB10.0 了 Sybase 不 Microsoft 料 了 SQL Server 料 PB10.0
More information