피보나치

 

#include <iostream>
#include <iomanip>
using namespace std;
long fib(long num);

int main(void)
{
 int looper;
 int seriesSize;

 cout<< "몇개출력?";
 cin>>seriesSize;
 
 for(int i=0; i<seriesSize; i++)
 {
  cout<< fib(i) <<endl;
 }
}

long fib(long num)
{
//베이스케이스

   if(num==0 || num ==1)
   {
 return num;
   }

 //제너럴케이스
   else
   {
     return(fib(num-1)+ fib(num-2));
   }

}

'1. IT Story > Development' 카테고리의 다른 글

insertionSort  (0) 2012.03.28
Heap Tree (보기좋게출력)  (0) 2012.03.28
하노이타워  (0) 2012.03.28
이진찾기  (0) 2012.03.28
윈도우폰 게임개발 기초(WindowPhoneGame)  (0) 2012.03.07
C# 채팅 프로그램(Client 확장)  (0) 2012.03.07
C# 채팅 프로그램(Server 확장)  (4) 2012.03.07
C# 채팅 프로그램(Client)  (0) 2012.03.07
블로그 이미지

운명을바꾸는자

IT와 함께 살아가는 삶

,




Oracle 10g Install 설치 후(DBCA생성 전) -> Upgrade(10.2.0.4) -> DB설치(DBCA) -> Upgrad(10.2.0.5) [RHEL5]

   

1.오라클 현재 버전 확인

   

1-1 Dbupgdiag.sql

   

   

1-2 dbupgdiag.sql 실행 및 버전 확인

  • 간단하게 sqlplus "/as sysdba" 나 select * from v$version 을 통해서 알아 볼 수 도 있다.
  • 해당 스크립트를 사용하는 이유는 현재 버전에 대한 정보와, 그 후에 버전의 번화를 확인할 때 편리하기 때문이다.

       

   

   

2.기존에 존재하던 패치파일 삭제

   

   

3.10.2.0.5 패치파일 준비

   

   

4.패치를 하기 전에 리스너와 DB를 정지시킨다.

  • 정지하지 않을 경우 중간에 프로세스를 중지하라는 에러가 발생하게 됨.

   

   

5.10.2.0.5 패치 파일 실행

   

   

   

5-1 패치 할 Oracle Home 지정

   

   

5-2 오라클 서포터를 받을 건지에 대한 선택

   

   

5-3 해당 패치파일 설치에 필요한 요구 값들 체크

   

<에러 발생1>

  • 커널 파라미터 값에 대한 에러발생

       

   

Checking the Components installed in Oracle Home

Check complete. The overall result of this check is: Passed

=======================================================================

   

Checking for Oracle Home incompatibilities ...

Check complete. The overall result of this check is: Passed

=======================================================================

   

Checking kernel parameters

Checking for semmsl=250; found semmsl=250.        Passed

Checking for semmns=32000; found semmns=32000.        Passed

Checking for semopm=100; found semopm=100.        Passed

Checking for semmni=128; found semmni=128.        Passed

Checking for shmmax=1073741824; found shmmax=536870912.        Failed <<<<

Checking for shmmni=4096; found shmmni=4096.        Passed

Checking for shmall=2097152; found shmall=2097152.        Passed

Checking for file-max=101365; found file-max=65536.        Failed <<<<

Checking for VERSION=2.6.18; found VERSION=2.6.18-194.el5.        Passed

Checking for ip_local_port_range=9000 - 65500; found ip_local_port_range=1024 - 65000.        Failed <<<<

Checking for rmem_default=1048576; found rmem_default=262144.        Failed <<<<

Checking for rmem_max=1048576; found rmem_max=262144.        Failed <<<<

Checking for wmem_default=262144; found wmem_default=262144.        Passed

Checking for wmem_max=262144; found wmem_max=262144.        Passed

Check complete. The overall result of this check is: Failed <<<<

Problem: The kernel parameters do not meet the minimum requirements (see above).

Recommendation: Perform operating system specific instructions to update the kernel parameters.

  

  

   

<에러 해결1>

  • 에러가 발생한 파라미터 값들을 해당 패치가 원하는 값의 크기로 변경하여 적용

       

# Vi /etc/sysctl.conf

파일 위치

   

   

<에러 발생2>


<에러 해결2>

  • 10g는 기본적으로 물리적 메모리를 1GB 이상 요구한다. 그러나, 실제 시스템에서는 2GB 이상의 메모리를 장착하므로 기본적으로 Passed로 나오게 된다. 512MB인 경우에도, swap이 충분하면 설치가 가능하며 DB 생성, 운영이 가능하다.
  • 넘어가도 설치하는 것에는 이상이 없음(정확한 이유를 잘모르겠음)

   

5-4 패치 요약

   

   

5-5 패치 설치

   

   

5-6 스크립트 실행(Root계정)

   

   

   

5-7 패치 설치완료

   

   

<에러 발생3>

  • 패치 후에 DB를 시작하게 되면 다음과 같은 에러가 발생한다.

       

   

   

  • 오라클 10g 패치 후(10.2.0.4 -> 10.2.0.5)  

    startup 명령어로 DB를 open 하려고 할 때,

    ORA-01092: ORACLE instance terminated. Disconnection forced 에러 발생

       

  • 발생 원인

    오라클 엔진만 패치되고 DB에 패치가 제대로 적용되지 않았을 경우

   

   

7.Post Upgrade

   

  • 해당 작업은 DB를 이미 사용하고 있는 경우에 작업, 즉 DB가 설치되어 있지 않은 경우에는 하지 않아도 된다.(소프트웨어만 설치되었을 경우)
  • 패치 작업이 끝난 후에는 Post Upgrade 작업을 진행
  • 주 작업 내용은 DB 파라미터 값을 수정.

   

6-1

   

SQL> startup upgrade

(SQL> startup migrate)

두 개 중 1개만 사용

SQL> select status from v$instance;

현재 상태확인

   

   

   

   

6-2

SQL> @?/rdbms/admin/catupgrd.sql

엔진을 따라서 DB에 버젼 패치 적용.

   

   

   

6-3

SQL> shutdown

  

SQL> startup

  

SQL> @?/rdbms/admin/utlrp.sql

// Invalid PL/SQL package를 compile 하는 단계

   

   

   

7.패치완료 확인

  • 현재까지 무사히 왔다면, 패치가 완료되었을 것임.
  • 마지막으로 패치가 잘 되었는지를 확인해야 함.
  • 현재 DB 버전확인
  • 현재 DB 상태확인
  • 데이터베이스 중요 데이터파일들이 존재하고, 잘 적용이 되는지 확인한다.
  • Dbupgdiag.sql를 통하여 현재 데이터베이스의 패치 상태를 확인한다.(아래 참고)

       

   

7-1 dbupgdiag.sql 패치완료 확인

  • 스크립트 실행후, 해당 로그 파일을 천천히 보면서 패치가 잘 적용되었는지 확인한다.

   

   

   

   

   

원본 위치 <http://web3.c2.cyworld.com/myhompy/board/retrieveBoard.php?home_id=a3177717&lmenuSeq=499037&smenuSeq=834741&postSeq=6952833&referrer=http%3A%2F%2Fwww.cyworld.com%2FBC83%2F6952833>

원본 위치 <http://blog.naver.com/PostView.nhn?blogId=thesot&logNo=70126892070&beginTime=0&jumpingVid=&from=search&redirect=Log&widgetTypeCall=true&topReferer=http%3A%2F%2Fsearch.naver.com%2Fsearch.naver%3Fsm%3Dtab_hty.top%26where%3Dnexearch%26ie%3Dutf8%26query%3Dora-01092%26x%3D0%26y%3D0>

원본 위치 <http://www.saybox.co.kr/bbs/board.php?bo_table=board04&wr_id=1>

블로그 이미지

운명을바꾸는자

IT와 함께 살아가는 삶

,



Oracle 10g Install 설치 후(DBCA생성 전) -> Upgrade(10.2.0.4) -> DB설치(DBCA) [RHEL5]

   

1.Display 및 DB 설치 시작

   

# Xhost +

Display 사용

# Su - oracle

Oracle 유저

$ dbca

DB 설치

   

   

2.DBCA를 이용한 DB 생성

   

   

2-1 데이터베이스 생성

   

   

2-2 General Purpose 선택(일반 목적)

   

   

2-3 데이터베이스 이름(SID)

  • 이전에 설정했던 .bash_profile의 SID와 설정 값을 맞추어야 된다.

       

   

2-4 EM(Enterprise Manager) 사용할지 않할지 선택.(않함)

   

   

2-5 DB 생성 사용자의 암호(일괄적으로 암호를 설정함)

  • 개별적으로 암호를 설정할 수 있음.

   

   

2-6 데이터베이스의 저장 환경 지정(File system 선택)

   

   

<기본값 계속>

   

<기본값 계속>

   

2-7 플래시 복구 영역 설정

   

   

2-8 샘플 스키마 설치

  • 안 해도 되는데, 실습을 위한 환경이므로 설치

   

   

2-9 3번째 탭에서 Charater Sets 설정

  • 한국어 (언어 설정)

   

   

<기본값 계속>

   

2-10 데이터베이스 생성

   

   

   

   

<설치 완료>

   

3.오라클 10g DB 생성 완료

   

   

블로그 이미지

운명을바꾸는자

IT와 함께 살아가는 삶

,




Oracle 10g Install 설치 후(DBCA생성 전) 바로 Upgrade(10.2.0.4) [RHEL5]

   

1.해당 패치파일 준비 및 Certified Versions 확인

  • 오라클 10g 설치파일에서는 RHEL5에 대한 버전이 없었는데 패치파일에서는 추가된 것을 확인할 수 있다.

     

     

    

 

   

2.오라클 패치파일 실행

  • 오라클 초기 설치 때와 같은 방식이다.
  • DB가 생성된 뒤에 패치를 했다면, 해당 패치 설치 후에, DB에 추가적인 적용을 해주어야 한다.
  • 하지만 소프트웨어만 설치한 뒤, 바로 패치를 하기 때문에 추가적인 적용이 필요 없어 수월하게 작업을 할 수 있다.
  • 조금 바뀐 부분에 대해서만 추가적으로 이야기를 추가함.

       

   

   

2-1 패치할 Oracle Home 지정

   

   

2-2 패치 설치를 위한 체크

   

   

   

2-3 패치 요약

   

   

2-4 패치 설치

   

   

   

   

   

3.오라클 10.2.0.4 패치 완료

   

   

블로그 이미지

운명을바꾸는자

IT와 함께 살아가는 삶

,


Oracle 10g Install [RHEL5]

1.오라클 유저생성 및 그룹지정(Root계정)

   

# Groupadd -g 5000 dba

그룹생성

# Useradd -g 5000 -d /home/oracle oracle

유저 생성과 동시에 그룹지정

# Passwd oracle

Passed 지정

   

  • /etc/passwd , /etc/group 에서 확인

       

   

2.시스템 커널 및 환경 설정

   

# Vi /etc/sysctl.conf

해당 파일 위치

kernel.sem = 250 32000 100 128

kernel.shmmni = 128

kernel.msgmnb = 65536

kernel.msgmni = 2878

추후에 추가적인 환경설정 추가

# sysctl -p

환경설정 추가 후, 적용

   

   

   

3.Limits.conf 내용 수정

   

#vi /etc/security/limits.conf

파일 위치

oracle10g soft nproc 2047

oracle10g hard nproc 16384

oracle10g soft nofile 1024

oracle10g hard nofile 65536

추가 설정

   

   

4.Login 내용 수정

   

#vi /etc/pam.d/login

파일 위치

session   required   pam_limits.so

추가 설정

   

   

5.설치파일 준비

   

# Unzip "해당 프로그램 알집"

  

   

   

6.설치에 필요한 추가 rpm 패키지 확인 및 설치

   

   

<설치 rpm위치>

  • #cd /media/(RHEL5 CD)/Server

   

<rpm 설치 명령어>

  • #rpm -Uvh RPM_Name.rpm

       

-패키지 설치확인 명령어-

  • #rpm -qa | grep 패키지 명

   

-강제설치- 

  • #rpm --nodeps -Uvh 패키지.rpm

   

gcc-c++-4.1.2-44.el5

gcc-java-4.1.2-44.el5

gcc-4.1.2-44.el5

gcc-gfortran-4.1.2-44.el5

binutils-2.17.50.0.6-9.el5

compat-libstdc++-33-3.2.3-61

compat-gcc-34-3.4.6-4

compat-gcc-34-c++-3.4.6-4

compat-db-4.2.52-5.1.i386.rpm  (설치필요)

elfutils-0.137-3.el5

elfutils-libelf-0.137-3.el5

elfutils-libelf-devel-static-0.137-3.el5

elfutils-libs-0.137-3.el5

elfutils-libelf-devel-0.137-3.el5

   

glibc-common-2.5-34

glibc-devel-2.5-34

glibc-2.5-34

libaio-0.3.106-3.2

libgcc-4

libstdc++-4

libXp-1.0.0-8.1 (설치필요)

libstdc++-devel-4

make-3.81

setarch-2.0-1.1

   

openmotif-2.3.1-2.el5.i386.rpm

libaio-devel-0.3.106-3.2.i386.rpm

unixODBC-2.2.11-7.1.i386.rpm

unixODBC-devel-2.2.11-7.1.i386.rpm

sysstat-7.0.2-3.el5.i386.rpm

   

<설치 확인>

[root@localhost Server]# rpm -qa | grep binutils

[root@localhost Server]# rpm -qa | grep compat-libstdc

[root@localhost Server]# rpm -qa | grep compat-gcc

[root@localhost Server]# rpm -qa | grep compat-db

[root@localhost Server]# rpm -qa | grep elfutils

[root@localhost Server]# rpm -qa | grep glibc

[root@localhost Server]# rpm -qa | grep gcc

[root@localhost Server]# rpm -qa | grep libaio

[root@localhost Server]# rpm -qa | grep libgcc

[root@localhost Server]# rpm -qa | grep libstdc

[root@localhost Server]# rpm -qa | grep libXp

[root@localhost Server]# rpm -qa | grep libstdc

[root@localhost Server]# rpm -qa | grep make

[root@localhost Server]# rpm -qa | grep setarch

이러한 형태로 설치된 rpm확인

   

7..bash_profile 작성

   

#vi /home/oracle/./bash_profile

  

PATH=$PATH:$HOME/bin

export ORACLE_OWNER=oracle

export ORACLE_BASE=/home/oracle

export ORACLE_HOME=/home/oracle/product/10g

export PATH=$PATH:$ORACLE_HOME/bin:$ORACLE_HOME

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib:$ORACLE_HOME/jdbc/lib

export ORACLE_SID=orcl

export NLS_LANG=AMERICAN_AMERICA.KO16MSWIN949

export ORACLE_TERM=vt100

export TNS_ADMIN=$ORACLE_HOME/network/admin

export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data

export EDITOR=vi

  • 설치시 해당 Profile 내용과 일치해야 함(ORACLE_BASE, ORACLE_HOME,ORACLE_SID,TNS_ADMIN)

     

 

   

8.Oracle 사용자의 홈 디렉토리 소유권을 변경

   

# chown -R oracle.dba /home/oracle

  

   

   

9.오라클 설치 진행 OUI(Oracle Universal Installer)

   

# xhost +

Display를 실행 하기 위함.

# su - oracle

Oracle 유저에서 설치 실행

$ unset LANG

한글 깨짐현상이 발생하기 떄문에 -> 영어로 변경

$ runinstaller

오라클 설치실행

   

   

<에러 발생1>

  • 해당 에러는 오라클 10g 설치파일이 RHEL5에서는 호환이 않된다.
  • 그렇게 때문에 해당 설치파일에 수정이 필요함.

     

   

<에러 해결1>

  • 해당 설치파일 vi /database/install/Oraparam.ini에서 수정해야 함
  • Certified Versions 부분의 Linux="가능 버전" 이 적혀 있다.
  • 이 부분에 redhat-5를 추가하던지, 아니면 삭제를 통해 설치를 진행 할 수 있다.

   

<redhat-5추가>

   

<해당 버전 삭제>

   

  • 에러를 해결한 뒤 다시 설치 진행

       

   

   

9-1 advanced Installation을 선택하여 소프트웨어만 설치

  • 오라클 소프트웨어만 설치할 경우, 바로 패치 후에 DB를 설치하게 되면 해당 패치를 손쉽게 할 수 있다.
  • 그렇지 않을 경우 패치 시에 해당 DB에 적용 해주어야 한다.

 

   

9-2 해당 디렉토리와, 그룹명확인

   

   

9-3 Enterprise Edition 선택

   

   

9-4 사용할 언어 선택

   

   

9-5 해당 Oracle Home 선택

   

   

9-6 설치에 필요한 요소체크

  • RHEL5가 오라클 10g설치에 Certified Versions이 아니기 때문에 에러가 발생한다, 해당 에러에 대한 부분은 넘어가도 설치에는 이상이 없다(좀 더 알아 봐야 될 문제)
  • 추후 오라클 10g 패치 파일에는 Certified Versions에 RHEL5가 추가되어 있다.

   

   

9-7 소프트웨어만 설치

  • DB까지 설치해도 되지만, 추후에 DBCA를 통해 DB를 설치하는 방식이 좋다.

       

   

9-8 설치 요약

   

<에러 발생2>

  • 해당 에러는 RHEL5의 용량이 오라클 10g를 설치하기에는 부족하다는 것을 알려준다.

       

   

<에러 해결2>

  • 해당 리눅스의 용량을 늘려주는 방법.
  • 다른 곳에 여유의 용량이 있다면, 해당 설치하는 곳으로 용량을 배분해주면 되겠다.

   

   

9-9 오라클 10g 설치

   

   

<에러 발생3>

  • 해당 에러를 알아 보기 위해서 log파일이 있는 곳으로 가서 설치 log파일을 실행.
  • 해당 로그파일에 들어가서 맨 밑으로 내려 해당 에러를 확인한다.

   

   

  • 확인한 결과 설치에 필요한 패치지들이 정확하게 설치 되지 않았다. (/user/bin/gcc : No Such file of directiory~)

   

<에러 해결3>

  • 설치에 필요한 rpm 패키지들을 재확인한다(1:1대조)
  • 없는 패키지들에 대해서 꼼꼼히 확인하며, 설치한다.

   

   

   

   

   

   

   

  • 해당 패키지들을 확실히 확인한 뒤, Retry를 눌러 설치를 진행한다.
  • 어느정도 설치된 상태인 지금, 취소를 하게 되면, 지금까지 설치된 파일들을 깨끗이 삭제 후, 재 설치해야한다.
  • 패치할 경우 이와 같은 상황이 발생할 경우, 취소하게되면 해당 DB가 망가져 버릴 수 있다.

       

<설치 계속>

   

9-10 해당 스크립트를 Root 계정으로 실행 및 설치 완료

   

   

   

   

10.오라클 10g 설치 완료 및 확인

   

   

블로그 이미지

운명을바꾸는자

IT와 함께 살아가는 삶

,




Oracle 10g Upgrade 10.2.0.1-> 10.2.0.4
(DB생성된 후 패치)


1. 현재 DB상태확인

   

   

  • 현재 데이터베이스의 중요한 데이터에 대해서 백업실행
  • 현재 데이터베이스 버전을 확인
  • 패치를 위해서 DB를 내려도 되는 상황인지 확인
  • 현재 데이터베이스가 사용하는 DB가 있는지를 확인(DB 설치되어 있을 경우와 소프트웨어만 설치되어 있는 경우)

   
2. Oracle Patch File   

  • 메타링크를 통해 해당 패치파일 다운로드(https://support.oracle.com)
  • 패치 파일을 선택할 때 패치버전, 해당 OS의 종류를 정확히 확인하고 다운로드 해야 한다.

       

             2-1 Patch 준비

  • 해당 패치파일을 넣어주고, zip을 풀어준다.

       

# Su - oracle

해당 오라클 유저상태에서 패치를 설치함.

$ unzip "해당 패치파일"

  

   

   

   
3. Patch Install   

  • GUI형태의 설치를 하기 위해서 Xhost를 선언한다.
  • 그리고 오라클 유저로 돌아와서 해당 설치 프로그램을 실행 시킨다.
  • 설치 단계는 이전에 오라클 설치와 크게 다른 점이 없기 때문에 별도에 설명은 없다.

       

       

   

   

   

   

<에러발생 1>

  • Client_sharedlib~ 에러가 발생하게 되면, 현재 OS나 오라클 버전에 맞지 않는 패치 파일을 설치하게 되면 이러한 에러가 발생한다.
  • 이 같은 경우, 현재 OS와 오라클 버전에 맞는 패치파일을 다시 다운 받아 설치해야 한다.
  • 설치중간에 에러가 발생하여, 기존의 데이터베이스가 작동하지 않을 수도 있다.
  • 결론적으로 정확한 패치파일을 사용해야 함.

       

       

       <에러발생 2>

   

   

  • 위의 에러는 설치 하기전에 오라클을 제대로 정지하지 않아서 발생하는 에러이다.
  • 리스너의 정지, 데이터베이스의 정지

       

       

       

  • 정지 후에도 해당 에러가 발생할 경우에는 오라클 프로세스 정지시킨다.(다시 실행 시 : emctl start agent)

       

       

  • 이렇게 했음에도 않 될경우는 OS를 ReStart시켜라.

       

   

   

   

  • 오라클 설치 때와 마찬가지로 루트권한으로 해당 Script를 실행해준다.

       

   

   

  • 해당 오라클 버전이 변경된 것을 확인할 수 있다.

       

   
4. Post Upgrade 작업
 

  • 해당 작업은 DB를 이미 사용하고 있는 경우에 작업, 즉 DB가 설치되어 있지 않은 경우에는 하지 않아도 된다.(소프트웨어만 설치되었을 경우)
  • 패치 작업이 끝난 후에는 Post Upgrade 작업을 진행
  • 주 작업 내용은 DB 파라미터 값을 수정.

       

    4-1단계

       

SQL> startup upgrade

(SQL> startup migrate)

두 개 중 1개만 사용

SQL> select status from v$instance;

  

   

   

   

4-2단계

   

SQL> @?/rdbms/admin/catupgrd.sql

엔진을 따라서 DB에 버젼 패치 적용.

   

   

   

4-3단계

   

SQL> shutdown

  

SQL> startup

  

   

   

4-4단계

   

SQL> @?/rdbms/admin/utlrp.sql

// Invalid PL/SQL package를 compile 하는 단계

   

   

   

   

4-5단계

   

  • 현재까지 무사히 왔다면, 패치가 완료되었을 것임.
  • 마지막으로 패치가 잘 되었는지를 확인해야 함.
  • 현재 DB 버전확인
  • 현재 DB 상태확인
  • 데이터베이스 중요 데이터파일들이 존재하고, 잘 적용이 되는지 확인한다.
  • Dbupgdiag.sql를 통하여 현재 데이터베이스의 패치 상태를 확인한다.(아래 참고)

       

 
5. Dbupgdiag.sql
 

   

   

  • 해당 스크립트를 통하여 다양한 로그정보들을 확인할 수 있고, 해당 버전에 대한 변경을 확인할 경우 간단하게 SQL문을 통하여 확인할 수 있다.

       

Select * from dba_registry;

  

   

   

참고자료

원본 위치 <https://support.oracle.com>

원본 위치 <https://updates.oracle.com/Orion/Services/download?type=readme&aru=7276814>

원본 위치 <http://web3.c2.cyworld.com/myhompy/board/retrieveBoard.php?home_id=a3177717&lmenuSeq=499037&smenuSeq=834741&pageNo=1&postSeq=6939315&view=summary&menu=smenu>

블로그 이미지

운명을바꾸는자

IT와 함께 살아가는 삶

,




Oracle 10g Upgrade 10.2.0.1 -> 10.2.0.4 (설치 후 바로 패치)

- 오라클 소프트웨어만 설치되어 있을 경우(DB설치되어 있지 않음)

1. 
현재 DB상태확인

   

   

  • 현재 데이터베이스의 중요한 데이터에 대해서 백업실행
  • 현재 데이터베이스 버전을 확인
  • 패치를 위해서 DB를 내려도 되는 상황인지 확인
  • 현재 데이터베이스가 사용하는 DB가 있는지를 확인(DB 설치되어 있을 경우와 소프트웨어만 설치되어 있는 경우)

   
2. Oracle Patch File   

  • 메타링크를 통해 해당 패치파일 다운로드 (https://support.oracle.com)
  • 패치 파일을 선택할 때 패치버전, 해당 OS의 종류를 정확히 확인하고 다운로드 해야 한다.

 

2-1 Patch 준비

  • 해당 패치파일을 넣어주고, zip을 풀어준다.

       

# Su - oracle

해당 오라클 유저상태에서 패치를 설치함.

$ unzip "해당 패치파일"

  

   

   

   
3. Patch Install

  • GUI형태의 설치를 하기 위해서 Xhost를 선언한다.
  • 그리고 오라클 유저로 돌아와서 해당 설치 프로그램을 실행 시킨다.
  • 설치 단계는 이전에 오라클 설치와 크게 다른 점이 없기 때문에 별도에 설명은 없다.
      


   

   

   

<에러발생 1>

  • Client_sharedlib~ 에러가 발생하게 되면, 현재 OS나 오라클 버전에 맞지 않는 패치 파일을 설치하게 되면 이러한 에러가 발생한다.
  • 이 같은 경우, 현재 OS와 오라클 버전에 맞는 패치파일을 다시 다운 받아 설치해야 한다.
  • 설치중간에 에러가 발생하여, 기존의 데이터베이스가 작동하지 않을 수도 있다.
  • 결론적으로 정확한 패치파일을 사용해야 함.

       

       

       <에러발생 2>

   

   

  • 위의 에러는 설치 하기전에 오라클을 제대로 정지하지 않아서 발생하는 에러이다.
  • 리스너의 정지, 데이터베이스의 정지

       

       

       

  • 정지 후에도 해당 에러가 발생할 경우에는 오라클 프로세스 정지시킨다.(다시 실행 시 : emctl start agent)

       

       

  • 이렇게 했음에도 않 될경우는 OS를 ReStart시켜라.

       

   

   

   

  • 오라클 설치때와 마찬가지고 루트권한으로 해당 Script를 실행해준다.

       

   

   

  • 해당 오라클 버전이 변경된 것을 확인할 수 있다.

       

   

4. DB 설치   

  • 패치 후에 DB설치할 경우 패치가 되어 있음.
  • 그래서 대부분 오라클 설치 시에 소프트웨어만 먼저 설치한 뒤, 패치 후, DBCA를 통하여 DB생성 함.

   

   

   

-DB 설치과정은 이전의 오라클 설치를 참고.

   

참고자료

원본 위치 <https://support.oracle.com>

원본 위치 <https://updates.oracle.com/Orion/Services/download?type=readme&aru=7276814>

원본 위치 <http://web3.c2.cyworld.com/myhompy/board/retrieveBoard.php?home_id=a3177717&lmenuSeq=499037&smenuSeq=834741&pageNo=1&postSeq=6939315&view=summary&menu=smenu

블로그 이미지

운명을바꾸는자

IT와 함께 살아가는 삶

,


Linux ftp server 설치 및 사용법

   

리눅스가 9.x로 변화하면서 anonymous ftp 서버가 proftpd로 변경되었다.

 
    1. 
Linux FTP설치
 

        - 
anonymous ftp가 설치 되어 있지 않다면 여러분은 다음의 두 파일을 다운 받아 설치 해야 한다.

          
-anonftp-2.9-4ac.i386.rpm
          
-proftpd-1.2.0pre9-3ac.i386.rpm
 

  1. xxxxxxxxx.tar.gz, gz으로 압축된 파일이다. 주로 리눅스상에서 압축을 풀고 사용한다.
  2. xxxxxxxxx.src.rpm, 소스rpm파일이다. 소스 내용을 일부 수정해서 사용할 수 있다.
  3. xxxxxxxxx.i386.rpm, 소스 내용을 수정할 수 없는 패키지이다. i386은 인텔 i386호환기종을 말한다.
    대부분의 시스템들이 인텔 호한칩을 사용하고 있으므로 요걸 다운 받는다.

   

  • 이 파일 중에서anonyftp는 /home/ftp라는 디렉토리를 만들고 기본적인 ftp가 운용되도록 설정을 해주는 것이며 profptd는 anonymous로 접속하는 사용자들을 제어하고 anonymous서비스를 제공하는 ftp서버 프로그램이다.

    <rpm 설치 명령어>

    • #rpm -Uvh RPM_Name.rpm

         

    -패키지 설치확인 명령어-

    • #rpm -qa | grep 패키지 명

       

    -강제설치- 

    • #rpm --nodeps -Uvh 패키지.rpm
       
2. Linux FTP설정 

  - ftp서버도 마찬가지이다. conf파일만 수정하는 것으로 바로 운용이 가능하다.

  
다음 파일은 /etc/proftpd.conf의 내용이다.(OS 버전 별로 다를 수 있음.) 

[root@rootshell /root]#vi /etc/proftpd.conf

  

   

# This is a basic ProFTPD configuration file (rename it to
# 'proftpd.conf' for actual use. It establishes a single server
# and a single anonymous login. It assumes that you have a user/group
# "nobody" and "ftp" for normal operation and anon.

ServerName         "dacker.net"
ServerType         standalone
DefaultServer on

여기서 Server Name은 여러분의 ftp서버명을 말한다.
또한 서버타입은 standalone으로 하는 것이 슈퍼데몬(inetd)에 영향을 주지 않고 좋다.

# Use Pam Module (required /etc/pam.d/ftp)
# please read /usr/doc/proftpd-1.2pre3/mod_pam.c
#
AuthPAMAuthoritative on
사용자 인증에서 PAM을 사용할 것인지를 명시
# Port 21 is the standard FTP port.
Port                                21
기본 포트번호 21 반드시 외워라
# Umask 022 is a good standard umask to prevent new dirs and files
# from being group and world writable.
Umask                                022
파일을 생성하게 되면 기본적으로 주어지는 퍼미션을 umask라 한다.
022라고 설정 되어 있다면 퍼미션 644(-rw-r--r--)을 뜻한다.

# To prevent DoS attacks, set the maximum number of child processes
# to 30. If you need to allow more than 30 concurrent connections
# at once, simply increase this value. Note that this ONLY works
# in standalone mode, in inetd mode you should use an inetd server
# that allows you to limit maximum number of processes per service
# (such as xinetd)
MaxInstances                        30
자식 프로세스 최대 생성수지정. 바람직하지 못한 서비스
공격 방지 , 수 초과시 log기록 연결 해제
# Set the user and group that the server normally runs at.

User                                nobody
Group                                nobody

proftpd 데몬을 실행시키는 사용자와 그룹 설정
# To show all filenames including ``dot'' files
#LsDefaultOptions "-a"

#
# To allow root login
# be sure to take root out from /etc/ftpusers also :)
#
#RootLogin on
RootLogin off
root 계정으로 로그인, 보안에 좋지 않음 항상off로 해놓을 것

# Normally, we want files to be overwriteable.
<Directory /*>
AllowOverwrite                on
새로운 파일명이 기존의 파일명과 같을 경우 덮어쓰기 허용
</Directory>

# A basic anonymous configuration, no upload directories.
<Anonymous ~ftp>

User                                ftp
Group                                ftp
RequireValidShell off
익명사용자로 접근 가능 설정
# We want clients to be able to login with "anonymous" as well as "ftp"
UserAlias                        anonymous ftp
anonymous,ftp로 로그인 가능

# Limit the maximum number of anonymous logins
MaxClients                        10
매직 쿠기이용 메세지 삽입가능
("죄송합니다. 현재 사용인원은 %M입니다. 다음을 이용해 주십시요")
최대 접속가능 클라이언트 제한 none으로 설정하면 무제한 접속가능

# Limit the maximum number per host
# MaxClientsPerHost 1
동일한 사용자가 접속을 끊고 제접속할 수 있는 횟수
# We want 'welcome.msg' displayed at login, and '.message' displayed
# in each newly chdired directory.

DisplayLogin                        welcome.msg
로그인시 보여줄 문서 파일 welcome.msg

DisplayFirstChdir                .message

디렉토리 이동시 보여줄 문서 파일 .message
# Limit WRITE everywhere in the anonymous chroot
<Limit WRITE>
DenyAll
</Limit>
익명사용자 쓰기금지 설정
# Upload directory, allow upload and mkdir and deny download
#
# <Directory incoming>
# <Limit READ>
# DenyALL
# </Limit>
# <Limit STOR MKD>
# AllowALL
# </Limit>
# </Directory>
업로드 디렉토리 생성시 다운로드 금지, 업로드 디렉토리
생성 가능 설정
</Anonymous>

자 설정이 끝났으면 데몬을 재실행하자(윈도우에서 프로그램 설치 후 리부팅하는
것을 기억하는가
리눅스에서는 데몬에 관한 내용을 설정 후 데몬을 재 실행 시켜야만 한다.)


3. Proftpd Start/Stop

[root@rootshell /root]# /etc/rc.d/init.d/proftpd stop
shutting down ProFTPD [ok]
[root@rootshell /root]# /etc/rc.d/init.d/proftpd start
starting ProFTPD [ok]

  

 
         4. FTP 사용법

        4-1 리눅스

  • # Ftp 192.168.xxx.xxx
  • Username 입력
  • Password 입력

  

   

   

4-2 윈도우(cmd창)

  • 방화벽으로 인하여 접속이 않될 경우가 있음.(방화벽 해제)

       

  • # Ftp 192.168.xxx.xxx
  • Username 입력
  • Password 입력

  

   

   

   

4-3 FTP 명령어들..

1) ls, dir : ftp의 폴더 목록이나 파일 목록을 보여준다.

2) cd : 해당 폴더의 내부로 들어가기 위해서 cd 폴더명 을통해 폴더를 접근한다.

3) get : 파일을 받는 명령어 이다. get 파일명 을 적어주면 파일을 받을수있다.

4) mget : 파일을 여러개 받는 명령어 이다.

5) put : 파일을 업로드 한다. put 파일명을 적어주면 된다.

6) mput : 파일 여러개를 함께 올리는 명령어 이다.

7) hash : 파일 업/다운 로드의 진행 상황을 보여준다

8) bye or quit : ftp를 끝낸다.

9) help : 명령어의 전체보기

   

   

   

참고자료

원본 위치 <http://blog.iizs.net/6010654 >

원본 위치 <http://www.webtoedu.com/menu2_4.html>

원본 위치 <http://superuser.org/linux/dacker/page04.htm>

원본 위치 <http://cafe.naver.com/ArticleRead.nhn?articleid=909&sc=e0d2361c0e40259b12&query=cmd+ftp+%B8%ED%B7%C9%BE%EE&clubid=16566486>

블로그 이미지

운명을바꾸는자

IT와 함께 살아가는 삶

,