command )

    service list
    #service --status-all

    port list
    #netstat -atlpvn


Posted by 양형

댓글을 달아 주세요

java.net.UnknownHostException

Java 2016. 1. 28. 17:57
  • [원인]

웹 서버의 DNS 설정이 되어있지 않아서 발생되는 문제입니다.

이 문제는 localhost 환경에서는 발생되지 않지만, 직접 설치된 서버 혹은 외부서버에서 가동 시에 문제가 될 수 있습니다.

이 문제는 SNMP 통신 혹은 PING 등의 Network 관련 작업을 수행할 경우,

해당 웹 서버에서 외부로의 이동이 요구될 때 발생될 수 있는 문제입니다.

  • [해결방법]

각 웹 서버의 설정에 맞게 DNS 설정을 합니다.

[1] 서버가 IBM AIX 일 경우

telnet 으로 해당 서버에 접속 cd /etc/resolv.conf 파일을 vi 편집기로 수정하여

해당 ISP 의 네임서버와 IP 주소를 등록합니다.

(ex : 127.0.0.1 localhost )

[2] 서버가 TOMCAT 일 경우

telnet 으로 cd /etc/ 경로로 이동하여 vi 편집기로 hosts 파일을 수정합니다.

[1] 번과 마찬가지로 수정하면 됩니다.

ps. 운영체제는 리눅스 혹은 UNIX 기준입니다. Windows OS 일 경우 아래와 같이 변경하시면 됩니다.

경로 : windows/system32/driver/etc

위의 경로를 따라가면 hosts 라는 파일이 있습니다. 해당 파일을 메모장 혹은 기타 편집기를 이용하여

수정하시면 됩니다.

일반적인 hosts 파일의 내용은 아래와 같습니다만, 상이할 수 있습니다.

#========================================================================================

# Copyright (c) 1993-2006 Microsoft Corp.
#
# This is a sample HOSTS file used by Microsoft TCP/IP for Windows.
#
# This file contains the mappings of IP addresses to host names. Each
# entry should be kept on an individual line. The IP address should
# be placed in the first column followed by the corresponding host name.
# The IP address and the host name should be separated by at least one
# space.
#
# Additionally, comments (such as these) may be inserted on individual
# lines or following the machine name denoted by a '#' symbol.
#
# For example:
#
# 102.54.94.97 rhino.acme.com # source server
# 38.25.63.10 x.acme.com # x client host

127.0.0.1 localhost
127.0.0.1 activate.adobe.com
127.0.0.1 3dns-3.adobe.com
127.0.0.1 adobe-dns-2.adobe.com
127.0.0.1 adobe-dns-3.adobe.com
127.0.0.1 ereg.wip3.adobe.com
127.0.0.1 activate-sea.adobe.com
127.0.0.1 wip3.adobe.com
127.0.0.1 wwis-dubc1-vip60.adobe.com
127.0.0.1 activate-sjc0.adobe.com
127.0.0.1 practivate.adobe.com
127.0.0.1 ereg.adobe.com
127.0.0.1 activate.wip3.adobe.com
127.0.0.1 3dns-2.adobe.com
127.0.0.1 adobe-dns.adobe.com

#========================================================================================


Posted by 양형

댓글을 달아 주세요

[SQL] ALTER TABLE 테이블 수정 (ADD, DROP, MODIFY, RENAME)


한번 생성된 테이블은 특별히 사용자가 구조를 변경하기 전까지 생성 당시의 구조를 유지하게 된다.

처음의 테이블 구조를 그대로 유지하는 것이 최선이지만, 업무적인 요구 사항이나 시스템 운영상 테이블을 사용하는 도중에 변경해야할 일들이 발생하기도 한다.

이 경우 주로 컬럼을 추가/삭제 또는 제약조건을 추가/삭제 작업을 하게 된다.


1. ADD COLUMN (컬럼 추가)


기존 테이블에 필요한 컬럼을 추가하는 명령어



ALTER TABLE 테이블명
ADD 추가할 컬럼명  데이터 유형;

ALTER TABLE PLAYER
ADD (ADDRESS VARCHAR2(80));


- PLAYER 테이블 마지막에 ADDRESS(길이 80) 컬럼을 추가한다.


* 새롭게 추가된 컬럼은 테이블의 마지막 컬럼이 되며 컬럼의 위치를 지정할 수는 없다.



2. DROP COLUMN (컬럼 삭제)


DROP COLUMN은 테이블에서 필요 없는 컬럼을 삭제할 수 있으며, 데이터가 있거나 없거나 모두 삭제 가능하다.

한 번에 하나의 컬럼만 삭제 가능하며, 컬럼 삭제 후 최소 하나 이상의 컬럼이 테이블에 존재해야 한다.



ALTER TABLE 테이블명
DROP COLUMN 삭제할 컬럼명;

ALTER TABLE PLAYER
DROP COLUMN ADDRESS;


- PLAYER 테이블에 ADDRESS 컬럼을 삭제한다.


* 한번 삭제된 컬럼은 복구가 불가능하다.



3. MODIFY COLUMN (컬럼 수정)


테이블에 존재하는 컬럼의 데이터 유형, 디폴트(DEFAULT) 값, NOT NULL 제약조건에 대한 변경을 한다.



ALTER TABLE 테이블명
MODIFY (컬럼명1 데이터 유형 [DEFAULT 식] [NOT NULL],
               컬럼명2 데이터 유형 [DEFAULT 식] [NOT NULL]);
            
            
ALTER TABLE TEAM_TEMP
MODIFY (ORIG_YYYY VARCHAR2(8) DEFAULT '20020129' NOT NULL);


 


- TEAM 테이블의 ORIG_YYYY 컬럼의 데이터 유형을 CHAR(4)->VARCHAR2(8)로 변경하고, 향후 입력되는 데이터의 DEFAULT 값으로 '20020129'를 적용하고, 모든 행의 ORIG_YYYY 컬럼에 NULL이 없으므로 제약조건 NULL -> NOT NULL로 변경한다.

 

* MODIFY COLUMN 시 고려사항


- 해당 컬럼의 크기를 늘릴 수는 있지만 줄이지는 못한다. 이는 기존의 데이터가 훼손될 수 있기 때문이다.

- 해당 컬럼이 NULL 값만 가지고 있거나 테이블에 아무 행도 없으면 컬럼의 폭을 줄일 수 있다.

- 해당 컬럼이 NULL 값만을 가지고 있으면 데이터 유형을 변경할 수 있다.

- 해당 컬럼의 DEFAULT 값을 바꾸면 변경 작업 이후 발생하는 행 삽입에만 영향을 미치게 된다.

- 해당 컬럼에 NULL 값이 없을 경우에만 NOT NULL 제약조건을 추가할 수 있다.


4. RENAME COLUMN (컬럼명 수정)


테이블을 생성하면서 만들어졌던 컬럼명을 변경해야 할 경우에 사용한다.



ALTER TABLE 테이블명
RENAME COLUMN 변경해야할 컬럼명 TO 새로운 컬럼명;


ALTER TABLE PLAYER
RENAME COLUMN PLAYER_ID TO TEAM_ID;


- PLAYER 테이블의 PLAYER_ID 컬럼명을 TEAM_ID 로 변경한다.


* RENAME COLUMN으로 컬럼명을 변경하면, 해당 컬럼과 관계된 제약조건에 대해서도 자동으로 변경된다.

(Oracle 등 일부 DBMS에서만 지원한다.)


5. ADD CONSTRAINT


테이블 생성 시 제약조건을 적용하지 않았다면, 생성 이후에 필요에 의해서 제약조건을 추가할 수 있다.



ALTER TABLE 테이블명
ADD CONSTRAINT 제약조건명 제약조건 (컬럼명);


ALTER TABLE PLAYER
ADD CONSTRAINT PLAYER_FK
   FOREIGN KEY (TEAM_ID) REFERENCES TEAM(TEAM_ID);



- PLAYER 테이블에 TEAM 테이블과의 외래키 제약조건을 추가한다.

- 제약조건명은 PLAYER_FK로 하고, PLAYER 테이블의 TEAM_ID 컬럼이 TEAM 테이블의 TEAM_ID를 참조하는 조건이다.


* FOREIGN KEY 제약조건을 위와 같이 추가하면 PLAYER 테이블의 TEAM_ID 컬럼이 TEAM 테이블의 TEAM_ID 컬럼을 참조하게 된다.

참조 무결성 옵션에 따라서 만약 TEAM 테이블이나 TEAM 테이블의 데이터를 삭제하려 할 경우 외부(PLAYER 테이블)에서 참조되고 있기 때문에 삭제가 불가능하게 제약을 할 수 있다.

즉 외부키(FK)를 설정함으로써 실수에 의한 테이블 삭제나 필요한 데이터의 의도치 않은 삭제와 같은 불상사를 방지하는 효과를 볼 수 있다.


6. DROP CONSTRAINT


테이블 생성 시 부여했던 제약조건을 삭제하는 명령어



ALTER TABLE 테이블명
DROP CONSTRAINT 제약조건명;


ALTER TABLE PLAYER
DROP CONSTRAINT PLAYER_FK;


- PLAYER 테이블의 제약조건 PLAYER_FK 를 제거한다.

'Query' 카테고리의 다른 글

[SQL] ALTER TABLE 테이블 수정 (ADD, DROP, MODIFY, RENAME)  (0) 2016.01.26
Posted by 양형

댓글을 달아 주세요