달력

1

« 2025/1 »

  • 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
2008. 10. 24. 18:35

WAS 시스템 설정 기준을 제시하라 Enjoy/etc2008. 10. 24. 18:35

출처 : http://www.imaso.co.kr/?doc=bbs/gnuboard_pdf.php&bo_table=article&page=3&wr_id=913&publishdate=20030401

이상훈 | sanghoone@lgcns.com
J2EE Working Group의 간사로 활동하고 있으며, KM 활동의 일환으로 사내 K-Village SUN 전문가 포럼의 아키텍처 스터디에서 돌쇠(?) 역할을 하고 있다. 개인적으로는 프로덕트 라인 엔지니어링과 스쿠버 다이빙, 인라인 스케이팅, 스노우 보드에 관심이 많다.

다음은 K회사 WAS 관리자와 PM과의 대화내용이다.

WAS 관리자 : WAS 설정 값을 좀 변경하는 게 좋을 것 같습니다.
PM : 왜?
WAS 관리자 : 일부를 좀 바꿔보았더니 성능이 좋아지는 것 같아서요.
PM : 벤더가 왔을 때도 그냥 디폴트(Default)로 설정하라고 했잖아. 설정 바꾸지 말고 디폴트로 설정해! 문제 생기면 책임질꺼야?
WAS 관리자 : @.@

앞의 WAS 관리자와 PM의 대화가 비현실적이었으면 하지만 누구나 경험할 수 있는 안타까운 현실이다. 지난해 J2EE Working Group(이하 J2EE-WG)의 고민도 바로 ‘J2EE 기반의 WAS (Web Application Server) 설정에 대한 불명확성’이었으며, 이를 해결하고자 한 해를 보냈다.
J2EE의 주요 기술이 은행, 이동통신사업 등과 같이 대규모의 시스템에 적용되기 위해서는 시스템 성능에 대한 안정성이 필요하다. 그러나 성능 안정화 및 성능 향상을 위한 튜닝은 실제 프로젝트 팀보다 WAS 벤더에 의존적으로 수행되고 있는 경우가 많고, 개인적인 경험을 토대로 행해지기 때문에 개인의 능력에 따라 성능이 좌우되는 문제점이 제기되고 있다. 이에 J2EE-WG은 성능 안정화를 위한 시스템 성능 향상에 영향을 줄 수 있는 요소들을 선정하고, 각 요소에 대한 국내 J2EE 기반 WAS 벤더의 권고사항을 기초로 하여 성능 향상을 위한 고려사항들을 정리했다.
시스템 성능 향상을 위해서는 업무 모델링, 데이터 모델링, 네트워크, 하드웨어 등 각종 인프라스트럭처, 애플리케이션 아키텍처 등 모든 기본 요소가 업무 특성에 따라 종합적으로 고려되어야 하지만, J2EE-WG은 1차적으로 J2EE의 기반 구조를 제공해주는 ‘WAS 성능 향상을 위한 고려사항’을 제시하고자 한다(차후 기회가 되면 이런 기본 요소에 대한 부분도 다루도록 하겠다).

성능 향상을 위한 고려사항 선정
성능 향상을 위한 고려사항들은 J2EE 기반 시스템 구축 경험이 있는 J2EE-WG 회원들을 중심으로 선정되었다. 이러한 요소들은 현장에서 대부분 디폴트로 설정되고 있으며, 설정 변경보다는 시스템 용량(CPU, 메모리 등)을 늘리게 하는 주요 이슈들이다. 다음의 질문에 대한 각 벤더별 답변 내용의 주요 골자를 보며 고려되어야 할 사항들을 살펴보자(각 벤더의 답변 내용 중 오해의 소지가 있는 부분은 영문 그대로 실는다. 또한 각 벤더별 답변 원문은 ‘이달의 디스켓’을 참고하기 바란다).

짾 EJB 컨테이너 설정
짿 Deployment Descriptor 설정
쨁 패키징(packaging) 설정
쨂 트랜잭션 유형 설정
쨃 커넥션 풀링(connection pooling) 설정
쨄 기타 성능 향상 요소

EJB 컨테이너 설정
하나의 WAS에 여러 개의 컨테이너를 띄워서 시스템을 운영하는 경우가 많은데, 이때 각 컨테이너가 차지하는 시스템 리소스의 규모로 인해 컨테이너 설정이 전체적인 시스템 성능에 영향을 주고 있다. 컨테이너 설정을 어떻게 최적화해 운영·유지할 것인지 정확하게 입증하는 것은 중요한 이슈라고 생각된다. 컨테이너 수를 어떻게 결정하는지, 각 컨테이너는 어떻게 설정할 것인지 등에 대한 적정한 지표가 없어, 설정값이 대부분 디폴트로 설정되거나 벤더 기술 지원 인력의 주관적 경험에 의존해 결정되고 있다. 또한 업무 특성이 고려되지 않은 기술적인 접근은 실제 운영에 있어 예상치 못한 문제들을 발생시킬 수 있다. 기본 값이 아닌 다른 값으로 설정했을 때 발생될 수 있는 영향 혹은 문제점들에 대한 명확한 가이드라인의 부재로 인해, 업무 특성을 고려한 설정을 하려고 해도 어쩔 수 없이 디폴트로 운영하는 경우가 많다.

Q1. 컨테이너의 적정 개수 산정과 관련된 고려 사항

오라클 컨테이너에 있어 처리 가능한 트랜잭션 수는 시스템 리소스에 따라 많이 달라지며, 실제로는 최대로 수행 가능한 JVM 쓰레드의 수가 의미를 지닌다. 쓰레드 풀 사이즈의 설정을 통해 제어(공식적인 자료로는 ECperf 결과를 활용할 수 있다).
BEA 기본적으로 인스턴스 <= # of CPU(현재 1머신에서 8개인 인스턴스까지 사용하는 예가 있다)
IBM 케이스 1. 관련 EJB를 여러 개의 컨테이너에 분산시켜서 전개
- 성능적/비용적 측면에서 볼 때, 성능적 이점은 없이 JVM에 대한 프로세스 오버헤드만 존재할 뿐이다.
케이스 2. 모든 EJB를 하나의 컨테이너에 전개시키고 컨테이너를 복수 개로 클로닝(cloning)
- EJB 컨테니어에만 해당되는 특별한 고려사항은 없다.
- 웹 컨테이너 클러스터링시 개수 산정과 관련된 고려 사항과 같다.
썬 기본적으로 한 시스템 당 한 개의 컨테이너를 권장한다.

Q2. 복수의 컨테이너를 운용해야 할 경우 개수의 정확한 정의를 위해 제시하고 있는 권장사항

IBM 복수 개의 컨테이너 운용 목적 중에는 성능, 확장성, 신뢰성 등의 향상을 들 수 있다. 한 개의 머신에서 복수 개의 컨테이너를 운용하는 것에 대해선 대용량 시스템이어야 한다는 대전제를 필요로 한다. 특히 필요에 의한 복수의 컨테이너 운용은 업무별로 애플리케이션 서버를 분리해 운영하고자 하는 운영적인 측면에서 생각해 볼 수 있는데, 이는 그다지 바람직하지 않다(애플리케이션 서버 단위 → EAR 단위 업무 분리).

Q3. 설정항목, 설정 값의 저장위치와 항목별로 설정 값 변경시 발생할 수 있는 성능 영향

오라클 서버 설정을 위한 모든 항목은 XML 파일로 되어 있다.
server.xml : 메인 서버 설정
default-web-site.xml : 웹 서버 설정
rmi.xml : RMI 포트, 로그 등 설정
jms.xml : queues, topics, ports 등 설정
principals.xml : 사용자 및 역할 등 설정
data-sources.xml : DB 접근 제어 등 설정
global-web-application.xml : global Web applications 설정
application.xml : default application을 위한 설정
IBM 관리 콘솔을 통해서 설정할 수 있고, 그 값은 리파지토리 DB에 저장된다.
<캐시 크기>
- 캐시할 수 있는 인스턴스 수를 지정한다.
- 총 EJB 개수 X 동시사용자 수
- 지정된 값이 너무 작을 경우 성능저하의 원인이 된다.
<캐시 정리 간격>
- 컨테이너가 캐시 크기를 초과하지 않도록 캐시에서 사용되지 않은 항목을 제거하려고 시도하는 간격
- 일반적으로 캐시 크기를 증가시킨 것 만큼 간격도 증가시켜 준다.
<워크로드 관리 방침>
- 로컬 우선 라운드 로빙 방침이 라운드 로빙보다 성능이 더 좋다. 로컬 우선이란 EJB 클라이언트에서 EJB를 요청할 때 동일한 애플리케이션 서버에 있는 EJB 컨테이너 내의 EJB를 우선적으로 요청한다는 방침이다.
썬 server.xml에 있는 ejb-container 설정항목 중 다음을 유의해야 한다.
- steady-pool-size
- max-pool-size
- pool-resize-quantity
- pool-idle-timeout-in-seconds
- max-cache-size
- Cache-idle-timeout-in-seconds
- Removal-timeout-in-seconds

Q3의 경우 많은 기대를 했던 항목이지만 명쾌한 해답을 들을 수 없어서 아쉬웠던 부분이다. 업무 및 애플리케이션의 특성이 다양하기 때문에, 벤더에서도 케이스별 모범 답안을 제시하기가 어려웠던 내용이다. 그리하여 기술 지원을 하는 개개인의 역량과 경험에 따라서 시스템 성능이 좌우되는 현실을 경험할 수밖에 없는 것이다.

Deployment Descriptor
각 벤더에서 제공되는 가이드에는 Deployment Descriptor에 설정할 수 있는 항목들과 그에 대한 설명이 있지만 각 요소들이 실제로 시스템 성능에 어떠한 영향을 주는지 알 수 없기 때문에, 현실적으로는 대부분의 요소들을 디폴트로 설정하는 경우가 많다.
또한 Deployment가 정상적으로 이루어진 것처럼 보이지만 실제로 동작이 안되는 경우가 종종 발생하고 있으며, 일단 동작이 되면 그 자체에 만족하고 있기 때문에 성능에 대한 고려를 할 수 없는 환경이 만들어지고 있는 것이다.

Q4. 상황에 따라 여러 회사의 제품들이 함께 운영될 수 있는데, 이에 대한 가이드(예 : 웹 서버(A사) + 웹 컨테이너(B사) + 웹 애플리케이션 서버(C사) + DBMS(D사))

IBM < 툴 >
- 웹스피어는 텍스트 에디터를 통한 DD 직접 편집이 가능하지만 권장하지는 않는다.
- WSAD를 사용해서 개발할 경우, 개발과 동시에 웹스피어에 최적화된 DD가 자동으로 생성된다. 별도로 DD를 편집해야 할 경우에도 GUI를 통해 구조화된 방법으로 접근하기 때문에 쉽고 빠르게 작업할 수 있고 실수를 줄일 수 있다.
- WSAD 이외의 개발 툴을 사용할 경우에는, 웹스피어에서 제공하는 AAT(Application Assembly Tool)을 사용해서 역시 GUI로 작업할 수 있다.
< 튜토리얼 >
- DD는 HTTP Svr나 DB Svr의 종류에 독립적이다.
- 웹 애플리케이션(WAR), EJB(JAR), 엔터프라이즈 애플리케이션(EAR)의 DD 설정에 대해 쉽게 따라할 수 있는 튜토리얼이 웹으로 제공된다( http://www.ibm.com/software/webservers/appserv/ doc/v40/ae/infocenter/was/0607.html).
썬 Deployment Descriptor를 작성하는 가장 쉬운 방법은 썬원 스튜디오 4 IDE 또는 Administration 인터페이스를 사용한 EJB 모듈을 디플로이하는 것이다. 업데이트된 Deployment Descriptor 정보들은 제공되는 Ad ministration 인터페이스와 기타 유틸리티를 이용해 재설정할 수 있다.

‘한 벤더에서 모든 제품을 사야지 궁합이 잘 맞을까’라는 의문은 주위에서 쉽게 들을 수 있을 것이다. 표준 스펙은 따르고 있지만, 각 제품별로 벤더 나름대로의 특성들이 있기 때문에, 여러 벤더의 제품들을 조합하고자 할 때 혹은 조합해야 하는 경우에 어떠한 문제점들이 발생할 수 있고, 또 어떻게 조합하는 것이 좋은지 알고 싶었다. 그러나 벤더별 입장의 차이와 케이스별 조합이 매우 다양하다는 이유를 들면서 깊이 있는 답변을 주지 못하였다.

Q5. 주요 설정 항목(세부사항 : 퍼포먼스에 미치는 영향, WAS 설정 항목은 벤더별로 특성이 있는데, 각 벤더별로 유념해야 할 설정 항목들을 나열해 보았다)

오라클 server.xml에서 max-http-connections 설정에 유의
global-web-application.xml에서 main-mode 설정에 유의
web.xml에서 load-on-startup 설정에 유의
orion-ejb-jar.xml에서 do-select-before-insert 설정에 유의
orion-ejb-jar.xml에서 update-changed-fields-only 설정에 유의
orion-ejb-jar.xml에서 exclusive-write-access 설정에 유의
orion-ejb-jar.xml에서 isolation & locking-mode 설정에 유의
data-sources.xml에서 max-connections 설정에 유의
BEA 설정 값이 저장되어 있는 Weblogic-ejb-jar.xml 파일에서 다음 항목들 설정에 유의
- max-beans-in-free-pool
- initial-beans-in-free-pool
- max-bean-in-cache
- concurrency-strategy
- isolation-level
IBM 다음과 같은 설정항목에 유의
ibm-web-ext.xmi
ibm-ejb-jar-ext.xmi
썬 sun-ejb-jar.xml에서 풀링/캐싱 요소에 유의한다.
- Bean 풀 설정시
steady-pool-size
max-pool-size
pool-idle-timeout-in-seconds
Pool-resize-quantity
- Bean 캐시 설정시
max-cache-size
cache-resize-quantity
cache-idle-timeout-in-seconds
Victim-selection-policy

Q6. 운영 중인 WAS 상의 애플리케이션을 업데이트된 애플리케이션으로 교체하고자 할 경우 Deployment Descriptor 작성시에 고려되어져야 할 사항(Dynamic Deployment)

오라클 Deployment descriptor를 별도로 설정하지 않아도 변경된 클래스를 해당 디렉토리에 적용하면 자동적으로 dynamic deployement를 지원한다.
BEA 애플리케이션의 패키지 묶음
IBM 애플리케이션 서버를 재시작하지 않고도 애플리케이션 추가/변경 가능
웹 모듈
- JSP : DD의 설정과 관계없이 추가/변경 가능
- 서블릿 : 웹 애플리케이션 오토 리로딩이 true인 경우 추가/변경 가능
- 서블릿에서 참조하는 클래스나 Jar : 서블릿의 경우와 동일
- web.xml : 서블릿의 경우와 동일. 단, 다음의 경우는 해당 모듈 재시작 필요



- Web.xml에서 서블릿 맵핑 추가/변경시 HTTP Plugin configuration file 재생성 필요
- ibm-web-ext.xmi : 서블릿의 경우와 동일
- ibm-web-bnd.xmi : 해당 모듈 재시작 필요
-EJB 모듈
- ejb-jar.xml, ibm-ejb-jar-ext.xmi, ibm-ejb-jar-bnd.xmi : 변경시 모듈 재시작 필요
- Table.ddl : 변경시 DB 서버에서 재수행 필요
- Map.mapxmi, Schema.dbxmi : 변경시 EJB re-deploy, 모듈 재시작 필요
- EJB가 참조하는 클래tm나 Jar : 변경시 모듈 재시작 필요
- Home/Remote Interface class : 변경시 EJB re-deploy, 모듈 재시작 필요
썬 EJB 등의 일부 모듈이 변경된 경우에는 다시 디플로이를 한다든지, 서버를 재시작해야 할 필요는 없다. 변경된 파일(모듈)을 애플리케이션이 디플로이된 디렉토리(예 : instnce-dir/applications)에 넣어놓기만 하면 자동으로 변경된 것이 반영된다. Adminsration 인터페이스를 이용해 다이내믹 리로딩을 가능하게 하려면 다음과 같다.
짾 Adminsration 인터페이스에서 서버 인스턴스를 선택한다.
짿 애플리케이션을 선택한다.
쨁 애플리케이션의 설정 페이지들이 보여질 것이다.
쨂 ‘Reload Enabled’ 박스를 선택해 다이내믹 리로딩이 가능하도록 한다.
쨃 리로드되는 주기를 초단위로 입력한다(이 시간단위로 변화 여부가 체크된다).
쨄 설정을 저장한다.

Dynamic Deployment는 벤더 모두 지원한다는 입장을 보였으며, 고려되어야 할 사항보다는 어떻게 Dynamic Deployment를 하는지 알려주는 정도의 답변이었다.

패키징 설정
J2EE 기반의 애플리케이션은 HTML, XML, 서블릿, JSP, EJB 등과 같은 요소들로 구성되어 있으며 업무별, 기능별, 혹은 기타 다양한 원칙에 따라 JAR/WAR/EAR의 형태로 패키징된다. 그러나 각종 패키지들이 모호한 원칙에 따라 다양한 형태와 크기로 등록·설치되어 사용되고 있는 실정이므로, 패키징의 기술적인 제약사항, 기본요건, WAS간 호환 문제 해결 등을 위한 관련 가이드의 필요성이 제기되었다.

Q7. 패키징 단위 설정에 대한 권고사항(업무별, 기능별, 사용빈도별, 중요도별 등)

오라클 업무 프로젝트별 패키징을 권장
BEA 상황에 따라 다름. 그러나 관리가 따로 되는 단위가 제안됨
IBM 웹 모듈의 경우 HttpSession의 공유를 고려해야 한다.
J2EE 환경에서 HttpSession의 범위는 각 웹 애플리케이션으로 제한되기 때문에, HttpSession을 공유해야 할 서블릿/JSP는 동일한 웹 모듈 안에 있어야 한다.
썬 Type of Development Group
Small workgroup
Enterprise workgroup
Teams in Group
1 web team + 1 EJB team
2 EJB teams + 1 web team + 1 component
Modularizing Scheme
1 EAR = 1 EJB + 1 WAR
1 EAR = 2 EJB + 1 WAR + 1 individual component

Q8. 패키징의 기술적 제약사항 및 기본 요건

IBM 웹 모듈의 경우 HttpSession의 공유를 고려해야 한다.
특별한 제약사항은 없다.
Common code(common/utility class or Jar)의 위치는 다음 두 가지 중에서 상황에 맞는 것으로 선택
- Common classpath에 놓는다(Runtime Sharing)
소스 관리가 용이/약간의 시스템 자원 절약
- 각각의 EAR마다 하나씩 포함시킨다
애플리케이션이 서로에 대해 독립적

Q9. 패키징 사이즈에 따른 성능에의 영향과 근거

오라클 큰 패키지 사이즈는 수행 성능에는 문제가 없지만 개발시에 긴 설치 시간 및 메모리 점유로 인한 성능적인 부담을 줄 수 있음
BEA 상관 관계에 대한 문서는 아직 없음. 메모리에 많이 올라가서 많은 프로그램을 처리하는 것은 부하가 될 수 있음
IBM JDK 1.3.X에서 효율적으로 사용할 수 있는 애플리케이션 힙 사이즈의 한계는 대략 1.2GB다. 애플리케이션이 이 힙 사이즈 안에서 과도한 가비지 컬렉션 없이도 잘 수행된다면 패키징 사이즈는 성능과 직접적인 관계가 없다. 패키징 사이즈보다는 애플리케이션의 디자인과 코딩 기법이 성능에 미치는 영향이 훨씬 크다. 웹스피어 디벨로퍼 도메인에서 성능 향상을 위한 다양한 실전 예제를 찾아 볼 수 있다(http://www7b.soft ware.ibm.com/wsdd/zones/bp/).

Q10. WAS간 호환 문제를 해결하기 위한 패키징 방안

오라클 소스에는 영향이 없음. Deployment descriptor만 플랫폼에 맞추어 설정을 변경해 주면 됨
BEA 소스는 그대로 사용하고 포팅시에 Deployment Descriptor를 재작성할 필요가 있음
IBM 기본적으로 J2EE 표준 DD만 사용해서 패키징한 애플리케이션은 WAS 벤더에 비종속적으로 디플로이할 수 있다. WAS 벤더의 확장 DD를 사용할 경우에는 타 벤더와 호환되지 않기 때문에 디플로이하기 전에 확장 DD를 편집해 주어야 한다. WAS간 호환을 위해서는 벤더 확장 DD를 사용하지 않는 방법이 최선이다.

트랜잭션 유형 설정
트랜잭션의 설정은 중요한 자원에 대한 변경 관리시에 매우 중요한 사안이며, 그 관리를 위해서는 많은 시스템 자원이 필요하게 된다. 그러나 트랜잭션 관리가 필요하지 않은 경우가 있음에도 불구하고 트랜잭션 관리 범위를 확대함으로써 시스템 자원이 불필요하게 낭비되는 결과를 초래하는 경우가 많기 때문에, 트랜잭션 관리의 원칙을 도출하는 것은 중요한 의미를 가진다. 특히, CMT(Container Managed Transaction)보다는 BMT(Bean Managed Transaction)가 더 효과적인 경우에도 개발자의 기술 의존도가 높아지기 때문에 CMT를 선호하고 있으며, 트랜잭션 옵션 설정이 시스템 성능에 미치는 영향에 대한 확신이 부족하기 때문에 Transacti on_Required와 같은 값으로 설정하는 경우가 대부분이다.

Q11. CMT vs. BMT
트랜잭션 유형의 설정은 극단적으로 얘기하면 ‘개발자에 대한 믿음’과 ‘트랜잭션 유형을 염두에 둔 개발 표준에 대한 믿음’의 정도에 따라서 결정할 수 있다. 벤더의 입장도 개발자의 실수만 아니라면 BMT로 설정하는 것이 성능향상에 도움이 된다고 생각하고 있다. 결국 표준화가 철저하게 검증되어 지켜지고 있는 경우에만 BMT로 설정해 사용하라는 권고를 하고 있다. 사실 우리는 ‘BMT로 설정하고 또 BMP(Bean Managed Persistence)로 설정한다면 EJB를 왜 사용하는가?’라는 질문을 하였지만 논리적인 답변을 받을 수는 없었다. 다만 트랜잭션 유형 결정은 개발자의 실력과 그에 대한 믿음 그리고 개발표준 등의 정도에 따라서 이루어질 수 있다는데 공감하였다.

Q12. 트랜잭션 isolation에 대한 가이드라인

오라클 isolation 및 잠금 모드(locking mode)의 설정을 지원
BEA DB에 의존적임
IBM 대부분 트랜잭션 isolation 레벨은 데이터베이스 기본 isolation 레벨인 ‘Read Committed’를 그대로 따른다. 데이터 일관성의 문제는 성능의 문제보다 더 심각하기 때문에 불확실할 경우 ‘Serializable’을 선택한다. 만약 성능이 문제가 된다면 나중에 당황하지 않도록 낮은 isolation 레벨도 견딜 수 있는 트랜잭션을 작성하도록 개발할 때 신중하게 생각해 봐야 한다.
썬 server.xml 에 있는 ‘transaction-isolation-level’은 풀링된 DB 커넥션에 대한 레벨을 나타낸다. 이 셋팅은 선택적으로 할 수 있으며 디폴트는 없다. 명시되지 않으면 JDBC 드라이버에 설정된 isolation 레벨로 설정될 것이다. 설정 값에는 read-uncommitted, read-committed, repeatable-read, serializable 등이 있다. 설정 값은 트랜잭션이 진행 중에 변경해서는 안된다. 또한 연결된 DB의 특성을 잘 파악하여야 한다. 참고로, Isolation 레벨 설정에 관한 사항들은 J2EE 플랫폼에서 표준화되지 않았다.

커넥션 풀링 설정
과거 DB 커넥션 자체에 많은 부하가 발생됐으나, 커넥션 풀링을 통해 시스템의 성능향상이 이루어졌다. 그러나 한정된 자원을 활용해 더욱더 안정적인 성능을 보장하기 위해서는 커넥션 풀링의 효율적 관리 방안이 도출되어야 한다. 커넥션 풀링 관련 가이드는 실제로 존재하지만, 설정 값 변경에 따른 시스템 성능에의 영향을 명확히 알지 못하기 때문에 자신감 있게 환경 설정을 하지 못하는 원인이 되고 있다.

Q13. 커넥션 풀링 관련 프로퍼티 설정 가이드 및 설정 근거와 성능에의 영향(min/max pool size, connection/idle/orphan ti meout, statement/preparedStatment cache size 등)

오라클 JDBC 커넥션 외에 HTTP 커넥션 등 종합적인 커넥션 리소스가 관리되어야 한다.
Data-source 최대 커넥션 수 >= (모든 JVM을 걸친) 동시 유효 쓰레드 수의 최대치
쓰레드가 무제한이거나, DB concurrency에 병목현상이 있는 경우에는 좀더 낮춰야 한다.
커넥션이 지속적으로 최대로 사용되고 있으면 wait-time을 조정해야 한다.
BEA InitialCapacity와 MaxCapacity의 개수를 동일하게 지정
- Caching Prepared Statement
- 성능 향상에 매우 도움이 됨
- 웹로직 콘솔에서 설정
- WLS가 애플리케이션이나 EJB에서 사용된 Prepared statement를 저장한다.
- 제약 사항 : 데이터베이스의 테이블이 삭제되었다가 재생성되거나, 컬럼이 추가 혹은 변경되는 경우는 에러가 날 수 있음
IBM Max : Burstness factora→0/부족하지 않으면 충분/Active 유저의 개수에 근접
Min : 첫 접속시에만 이슈
PreparedStatement cache : 빈번히 사용되는 pstmt # x Active 유저
썬 - setTransactionIsolationLevel()로 설정하기 보다는 드라이버에서 설정된 디폴트 isolation 레벨을 사용하는 것을 권장한다(idle time = 0).
- max-wait-time-in-millis = 0
- ‘Transcation-isolation-level’을 수정하는 것은 자제할 것을 권장한다.
- connection-validation-required = true로 설정할 것을 권장한다. 이는 DB 커넥션이 풀에 반환될 때마다 커넥션의 상태를 점검해준다.

Q14. 기술지원에 참여했던 안좋은 경우와 솔루션

IBM 상대적으로 최대 값을 100, 300, 500, 1000 등 불필요하게 높게 책정하는 경향이 있음. 권장사항은 Active 유저의 개수 근방에서 조정

기타 성능 향상을 위한 고려 사항
Q15. WAS 제품의 각 O/S별 최적 운용을 위한 파라미터 설정 가이드라인

오라클 네트워크(TCP) 파라미터 설정
tcp_conn_hash_size 32768
tcp_conn_req_max_q 1024
tcp_conn_ req_max_q0 1024
tcp_recv_hiwat 32768
tcp_slow_start_initial 2
tcp_close_wait_interval 60000
tcp_time_wait_interval 60000
tcp_xmit_hiwat 32768
BEA http://edocs.bea.com/wls/certifications/certifications/index.html를 참조한다.
IBM 웹스피어 애플리케이션 서버 4.0 InfoCenter
http://www-3.ibm.com/software/webservers/appserv/ infocenter.html
IBM WebSphere Redbooks
http://www.redbooks.ibm.com
468 웹스피어 추천 문서모음
http://www.javaservice.com/~java/bbs/read.cgi?m=appserver&b=was&c=r_p&n=1010952419
140 웹스피어 V3 퍼포먼스 튜닝 가이드
http://www.javaservice.net/~java/bbs/read.cgi?m=appserver&b=was&c=r_p&n=959577074
301 벤치마크 테스트를 위한 퍼포먼스 튜닝 퀵가이드
http://www.javaservice.net/~java/bbs/read.cgi?m=appserver&b=was&c=r_p&n=985764595
[강좌] 웹 기반 시스템에서의 성능에 대한 이론적 고찰
http://www.javaservice.net/~java/bbs/read.cgi?m=resource&b=consult&c=r_p&n=1008701211
405 웹 사이트 분석 방법 및 용량산정 팁
http://www.javaservice.net/~java/bbs/read.cgi?m=qna&b=consult&c=r_p&n=1015965697

Q16. 가비지 컬렉션 관련 설정 가이드라인

오라클 가비지 컬렉션 튜닝시에는 총 힙 메모리를 유념해야 한다.
힙 메모리는 기본적으로 가비지 컬렉션에 의해서 늘어나기도 하고 줄어들기도 한다.
또한 JVM은 사전에 정해진 특정 비율로 빈 메모리 공간을 유지하려는 특성이 있다.
목표 범위는 다음과 같은 형태로 설정할 수 있다.
-XX:MinHeapFreeRatio=
-XX:MaxHeapFreeRatio=
최대 범위는 ?Xms ~ ?Xmx 사이가 된다.
<키 포인트>
JVM에 기본적으로 할당된 메모리는 매우 적은 편이기 때문에, 별다른 문제가 없는 한 JVM에 메모리를 많이 할당해주어야 한다.
Xms와 Xmx는 같은 수치로 설정한다(물론 값에 대한 테스트는 수행되어야 한다).
프로세서를 증설하면 메모리를 늘려주어야 한다.
메모리 점유는 병렬적으로 일어나지만, 가비지 컬렉션은 그렇지 않음에 유의하라.
Another important tuning item is sizing the area of the heap dedicated to the young generation
BEA Java ?verbosegc : 가비지 컬렉션이 얼마나 자주 일어나는지 알 수 있음
힙 메모리 최소/최대 동일하게 설정
로우 메모리 설정 가능
IBM JDK 1.2 < JDK 1.3 이상에서는 가비지 컬렉션의 영향도는 없음
Xms 및 Xmx 값이 중요하며, 128-256-512m 정도 설정
썬 - Garbage collection reclaims the heap space previously allocated to objects no longer needed. The process of locating and removing the dead objects can stall any application while consuming as much as 25 percent throughput.
young generation 사이즈를 적절히 고려해 JVM에 충분한 메모리를 할당해야 한다.
JVM1.4를 위한 디폴트는 NewRatio 값과 -Xmx 값을 고려해 설정되어 있다.
- 솔라리스 시스템을 위한 설정의 예제를 살펴보자.
-Xms3584m
-Xmx3584m
-Xss128k
-Xnoclassgc
-verbose:gc
-Dsun.rmi.dgc.client.gcInterval=3600000

Q17. 쓰레드 관련 파라미터 설정 가이드라인

오라클 사용자의 부하가 큰 경우에는 쓰레드 수를 제한해야 하지만 시스템 리소스가 충분한 경우에는 쓰레드 수를 늘려준다.
최대 쓰레드 개수를 안다면 쓰레드 튜닝은 다음과 같이 두 형태로 할 수 있다.
짾 큐 사이지를 최대 쓰레드 수의 두 배로 설정한다.
짿 min=max로 설정하고 keepAlive=-1(쓰레드 타임아웃을 없앰)
BEA Unix Threading model : Green/native 쓰레드 방식, 더 좋은 성능을 위해 네이티브 쓰레드를 사용함.
ThreadCount : Default: 15/# of CPU수가 비교해 설정한다. 큐(Queue)에 쌓이지 않도록 한다.
StuckThreadMaxTime : Default: 600초/서버가 stuck되었다고 판단하는 기준 시간, Node Manager로 restart함.
ThreadPoolPercentSocketReaders : Default: 33/쓰레드 중 일부를 클라이언트 요청을 받는데 읽도록 할당
IBM Xss(native stack size) 값이 작아야 더욱 많은 쓰레드를 생성할 수 있음.


시스템 성능향상을 위한 과제
시스템의 성능에 문제가 발생하면 대게는 기술적으로만 접근하는 오류를 범한다. 또한 최근에 나온 기술이면 모든 것이 해결될 것이라고 생각하고 문제가 생기면 검증되지 않은 기술을 도입했기 때문이라고 책임을 회피하는 경우도 많다. 최고의 아키텍트는 특정 도메인의 특성에 해박하고, 업무 모델링, 인프라스트럭처와 애플리케이션에 대한 식견, 그리고 그 모두의 코디네이션(Coordination)에 능해야 한다고 혹자는 말한다. 그만큼 도메인(비즈니스)에 대한 이해가 기본적으로 필요하다는 것이다. 도메인에 대한 이해가 없는 기술적 접근은 필요 이상의 기술을 도입하게 할 수 있으며, 시스템 성능 점검시 잘못된 판단을 할 수 있다. 새로운 기술을 사랑하는 만큼 내가 개발하고 있는 업무 특성에도 관심을 가져보자.
그러나 WAS 관리자가 아무리 업무 특성을 잘 파악하고, 적극적으로 설정 변경을 주장한다 할지라도, 프로젝트의 특성상 ‘책임’ 문제가 있기 때문에, 많은 WAS 관리자들이 망설이고 있다. 이는 단순히 몇몇 사람이 해결할 수 있는 사항이 아니라 ‘성능 향상을 위한 튜닝 작업 절차’의 정형화와 정책적인 지원이 제도적으로 이루어 져야만 한다. 또한 성능을 고려하지 않는 방법론과 업무 모델링과 그리고 구현은 큰 문제가 아닐 수 없다. 시스템의 기능(functional requireme nts)만 만족하게 하고, 나중에서야 급급하게 시스템의 성능(nonfunctional requirements)을 고려하는 단기적인 시각은 반드시 고쳐져야 할 것이다. 성능을 전혀 고려하지 않은 상태에서 몇 가지 설정만 바꾸어서 일시적으로 성능이 향상되었다고 할지라도 근본적인 시스템 효율성은 향상될 수 없는 것이다.
성능이 안정화되기 위해서는 많은 부분에 노력이 필요하지만, J2EE-WG은 그 중에서 ‘성능 향상을 위한 WAS 설정’을 고민해 보았다. 고민의 흔적을 보면서 느꼈겠지만 고민을 풀어줄 해답은 아직 명쾌하게 정리되지 않았다. 아마도 국내 대부분의 기업 내부에서도 본지에서 다루었던 이슈들에 대해 문서화된 명확한 가이드라인을 제시하기는 힘들 것이다. 내부적으로 정리되지 않았던 노하우와 성능 관련 중요한 이슈들을 이제부터는 함께 정리해 보았으면 한다. 목마른 사람은 물을 찾게 되어 있지만, 마실 수 있는 물을 혼자 찾아야 한다면 그 만큼 절망적인 현실은 없을 것이다. 내가 알고 있는 길, 그 길에 대한 감각이 희미할 지라고 함께 찾았으면 한다. ‘우리는 명쾌한 가이드라인이 있는데’라고 하는 독자 혹은 함께 고민하고 싶은 사람이 있다면 서로에 대한 노하우를 전수받을 수 있는 소중한 자리가 마련되었으면 한다. 그리고 WAS 벤더들이 앞으로 만들어질 소중한 자리에서 소극적인 기존의 모습에서 벗어나 주도적으로 활동할 것을 기대한다.

정리 | 조규형 | jokyu@korea.cnet.com

 

출처 : http://www.imaso.co.kr/?doc=bbs/gnuboard_pdf.php&bo_table=article&page=3&wr_id=913&publishdate=20030401

:
Posted by 라면스프
2008. 10. 23. 18:06

windows regedit 분석 Enjoy/etc2008. 10. 23. 18:06

출처 : http://boanchanggo.tistory.com/62

windows regedit 분석

□ 레지스트리 편집기를 열면 다음과 같은 항목들이 나온다.
▤ HKEY_CLASSES_ROOT
▤ HKEY_CURRENT_USER
▤ KEY_LOCAL_MACHINE
▤ HKEY_USERS
▤ HKEY_CURRENT_CONFIG 
 
레지스트리는 윈도우의 정보를 담고 있는 일종의 Database라고 이미 설명했다.
위의 항목들이 무엇을 뜻하는지 항목 하나하나를 살펴보도록 하자.
 

 
① HKEY_CLASSES_ROOT
  • HKEY_CLASSES_ROOT*shellex ContextMenuHandlers
    마우스 오른쪽 버튼에 추가되는 응용프로그램에 대한 정보

  • HKEY_CLASSES_ROOTCLSID {645FF040-5081-101B-9F08-00AA002F954E}
    운영체제에서 사용되는 파일들의 확장자에 대한 정의와 실행
    - 바탕화면의 휴지통의 이름은 여기서 변경할 수가 있다.
② HKEY_CURRENT_USER
  • 현재 사용자가 사용하는 응용프로그램들에 대한 여러 가지 환경설정이 기록된다. 뿐만아니라 윈도우98의 각 구성 요소들에 대한 정보 역시 이곳에 저장이 되어 사용된다.

  • HKEY_CURRENT_USERAppEvents
    EventLabels
    윈도우에서 일어나는 음향 설정에 관한 레지스트리 키. 제어판의 사운드 등록정보에서 확인할 수 있다.

    Schemes
    현재 윈도우의 음향에 적용된 효과음에 대한 설정 키들. 윈도우 자체의 음향뿐 아니라 응용프로그램을 인스톨해 설정되는 음향 설정까지 모두 포한다 (예: 한글 시작시 나오는 사운드).

    HKEY_CURRENT_USERAppEventsSchemesNames
    사운드 등록정보의 사운드 구성표의 내용.

  • HKEY_CURRENT_USERControl Panel
    제어판에 대한 설정뿐 아니라 데스크탑에 대한 설정까지 포함하고 있다.

    • HKEY_CURRENT_USERControl PanelAppearanceSchemes
      디스플레이 등록정보의 화면배색이라는 대화상자속에 포함되어있는 색구성표의 목록이다.

    • HKEY_CURRENT_USERControl PanelAppearanceColors
      현재 적용해 사용하고 있는 각각의 색에 대한 설정값.

    • HKEY_CURRENT_USERControl PanelCursorsSchemes
      마우스 등록정보의 포인터항목에 위치한 마우스 구성표이다.

    • HKEY_CURRENT_USERControl PanelKeyboard
      keyboardSpeed 항목의 값이 31이면 키의 반복속도는 최대한 빠르게 설정된 상태이다.

    • HKEY_CURRENT_USERControl PanelPowerCfgPowerPolicies
      전원관리 등록정보의 전원 구성표 목록이다.

    • HKEY_CURRENT_USERControl Paneldesktop
      MenuShowDelay 키를 만든후 그 값을 0으로... 그럼 메뉴 열리는 속도가 왕 빨라진다.

    • HKEY_CURRENT_USERControl PaneldesktopWindowMetrics
      Shell Icon BPP라는 키를 살펴보자. 이 키값이 16이면 하이컬러로 아이콘이 보인다.

  • HKEY_CURRENT_USERInstallLocationsMRU
    플로피 디스크나 하드디스크의 특정 위치에서 하드웨어의 드라이버를 설치했을 경우 그 정보들이 여기에 기록된다. 플로피 디스크 드라이버의 경우 삭제해도 소용없다.

  • HKEY_CURRENT_USERkeyboard layout
    제어판의 키보드 등록정보 안에 있는 설치된 키보드 언어 및 키 배치의 내용이다. 일반적으로 한국어로 등록이 되어있기 때문에 기본키값은 412이다.

  • HKEY_CURRENT_USERNetwork
    네트워크이용시 네트워크 드라이브에 대한 설정이 저장된다.

  • HKEY_CURRENT_USERRemoteAccess
    전화접속 네트워킹의 구성내용을 저장.

  • HKEY_CURRENT_USERSOFTWARE
    사용자가 윈도우98에 설치한 응용 프로그램의 구체적인 정보를 저장한다. 예를 들면 응용 프로그램에서 사용하는 하드웨어 드라이버라든가 프로그램의 툴바의 배치상태, 색상, 사용자가 지정한 옵션들에 대한 것들이 저장되어 있다. 대개 바이너리 형태로 저장되므로 직접 편집하기는 거의 불가능하다. 따라서 해당프로그램의 옵션에서 조정해주는 방식을 이용해야 한다.

    • HKEY_CURRENT_USERSOFTWAREMicrosoft
      윈도우98에 기본으로 깔리게 되는 응용 프로그램들에 대한 설정이 저장된다. 또한 현재 윈도우 설정에 대한 정보 역시 상당히 많이 가지고 있어서 레지스트리에서 가장 중요한 부분에 속한다.

    • HKEY_CURRENT_USERSOFTWAREMicrosoftActiveMoviedevenum
      제어판의 멀티미디어 부분에 대한 정보가 여기에 저장되어 있다.

    • HKEY_CURRENT_USERSOFTWAREMicrosoftInternet ExplorerDesktop
      윈도우98의 액티브 데스크탑에 대한 설정이 저장됨.

    • HKEY_CURRENT_USERSOFTWAREMicrosoftInternet ExplorerMain
      인터넷 익스플로어 4.0의 초기 셋업에 대한 옵션

    • HKEY_CURRENT_USERSOFTWAREMicrosoftInternet ExplorerTypedURLs
      인터넷 익스플로어의 주소창에 타이핑했던 주소들을 저장.

    • HKEY_CURRENT_USERSOFTWAREMicrosoftMultimediaAudio
      윈도우95의 멀티미디어 등록정보에서 볼 수 있었던 라디오 음질, CD 음질, 전화 음질을 찾을수 있다.

    • HKEY_CURRENT_USERSOFTWAREMicrosoftWABServer Properties
      디렉토리서비스를 지원하는 사이트의 목록

  • HKEY_CURRENT_USERSOFTWAREMicrosoftWindowsCurrentVersionExplorerRecentDocs
    시작버튼에 등록되어 있는 문서메뉴의 내용이다.

    HKEY_CURRENT_USERSOFTWAREMicrosoftWindowsCurrentVersionExplorerRunMRU
    실행창에서 실행시켰던 명령어들이 기록된다.

  • HKEY_CURRENT_USERSOFTWAREMicrosoftWindowsCurrentVersionRun
    윈도우의 시동시 자동으로 시작되는 프로그램을 정의.

③ HKEY_LOCAL_MACHINE
윈도우 시동에 필요한 모든 하드웨어, 소프트웨어의 정보가 모여있다. 윈도우를 처음으로 설치했을 때 그 내용이 구성되며, 장치관리자를 애용해 하드웨어 구성내용을 변경할 수 있다. 따라서 이부분을 건들일때에는 각별히 신경을 써야 한다.

  • HKEY_LOCAL_MACHINEConfig
    현재 사용자의 시스템 구성상황을 저장하는 곳이다. 시스템 등록정보의 하드웨어 초기화 파일에 있는 Original Configuration의 내용이 바로 여기에 등록 된다. 기타 하드웨어 초기화 파일이 여러 개일 때는 Config 키 밑에 0002, 0003 과 같은 서브 키가 새로 생겨 이를 저장한다.

  • HKEY_LOCAL_MACHINEConfig001DisplaySettings
    이곳은 현재 사용자가 사용하는 디스플레이에 대한 세팅을 조정할 수 있다.
    DPILogicalX 값과 DPILogicalY 값을 변경해 모든 윈도우 폰트 크기를 조정할 수 있다.

  • HKEY_LOCAL_MACHINEEnum
    장치관리자에서 관리하는 트리구조의 하드웨어 설정을 기록하고 있다.

  • HKEY_LOCAL_MACHINEEnumBIOS
    하드웨어를 처음으로 설치할 때 지정한 PNP기기의 설정 값이 기록되어 있다. 시스템 타이머, 직접 메모리 엑세스 컨트롤러, 통신포트 등이 이에 해당한다.

  • HKEY_LOCAL_MACHINEEnumESDI
    하드디스크 구성에 대한 기록. 이것은 하드디스크의 개수에 따라 따로 따로 설정 된다.

  • HKEY_LOCAL_MACHINEEnumFLOP
    플로피 디스크에 대한 하드웨어 구성을 담고 있다.

  • HKEY_LOCAL_MACHINEEnumINFRARED
    적외선 장치에 대한 설정.

  • HKEY_LOCAL_MACHINEEnumISAPNP ISA
    슬롯에 장착되어 있는 PNP기기에 대한 설정을 포함. 사운드 카드와 사운드 카드에 포함된 게임 포트, IDE 컨트롤러 등 역시 여기에 설정된다.

  • HKEY_LOCAL_MACHINEEnumLPTENUM LPT
    포트에 대한 설정 내용이 기록되며 이곳에 연결된 장치 역시 여기에 설정되어 있다. 대표적으로 프린터가 그 예이다.

  • HKEY_LOCAL_MACHINEEnumMF
    마더 보드에 있는 E-IDE 컨트롤러에 대한 설정이 기록되어 있다.

  • HKEY_LOCAL_MACHINEEnumMONITOR
    모니터 구성에 대한 기록되어 있다.

  • HKEY_LOCAL_MACHINEEnumNetwork
    시스템에 설치된 네트워크 구성요소들에 대한 설정이 포함되어 있다. 마이크로 소프트 네트워크 클라이언트, 전화 접속 어뎁터, 마이크로 소프트 네트워크 파일/프린터 공유 프로그램, NetBEUI, IPX/SPX 호환 프로토콜, TCP/IP등이 이에 해당한다.

  • HKEY_LOCAL_MACHINEEnumPCI
    시스템에 설치된 PCI기기와 PCI에 관계되는 Intel 82439TX Pentium(r) Processor to PCI bridge, PCI 스티어링을 위한 IRQ 홀더, Intel 82371AB/EB PCI Bus Master IDE Controller등 PCI슬롯과 연결되어 있는 모든 장치에 대한 설정이 모여 있다.

  • HKEY_LOCAL_MACHINEEnumRoot
    시동할 때 윈도우가 하드웨어를 정상적으로 인식하기 위해 참고하는 바이오스 설정 내용들이 지정되어 있다. 보드가 지원하는 플러그 앤 플레이 바이오스나 마더보드의 바이오스 버전, 전원 관리 등에 대한 설정이다.
    그리고 시동 때마다 새로 읽어들이는 마우스와 같은 장치들을 설정해 둔다. PNP를 완벽하게 지원하지 못하는 하드웨어(LAN 카드, 모뎀)가 있는 경우 이미 구성되어 있는 데이터 베이스 파일(C:WINDOWSINFMACHINE.INF)을 참조하여 키를 구성한다.

  • HKEY_LOCAL_MACHINEEnumSCSI
    스카시 기기에 대한 구성이 저장되는데 일반적으로 시디롬 구성정보 역시 이곳에 있다.

  • HKEY_LOCAL_MACHINEEnumUSB
    USB 컨트롤러에 대한 설정이 기록된다.

  • HKEY_LOCAL_MACHINEHardware
    시스템에 설치되어 있는 하드웨어 목록이 기록되어 있다. 구체적인 설정내용이 있는 것이 아니라 단순한 정보만 저장되어 있다.

  • HKEY_LOCAL_MACHINEHardwareDescript-xionSystem
    이 아래에는 몇개의 서브키가 존재한다. CentralProcessor 키에서는 CPU에 대한 정보가 기록되어 있으며 FloatingPointProcessor키에는 외부 포인터 장치에 대한 정보가 기록된다.

  • HKEY_LOCAL_MACHINEHardwareDescript-xionSystemCentralProcessor
    여기에 있는 서브키중 VendorIdentifier의 내용인 GenuineIntel을 Genuine Intel로 고친다. 그러면 시스템 등록정보의 일반항목에서 현재 자신의 CPU에 대한 정확한 정보를 알수가 있다. 참고로 펜티엄166MMX의 경우에는 x86 Family 5 Model 4 Stepping 3 이다. 펜티엄133 인경우에는 x86 Family 5 Model 2 Stepping 12이다.

  • HKEY_LOCAL_MACHINEHardwaredevicemap
    현재 시스템에 있는 시리얼 포트의 이름이 기록되어 있다.

  • HKEY_LOCAL_MACHINEHardwareDirectDrawDrivers
    다이렉트 드로우를 구동하기 위한 드라이버의 이름이 기록되어 있다.

  • HKEY_LOCAL_MACHINESoftware
    시스템에 설치된 소프트웨어에 대한 정보를 저장하고 있다. 주로 프로그램의 환경설정에 대한 구체적인 정보를 저장한다. HKEY_LOCAL_MACHINESoftwareCLASSES HKEY_CLASSES_ROOT의 키값과 동일한 값을 가진다.

  • HKEY_LOCAL_MACHINESoftwareClientsContacts
    윈도우98의 주소록에 대한 설정이 기록되어 있다.

  • HKEY_LOCAL_MACHINESoftwareClientsInternet Call
    윈도우98의 넷미팅에 대한 설정이 기록되어 있다.

  • HKEY_LOCAL_MACHINESoftwareClientsMail
    윈도우98에서 사용하는 전자메일 클라이언트에 대한 설정이 기록되어 있다. 윈도우98에서는 아웃룩 익스프레스가 기본으로 깔리기 때문에 이것의 설정이 여기에 있다.

  • HKEY_LOCAL_MACHINESoftwareClientsNews
    역시 뉴스 클라이언트에 대한 설정 내용이 여기에 있다. 아웃룩 익스프레스의 뉴스리더의 설정이 저장된다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoft
    윈도우98의 구성요소들에 대한 정보들이 모두 여기에 모여있다. 따라서 윈도우98의 레지스트리 중 가장 중요한 부분 중의 하나이다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftActive SetupInstall Check
    현재 윈도우98에 설치되어 있는 인터넷 익스플로어의 버전 정보가 기록되어 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftActive_SetupInstalled Components
    윈도우98을 처음 설치했을 때 사용자가 설정한 시스템 구성요소에 대한 정보가 기록되어 있다. 따라서 윈도우98의 구성요소를 추가할때는 먼저 이곳의 정보를 읽어들여서 나타내는 것이다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftAdvanced INF Setup
    인터넷 익스플로어4.0의 삭제 정보가 여기에 기록되어 있는데, 이것은 C:Program FilesUninstall Information의 파일을 이용하게 된다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftConferencingCaptureDevices
    동화상을 캡쳐하기 위한 하드웨어에 대한 데이터 베이스가 여기 있다. 필요없는 것들은 지워주는 것이 좋다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftInternet ExplorerAdvancedOptions
    제어판의 인터넷 등록정보 대화상자의 고급 항목 내용이 저장되어 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftInternet ExplorerMainUrlTemplate
    인터넷 익스플로어4.0에서 사용하는 자동 완성 데이터가 여기 수록된다. com, edu, org만 기본으로 지원한다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftPlus!
    윈도우98에 기본으로 설치되는 테마 이외의 기타 테마에 대해 설정되어 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftPlus!System AgentSAGECompression Agent
    압축 에이전트 디스크 공간 늘림3에 대한 설정이 기록되어 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftPlus!System AgentSAGEDisk Cleanup
    디스크 정리 프로그램에 대한 설정 내용일 여기에 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftPlus!System AgentSAGEDisk Defragmenter
    디스크 조각모음에 대한 설정 기록.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftPlus!System AgentSAGELow disk space notification
    디스크 공간 부족을 경고하는 것에 대한 설정 기록.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftPlus!System AgentSAGEScandisk for Windows
    디스크 오류 검사에 대한 설정 기록.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftShared ToolsMSInfo
    마이크로 소프트 시스템 정보라는 유틸에 대한 설정이 기록된다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersion
    시스템 등록정보에 보이는 여러 가지 항목들을 수정할 수 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionApp Paths
    윈도우98에 설치되어 있는 각 프로그램의 실행 파일 경로가 기록되어 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionAppletsCheck DriveLastCheck
    하드디스크 오류 검사 결과를 여기에 기록해 두는데, 나중에 다시 검사할 때 이 정보를 참고한다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionexplorerAdvanced
    탐색기 옵션을 저장함.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionexplorerAutoComplete
    자동완성 기능을 사용할 것인지 여기에서 결정할 수 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionexplorer
    MyComputerNameSpace
    내 컴퓨터에 있는 전화접속 네트워킹 아이콘과 예약된 작업 아이콘의 표시 유무를 기록.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionexplorerSmallIcons
    탐색기나 폴더의 도구모음 아이콘을 크거나 작게 조절할 수 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionexplorerThumbnail View
    이미지 파일이나 WAV파일과 같은 일부 멀티미디어 파일인 경우 폴더를 웹형식으로 보면 해당 파일들을 미리보거나 연주할 수 있다. 여기에서는 미리 연주 기능만 켜고 끌 수 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionFonts
    윈도우에 등록된 폰트들을 저장한다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionFS Templates
    컴퓨터의 용도를 지정한다. 즉, 데스크탑 컴퓨터인지 도킹 시스템인지 네트워크 서버인지 등을 지정한다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionInternet Settings
    인터넷 익스플로러에 사용되는 모든 설정 내용을 저장하고 있다. 히스토리나 캐시 파일의 위치, 쿠키 디렉토리 그리고 액티브X의 사용 여부, 자바 스크립트 사용 여부 등의 옵션을 저장한다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionMS-DOSOptions
    윈도우98 폴더에 있는 '게임용 MS-DOS 모드'라는 단축아이콘을 클릭하면 그에 대한 등록정보 대화상자가 나타난다. 이때 프로그램 항목에서 고급이라는 단추를 눌러주면 config.sys와 autoexec.bat를 구성하는 대화상자가 나타난다. 하단의 구성 버튼을 눌러주면 나타나는 MS-DOS 구성 옵션 선택 대화상자의 옵션들이 나타나는데 이 옵션 정보가 여기에 저장되어 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionrun
    윈도우를 시동할 때 시스템에 상주하는 프로그램에 대한 설정이 여기에 기록되어 있다. CTRL+ALT+DEL키를 누르면 확인할 수 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionTime Zones
    기준 시간에 대한 목록이 기록되어 있다. 레지스트리 크기를 줄이려면 필요없는 내용들을 지워도 좋다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersion Uninstall
    제어판의 프로그램 추가/삭제 등록 정보에 수록되어 있는 프로그램 항목들이 여기에 수록되어 있다. 프로그램을 삭제한 다음에도 여전히 기록이 남아 있다면 여기에서 해당 항목을 정리할 수 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersionURL
    주소 창에 웹사이트의 주소를 적을 때 맨 앞에 붙는 부분이 설정되어 있다.

  • HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersion Winlogon
    파워토이를 설치했다면 여기에 로그인 암호를 지정해, 윈도우를 시동할 때 나타나는 로그인 암호 상자에 자동으로 암호가 입력되게 할 수 있다.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlASD
    자동 생략 드라이버 에이전트의 내용이 기록되어 있다.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlComputerName
    컴퓨터 이름이 기록되어 있다.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlFileSystem
    파일 시스템에 대한 정보가 저장되어 있다.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlIDConfigDB
    하드웨어 설정 초기화 파일을 구분하기 위한 ID의 집합부분이다.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlInstalledFiles
    윈도우 폴더에 인스톨된 실행파일 및 가상 장치 드라이버에 대한 설정 기록.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlKeyboard Layouts
    전세계의 키보드 레이아웃 구성이 수록되어 있다. 필요한 것만 남기고 모두 삭제...

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControl
    MediaPropertiesPrivatePropertiesJoystickOEM
    조이스틱의 종류에 대한 데이터 베이스이다. 필요한것만 남기고 모두 삭제

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlMediaResourcesjoystick
    현재 시스템에 있는는 조이스틱에 대한 설정이 기록됨.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlNlsLocale
    언어 지정 장소. 영문(409)과 한글(412)를 제외한 모든 것은 삭제

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlSessionManagerCheckBadApps
    윈도우98에 치명적인 응용프로그램 리스트이다. 주로 도스용 프로그램이 주류...

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlSessionManagerCheckBadApps400
    역시 윈도우98에 치명적인 구버전의 응용프로그램 리스트이다. 윈도우3.1용과 윈도우98에 절대로 깔아서는 안되는 프로그램들 항목을 볼 수 있다.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetControlUpdate
    안에 있는 UpdateMode값을 01에서 00으로 바꿔주자. 그러면 탐색기에서 파일을 리네임할 때나 복사할 때, 많은 수의 파일들을 표시할 때 속도가 증가한다. 즉 자동으로 새로고침 명령을 수행하게 된다.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetServicesClass
    하드웨어 추가마법사에서 볼 수 있는 설치할 하드웨어 종류를 정의해 놓았다.

  • HKEY_LOCAL_MACHINESystemCurrentControlSetServicesVxD
    가상장치 드라이버에 대해 정의한 곳이다. 함부로 만지면 위험.

④ HKEY_USERS
컴퓨터를 공유하는 사용자 각각의 윈도우 환경에 관한 여러 가지 설정을 저장한다. 혼자 사용할 경우에는 .default 값만 있다. 대부분의 내용은 앞에서 다룬바와 같다.
⑤ HKEY_CURRENT_CONFIG
디스플레이나 프린터에 대한 설정 내용이 저장되어 있다



출처 : http://boanchanggo.tistory.com/62

:
Posted by 라면스프
원문 http://blog.naver.com/julymorning4/100035857242


'창 닫으시겠습니까' 메시지 없애는 방법(IE7에서)

부모창에서 자식창 오픈시키면서 부모창 닫을 때 '창 닫으시겠습니까' 라는 메세지 창 없이 브라우저
종료시키는 아래 스크립트가 있는데
self.opener = self;
self.close();  

이게 IE7에서 얼핏 안되게 보이지만 가능한 방법이 있습니다.

아래 내용을 참고 하세요~

[예]
//--------------------------------------
        //IE7에서 "창을 닫겠냐"는 메시지 뜨는 것 방지용
        //--------------------------------------
                function selfClose()
                {
                    if (/MSIE/.test(navigator.userAgent)) {
                        if(navigator.appVersion.indexOf("MSIE 7.0")>=0) {
                            //IE7에서는 아래와 같이
                            parent.window.open('about:blank','_self').close();
                            parent.window.opener=null;
                            parent.window.close();
                        }
                        else {
                            //IE7이 아닌 경우
                            parent.window.opener = self; 
                            parent.self.close();
                        }                       
                    } else {
                        window.name = '__t__';
                        var w = window.open('about:blank');
                        w.document.open();
                        w.document.write('<html><body><script type="text/javascript">function _(){var w=window.open("about:blank","'+window.name+'");w.close();self.close();}</'+'script></body></html>');
                        w.document.close();
                        w._();
                    }
                } 
:
Posted by 라면스프
2008. 10. 16. 17:40

EAS3.0 메모리 관련 예제 Enjoy/FLEX2008. 10. 16. 17:40

책에 나온 메모리 관련 예제입니다.

:
Posted by 라면스프
2008. 10. 15. 15:29

이클립스 속도 빠르게 설정 Enjoy/JAVA2008. 10. 15. 15:29

인터넷 검색하다 찾은건데...

실행 명령어 뒤에 실행 옵션 주기~!

C:\eclipse\eclipse.exe 뒤에 아래 내용 붙여넣기

-vmargs -Xverify:none -XX:+UseParallelGC -XX:PermSize=20m -XX:MaxNewSize=32m -XX:NewSize=32M -Xms256m -Xmx256m -XX:ParallelGCThreads=4 -verbosegc -XX:+PrintGCDetails -XX:+PrintGCTimeStamps




eclipse.ini 수정


  1) Before


-startup

plugins/org.eclipse.equinox.launcher_1.1.0.v20100507.jar

--launcher.library

plugins/org.eclipse.equinox.launcher.win32.win32.x86_1.1.1.R36x_v20100810

-product

org.eclipse.epp.package.jee.product

--launcher.defaultAction

openFile

--launcher.XXMaxPermSize

256M

-showsplash

org.eclipse.platform

--launcher.XXMaxPermSize

256m

--launcher.defaultAction

openFile

-vmargs

-Dosgi.requiredJavaVersion=1.5

-Xms40m

-Xmx512m



  2) After


-vmargs

-Dosgi.requiredJavaVersion=1.6

-Xverify:none

-XX:+UseParallelGC

-XX:-UseConcMarkSweepGC

-XX:PermSize=128M

-XX:MaxPermSize=128M

-XX:MaxNewSize=128M

-XX:NewSize=128M

-Xms512m

-Xmx512m


  3) 설명

-Dosgi.requiredJavaVersion=1.6 => JDK 1.6 이상을 설치했을 경우에 1.6으로 설정하면 속도가 빨라진다.

-Xverify:none => 클래스의 유효성을 검사 생략. (시작 시간이 줄어 빨라진다.)
-XX:+UseParallelGC => 병렬 가비지 컬렉션 사용. (병렬 처리로 속도 향상)
-XX:+AggressiveOpts => 컴파일러의 소수점 최적화 기능을 작동시켜 빨라진다.
-XX:-UseConcMarkSweepGC => 병행 mark-sweep GC 수행하여 이클립스 GUI의 응답을 빠르게한다.
-XX:+CMSIncrementalMode=true => 점진적인 GC

-XX:PermSize=128M        => Permanent Generation(영구 영역) 크기(Out Of Memory 에러시 크기 조절)

-XX:MaxPermSize=128M  => 최대 Permanent Generation 크기

-XX:NewSize=128M         => New Generation(새 영역) 크기

-XX:MaxNewSize=128M   => New Generation(새 영역) 의 최대 크기


-Xms512m : 이클립스가 사용하는 최소 Heap 메모리
-Xmx512m : 이클립스가 사용하는 최대 Heap 메모리
                     최소와 최대를 같은 값으로 설정하면 오르락 내리락 하지않아 빨라진다.

혹시, 오류로 이클립스가 죽는다면 설정값을 한줄씩 지우거나 숫자를 변경해서 테스트 후 사용하기바람.

[메모리 정의 예]
1 기가 이하 메모리인 컴퓨터인 경우 => -Xms256m -Xmx256m
2 기가 ~ 3 기가 메모리인 컴퓨터    => -Xms512m -Xmx512m
4기가 이상 메모리인 컴퓨터            => -Xms1024m -Xmx1024m

[ 참고 ]
JVM 은 3가지 메모리 영역을 관리합니다.
 1. Permanent(영구) 영역 : JVM 클래스와 메소드를 위한 공간. = PermSize 설정
 2. New/Young 영역 : 새로 생성된 개체들을 위한 공간. = NewSize 설정
 3. Old 영역 : 만들어진지 오래된 객체들의 공간.(New 영역에서 이동해 온다)


:
Posted by 라면스프
2008. 10. 9. 16:14

java Date 관련 Quick reference Enjoy/JAVA2008. 10. 9. 16:14


* 오늘 날짜 구하기
 new Date();
 Calendar now = Calendar.getInstance();
 now.getTime();

* 어제 날짜 구하기
 Calendar now = Calendar.getInstance();
 now.add(Calendar.DAY_OF_MONTH, -1);
 now.getTime();

* 날짜 포맷을 원하는 형태로 바꾸기
   Calendar now = Calendar.getInstance();
   SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
   sdf.format(now.getTime());  // 결과는 String

 

* 지 맘데로의 날짜를 담은 문자열을 다른 형태로 convert
 

    String dateStr = "200707211541122";
    SimpleDateFormat oldFormat = new SimpleDateFormat("yyyyMMddHHmmss");
    SimpleDateFormat newFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
   
    try {
      System.out.println(newFormat.format(oldFormat.parse(dateStr)));
    } catch (ParseException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
 

* yyyy-MMM-dd 형태 parse 시 주의 할 점
   String regDt = "27/Jul/2006:00:00:00";
   SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MMM/dd:hh:mm:ss",
       Locale.US);

   try {
     System.out.println(sdf.parse(regDt).toString());
   } catch (ParseException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
   }

-> 위와 같이 Locale을 지정하지 않으면 한글 OS에서는 parse 오류가 난다.

* 특정날짜가 무슨 요일인지 알아보기
   String regDt1 = "2006-11-14";
   SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd", Locale.US);
 

   Calendar cal = Calendar.getInstance();
 

   try {
     cal.setTime(sdf.parse(regDt1));
     System.out.println(cal.get(Calendar.DAY_OF_WEEK));
   } catch (ParseException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
   }

주의: cal.DAY_OF_WEEK라고 하면 처음 생성했던 instance의 값을 리턴한다.

* 날짜 간의 비교
 
    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
    Calendar now = Calendar.getInstance();
    now.add(Calendar.HOUR, -3);
    Date before3hour = now.getTime();
   
    try {
      if (before3hour.before(sdf.parse(regdttm))) {
        return true;
      } else {
        return false;
      }
    } catch (ParseException e) {
      return false;
    }

:
Posted by 라면스프
2008. 10. 7. 16:26

도적 트리 It's Me/와우2008. 10. 7. 16:26


출처 : http://wow.somegate.com/topic.php?topic_uid=85168

 

전투 도적으로 하고 있는데 특성 찍기 힘들어서...

와우섬게이트에서 괜찮은 글 있어서 퍼왔슴...

 

1. 전투 도도

 암살

 절개연마는 찍지 않습니다. 물론 도도특성은 단단에 비해 버블이 잘 모입니다만 절개의 기대dps는 쌍맹독 했을 경우 연마된 독살의 dps에 이길 수 없습니다. 맹독 디버프가 사라진다는 단점이 있지만 방어도에 따라 급격히 떨어지는 절개의 특성상 독살이 더 나은 것으로 판단됩니다. 개인적 취향에 따라 치독연마-독연마는 포인트를 어느정도 공유해도 무방합니다.

 전투

 사악연마-회피는 기본. 난도질 연마는 전투트리로 레이드 하는 도적이라면 당연히 다 찍는 특성이죠. 딜의 기본은 난도질 유지부터니까요. 간혹 무기막기-반격을 찍으시는 분들도 있습니다만 레이드 자체로 보면 별로 쓸모 없다고 판단됩니다. 전력질주연마-불뱀을 안가는 공대라면 안찍어도 무방합니다만 불뱀트라이중인 공대라면 반드시 찍으실 것을 권유드립니다. 바쉬 3차에서 그망, 소멸 쿨탐에  뿌리-독 콤보라면 몇초 후 누워있는 자신을 발견하시는 경우를 미리 방지하는 차원에서;; 강철신경-제 경험상 탱커가 스턴이나 공포 걸렸는데 딜러만 저항해서 딜하는 상황에선 딜러 급사가 자주 생깁니다. 검사-하이잘 트라이공대라면 개인적 취향에 따라 찍으셔도 무방할 듯 합니다만 체감상 별로 안터집니다;;이후 특성들은 기본적이며 보편적인 동시에 필수적인 것이므로 설명 패스.

2. 전투 단단

1. 암살: 학살:무정함 - 저도 스킬 리셋마다 항상 고민합니다. 무정함으로 인한 버블 수급이냐 학살으로 인한 dps상승이냐...기습딜은 사악딜보다 버블이 잘 안모여서 난도 유지가 '비교적' 어렵습니다. 이 2포인트는 개인차가 심하므로 둘중 아무거나 찍으셔도 무방하겠습니다. 치명상 - 잠행의 기회포착을 4포인트 주고 치명상을 5포인트 주시는 분들도 간혹 계십니다만 치명상은 말그래도 '치명상'에만 데미지가 상승합니다. 반면 기회포착은 치명상이 안터져도 딜 상승효과가 있죠. 기회포착 5포인트를 더 추천드립니다.

2. 전투: 도도 전투트리 설명과 모두 같습니다. 아 그리고 '공격성'특성은 2.3 패치 후 기습에도 적용됩니다.

3. 잠행: 암살에서 설명 드렸습니다.

3. 과다출혈 딜트리

 

2.3 패치로 과다출혈의 효과가 무기공격력의 125% 데미지를 주고 이후 10회의 물리공격에 36의 추가 데미지를 주는 것으로 상향되었습니다. 기력 40(특성 찍었을 때)의 사악데미지와 별로 차이나지 않을 정도로 상향이 되었죠. 기력 35의 적은 소모량과, 도적으로 다른 클래스에 도움을 주는 디버프를 걸 수 있다는 것으로 상당한 기대를 모으고 있습니다(물론 이전에도 있었지만 조금 안습이었죠). RDPS가 상승할 것으로 예상됩니다.  또한 '비열한 행위'가 생명력 35% 이하의 대상에게는 스킬로 주는 데미지가 10% 늘어나는 것으로 상향됩니다. 전투력 뻥튀기+톱니칼날로 인한 평타딜의 상승도 좋은 점이죠. 다만 문제는 버리는 포인트가 너무 많다는 점입니다. 아직은 검증되지 않은 트리입니다만 많은 기대심리를 불어일으키고 있습니다. 2.3 패치 후 기존의 전투트리에 질리신 분이시라면 한번 해볼만한 트리라고 생각됩니다.

 

 

출처 : http://wow.somegate.com/topic.php?topic_uid=85168

 

:
Posted by 라면스프

/castradom 사악한 일격, 반격 <- 가장 편하게 사용할수있는 매크로이지만 연타의 단점이

/cast [button;2] 반격;사악한 일격 <- 마우스 오른쪽 클릭시 반격이 나갑니다..마우스를 써야한다는 단점

/cast [modify;alt,ctrl,shift] 반격;사악한 일격 <- modify 뒤에 3가지중 한가지를 선택하면 알트,컨트롤,쉬프트 + 단축키 를 사용하면 반격 발동 그냥 단축키를 쓰면 사악이 나가는데 손에익는데 좀 시간이 걸린다는 단점이 있기는 하지만 적응이되면 아주편한 매크로 이지요

아래 매크로들은 제가 사용하는 간단한 매크로들인데 투버튼 매크로는 센터바를 사용하시는 분들이라면 아이콘 갯수를 상당히 줄여줄수있는 매크로 이구요 도움이 됬으면 좋겠네용

/cast [button:2] 소멸;그림자 망토
END
MACRO 16777228 "급후" INV_Misc_QuestionMark
/cast [button:2] 후려치기;급소 가격
END
MACRO 16777231 "난교" INV_Misc_QuestionMark
/cast [button:2] 교란;난도질
END
MACRO 16777227 "독절" INV_Misc_QuestionMark
/cast [button:2] 절개;독살
END
MACRO 16777220 "사그반" INV_Misc_QuestionMark
/startattack
/castrandom 사악한 일격, 반격, 독칼
END

MACRO 16777223 "절훔" INV_Misc_QuestionMark
/대상
/주시
/cast 기절시키기 <- 따로 유닛프레임을 사용하시는 분들이나 자신의 매즈시간을 표시하는 애드온을 사용하시는 분들이라면 다른 클래스에서도 아주 유용한 매크로이지요
END
MACRO 16777230 "파약" INV_Misc_QuestionMark
/cast [button:2] 약점 노출;파열
END
MACRO 16777222 "폭아" INV_Misc_QuestionMark
/cast [button:2] 아드레날린 촉진;폭풍의 칼날
END
MACRO 16777221 "훔비그" INV_Misc_QuestionMark
/castsequence [harm] reset=target 훔치기, 비열한 습격
END

:
Posted by 라면스프
2008. 10. 7. 11:17

HashMap에 있는 값 모두 가져오기 Enjoy/JSP2008. 10. 7. 11:17

 
HashMap에 있는 값 모두 가져오기
IT 관련/Java 2005/11/10 19:28 posted by 러브누노

HashMap에서 값을 꺼내기 위해서 보통 get 매소드를 이용하여 key값에 해당하는 value를 얻는다.
 
key값을 모르는 상태에서 HashMap에 저장된 모든 key와 그에 대응되는 value를 얻고자 할 때 다음과 같이 하면 된다.
 
 
[ HashMap 예제 ]
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map.Entry;
public class HashMapTest {
  public static void main(String[] args) {
    HashMap map = new HashMap();
    map.put("first", "First String");
    map.put("second", "Second String");
    Iterator iterator = map.entrySet().iterator();
    while (iterator.hasNext()) {
      Entry entry = (Entry) iterator.next();
      System.out.println("key : " + entry.getKey() + "    value : " + entry.getValue());
    }
  }
}

결과 )
key : first    value : First String
key : second    value : Second String
HashMap에 값이 저장될
:
Posted by 라면스프
2008. 10. 5. 15:23

하늘아리 [ Hanulari3_build_1.10_basic ] It's Me/와우2008. 10. 5. 15:23

하늘아리 3 

 Build No 1.10 베이직 (초심자용)

 

주의 !! 반드시 기존 애드온과 WTF 폴더를 삭제 후 설치하세요.

출처 : http://wow.gamemeca.com

 

본 버전은 초심자 용으로 가장 기본적인 애드온 들만 설치됩니다.

깔끔하고 가벼운 하늘아리를 원하시는 분들은 이 버전을 설치하세요.

베이직 버전은 전체 설치 후 사용 메모리는 대략 10메가 전후입니다.

본 버전은 빅윅, 공격대도우미, 데미지미터, 어그로미터 등의 애드온은 포함되어 있지 않습니다.

 

Changes Build 1.10

------------------------------------------------------------------------------------------

1. 메모리 최적화

   - 전체 설치를 하더라도 총 사용메모리가 11메가를 넘지 않습니다.


2. 1.9c 업그레이드 내용 포함

   - 기존의 업그레이드 버전의 내용을 전부 포함

   - 1.9c에서 문제가 되었던 유닛프레임의 프레임 모양을 기본으로 변경


3. 일부 애드온의 기본 셋팅 값 변경(1024x768 해상도를 기준)
   - 아이템랙이 기본적으로 주무기,보조무기, 장신구1, 장신구1의 슬롯이 미리 꺼내져 있습니다.

   - 하늘 퀘스트로그의 배경값 및 기본 위치값 변경

   - 미니맵 버튼 기본 위치값을 보기 좋게 변경

 

4. 라이브러리 업데이트

   - 라이브러리를 최신 버전으로 업데이트 하였습니다.


5. 하늘 트윅 내부의 물품관리자와 겹치는 기능을 제거

   - 하늘 트윅의 자동수리, 자동잡템 판매 기능이 물품관리자와 겹치는 관계로 누락시켰습니다.

 

6. I-팝바 추가

   - 기존의 팝바와 비슷한 기능을 수행하는 I-팝바가 새로 추가되었습니다.

   - 기본적으로 3D초상화 기능과 같이 애드온 목록에서 체크해제되어 있습니다.

     사용하시려면 애드온 목록에서 체크를 해주셔야 사용이 가능합니다.

   - I-팝바는 따로 설정패널을 불러오기 위한 버튼이 없습니다. 설정패널을 불러오기 위해서는

      "/ipopbar" 명령어를 치셔야 설정패널을 불러올 수 있습니다.

 

7. 레이아웃 변경 기능 제거

   - 더이상 레이아웃 변경 기능은 사용하실 수 없습니다. 프레임 구조상 오류(바가 글자를 가리는 현상)

     등의 오류로 인해 사용에 많은 불편함을 주는 관계로 해당 기능은 더이상 하늘아리에 포함되지

     않습니다. 바텐더 레이아웃을 사용하시는 분들은 따로 오리지날 바텐더3(http://files.wowace.com/Bartender3/Bartender3-r74802.zip)를 사용해주시기 바랍니다.


:
Posted by 라면스프