내가 이런글 올리면...

보안을 신경 쓰시는 분들은 버럭!! 하실 수도 있는 일이다..

보안적으로는 좋지 못한 방법이긴하지만//.^^;;(모..요즘 DB관리가 많이들 그러니...)

편의를 위해서 사용하는 방법으로 이해 해주시길 바란다.^^


File1. /bin/rsql

아주 단순한 놈이다..-_-;
ORACLE을 한방에 로그인 하기 위해 만든..쉘

sqlplus userid/userpassword

File2. /bin/rsql2

이것도 그다지 복잡한 놈은 아니다..
rsql2 <<sql문>>
형태로 사용하는데 은근히 편하다..

echo $@ > ~/tmp/sqltmp
echo "/" >> ~/tmp/sqltmp
sqlcvi ~/tmp/sqltmp
rsql < ~/tmp/sqltmp

File3. /bin/sqlcvi

이건 위를 보면 알겠지만 rsql2에서 사용하는 놈이다... \제거하는 역할을 한다.
사실 하도 오래전에 만들어서 기억은 잘 안나지만..막상 필요 없을 법도 하다..ㄱ-;
red $1 << EOF
1,$ s/\\\//g
w
q
EOF


File4. /bin/desc

이건 말이 DESC지 TABLE 정보를 보는 쉘이다..
사용은 desc <<테이블명>>
이면 된다.
다들 아시겠지만 oracle은 Comment 컬럼의 한글명 까지 저장이 되기때문에..
영어 컬럼명을 잘 알아보기 힘들때 쓰면 편리하다.

마지막 부분의 awk사용은 단지 빈줄로 나오는 것들을 걸러내기 위함이다..
만들고 보니 빈줄이 별로 안이쁘더라는..^^

#!/usr/bin/ksh

if [ $# -ne 1 ]
then
    echo "인자를 잘못 입력하셨습니다."
    echo "사용법 : desc TABLE_NAME"
    exit
fi

tablecomment $1 > ~/tmp/.desc_tmp

awk -F : '{
    if ($0 != "") printf("%s\n",$0);
}' ~/tmp/.desc_tmp

File4. /bin/tablecomment

이건 desc에서 사용하는 프로그램이다.
내가 하는 프로젝트의 경우 규칙이 정해져 있어 컬럼명만 보면.
사이즈., 데이터형이 어느정도 구분이 가기에 사이즈, 데이터 형은 제외하고.
영문 컬럼명, 한글 컬럼명만을 출력하도록 하였다.
이는 개발자들이 필요에 따라 데이터형, 사이즈를 추가하면 된다.
모 만들기 어려우신분은 요청을 하시면 해드릴수 있습니다.ㅎㅎ

#!/usr/bin/ksh

if [ $# -ne 1 ]
then
    echo "인자는 1개"
    exit
fi

echo "TABLE NAME : $1"

sqlplus -s userid/userpwd << EOF
        set     pagesize 10000
        set     linesize 400
        column  COMMENTS format a50
        column  COLUMN_NAME format a40
        SELECT  COLUMN_NAME,
                COMMENTS
          FROM  ALL_COL_COMMENTS
         WHERE  TABLE_NAME LIKE UPPER('$1')
        ;
        exit
EOF



File5. /bin/DESC

이건 desc를 응용하여 편하게 쓰기 위해 만든 녀석이다.

#!/usr/bin/ksh

while [ 1 ]
do
    clear
    echo "TABLE NAME을 입력하세요(종료 : q) : \c"
    read TB_NAME
    if [ ${TB_NAME} = "q" ]
    then
        break
    else
        desc $TB_NAME
    fi
    read
done




 

'컴퓨터 이야기' 카테고리의 다른 글

Unix 라인에디터  (0) 2007.02.09
find를 이용한 스크립트.  (0) 2007.02.08
나의 백업 솔루션  (0) 2007.02.06
내가 쓰고 있는 .vimrc  (0) 2007.02.05
(표준화)데이터 용어사전의 필요성.  (0) 2006.12.05

((아래는 말을 편히 하기위해서..^^
   좀 건방지게 한 면이 없지 않습니다..
   양해 부탁드리겠습니다..^^;;))

"백업에 실패한 개발자는 용서할 수 없다"

우리 사장님이 늘상 하시는 말씀이다.

나도 그렇다고 생각한다.

데이터, 코드를 날리고 백업을 하지 않아.

그만큼의 시간을 낭비한다는 것은 촉박을 다루는 프로그래머에게 아주 큰 실수이다.


어느 개발자나 개인적으로 백업 솔루션(?) 정도는 개발 하고 가지고 있어야 한다고 생각한다.

세상에 믿을건 나 밖에 없다..

회사에서 아무리 좋은 백업솔루션을 사용한다고 해도 파일 하나를 백업하기 위해서는

좀 많은 노력이 필요하게 된다.

수천개 수만개의 데이터를 백업하는데..

한개를 날렸다고 복구 솔루션을 돌리기는 부담스럽지 않은가..

나는 아래와 같은 백업 솔루션은 구성해 놓고 사용하고 있다.(유닉스환경)

File 1. bgback
이것은 cron을 지원하지 않는 시스템을 사용하기에..억지로 구성해 놓은것이다..ㄱ-;;

#! /usr/bin/ksh

while [ 1 ]
do
    /koscom/accnt/usr/hkkim2/hkkim/bnkback
    sleep 86400
done


억지 같다고..? -_-;; 난 어쩔수 없었다..

File 2. upback
이것은 FTP로 다른 PC로 전송하기 위해 만든 것이다. 서버 관리자가 실수로 서버 날리는 경우가 생기지 않는다고 장담 할 수 없다..내가 서버 관리를 해도 나를 못 믿을 것이다.
나는 내가 사용하고 있는 개발용 PC로 전송한다..
내 PC하드가 깨지면 어떻하냐고?
설마 내 하드와 서버그리고 회사 백업솔루션이 동시에 날아갈까.ㅡ_ㅡ;;
만약 그렇다면 울어버리는거다..ㄱ-;;

echo "========================================"
echo "  Open FTP Connection                   "
echo "========================================"
ftp -n xxx.xxx.xxx.xxx << EOF
    user username password
    put $1
    rm work.tar.gz
    put work.tar.gz
    bye
EOF
echo "========================================"
echo "  Close FTP Connection                  "
echo "========================================"

File 3. bnkbackup
실행명 이름들이 왜 이렇냐고 따지지 마라.-_-
내맘이다..
우리는 은행업무를 하는 팀이기 때문에.
bnk라고 넣은것 뿐..;;
단순히 압축만 해버리는 일을 한다.

if [ $# -eq 1 ]
then
        echo "======================================================"
        echo "      START BACKUP SHELL ($1)"
        echo "======================================================"
        cd ~/.backup/
        tar -cvf $1 /koscom/accnt/usr/DP/bank
        tar -cvf work.tar /koscom/accnt/usr/hkkim2/aps_bank
        gzip $1
        gzip work.tar
        echo "======================================================"
        echo "      END BACKUP SHELL ($1)"
        echo "======================================================"
else
        echo "argc is not 1 ($#)"
fi


File 3. bnkbackup
이건 File2, File3을 이용해서 실재 실행하는 놈이다.
File1은 단지 FTP용일 뿐이고..

filename=Bnk_`date +%Y_%m_%d_%H%M%S`.tar
cd ~/.backup
~/hkkim/bnkbackup $filename >> ~/.backup/log/backup.log
~/hkkim/upback $filename.gz >> ~/.backup/log/backup.log
rm -fr *.gz


현재는 DB백업하는 일이 없기때문에 단순하다..
그리고 나라는 놈은 쓸대 없이 프로그램을 많이 나누어 놨따.ㅋㅋ

모 만든 사람 맘이지..-_-;;

'컴퓨터 이야기' 카테고리의 다른 글

find를 이용한 스크립트.  (0) 2007.02.08
내가 쓰는 ORACLE..  (2) 2007.02.08
내가 쓰고 있는 .vimrc  (0) 2007.02.05
(표준화)데이터 용어사전의 필요성.  (0) 2006.12.05
Programing에 대해서 주저리주저리  (1) 2006.12.01

+ Recent posts