태터데스크 관리자

도움말
닫기
적용하기   첫페이지 만들기

태터데스크 메시지

저장하였습니다.

보통은 "내문서"와 같이 특정한 디렉토리를 지정해서 자료를 관리하게 됩니다.
그런데 이 파일들을 백업을 받을려고 다른 디렉토리로 복사를 해두기도 하는데...

이게 양이 많아지다 보면 모두 복사하는 데 꽤나 많은 시간이 걸리곤 합니다.
그래서, 처음에야 어쩔수 없지만,
두번째부터는 달리진 파일들만 복사하고 싶어서 이것저것 명령어를 찾다가, 지금 사용하고 있는 명령어 입니다.
(물론, 원본디렉토리에서 삭제된 파일이 복사본디렉토리에서도 삭제되는 건 아니기 때문에 복사본디렉토리에는
쓸데 없는 파일들도 남게 됩니다. 백업의 차원에서 이정도의 가비지는 인정하기로 했습니다. ^^ )

XCOPY "원본디렉토리"  "복사본디렉토리"  /D /S /C /R /Y

시간을 절약하는 데 도움이 되시길 바랍니다.




 

 

저작자 표시
Posted by bomsoft

-----------------------------------------------------------------------------
#!/usr/bin/sh

# log file을 날짜별로 변경하고자 할 경우에 사용할 수 있는 shell script 입니다.

CHG_DATE=$(date +%Y%m%d)   # 오늘날짜 가져오기
LOG_FILE=catalina.out    # 로그파일 지정
LOG_DIR=/ptc/tomcat5/logs/  # Log가 위치한 디렉토리 지정

# 해당 로그폴더로 이동합니다. 이부분은 절대경로로 사용하든, 상대경로로 사용하든 알아서 하면됩니다.
cd ${LOG_DIR}

# 로그파일을 오늘날짜이름으로 카피
cp ${LOG_FILE} ${LOG_FILE}_${CHG_DATE}.log

# copy가 성공됐으면, 원래의 로그파일을 0바이트로 만듭니다.
# mv나 지우고 다시 만들지 않는 것은, 서비스중 hang이 걸리지 않게 하기 위해서 입니다.

if [ -f "${LOG_FILE}_${CHG_DATE}.log" ]
then
    # 시스템에 따라서 다음 방법 중에서 잘 되는 걸로 선택하여 적용합니다..
   
    # 방법 1
    touch ${LOG_FILE}_tmp.log
    cat ${LOG_FILE}_tmp.log > ${LOG_FILE}

    # 방법 2
    touch ${LOG_FILE}_tmp.log
    cp ${LOG_FILE}_tmp.log  ${LOG_FILE}
   
    # 방법 2
    cp /dev/null ${LOG_FILE}
fi
# 끝.
----------------------------------------------------------------------------------

저작자 표시
Posted by bomsoft

최신버전으로 사용하는 것이 제일 좋을 수 있지만...

경우에 따라서는 이전 버전의 JDK나 JRE가 필요할 때도 있습니다.

이런 경우, 이전 버전의 java를 찾기 어려운데...
아래 링크에 가시면 선택해서 받을 수 있습니다.

http://java.sun.com/products/archive/



Posted by bomsoft
TAG download, java, JDK, jre

MS Office 2007에서는 .pptx , .docx , .xlsx 라는 파일로 저장되는 데...

이 파일들은 MS Office 2003에서는 열수 없습니다.

필자는 2003 버전에 더 익숙하고, 개인적으로 2007 버전이 좀 어색하다고 생각하기 때문에..

2007 버전으로 바꾸고 싶지는 않습니다.

하지만, 2007 버전의 파일들을 열어볼 필요는 많이 있습니다.

그래서 호환성을 보장해주는 프로그램 있어서, 유용할 것 같아 링크를 남겨 둡니다.

http://www.microsoft.com/downloads/details.aspx?displaylang=ko&FamilyID=941B3470-3AE9-4AEE-8F43-C6BB74CD1466
저작자 표시
Posted by bomsoft
#!/usr/bin/ksh
#
# process_start 가 실행하고자 하는 프로그램이라고 가정한다.

COUNT=`ps -ef | grep process_start | grep -v grep | wc -l`

if [ $COUNT -eq 0 ]
then
  process_start
fi
Posted by bomsoft
TAG ksh, RP, UNIX

HTTP Error Code

OS 2008/03/04 10:07
HTTP Error Code (에러 코드표) 
 
100: Continue
101: Switching Protocols
200: OK, 에러없이 전송 성공
202: Accepted, 서버가 클라이언트의 명령을 받음.
203: Non-authoritavive Information, 서버가 클라이언트 요구중 일부만 정송
204: Non Content, 클라이언트 요구를 처리했으나 전송할 데이터가 없음.
205: Reset Content
206: Partial Content
300: Multiple Choisces, 최근에 옮겨진 데이터를 요청
301: Moved Permanently, 요구한 데이터를 변경된 임시 URL에서 찾았음.
302: Moved Permanently, 요구한 데이터가 변경된 URL에 있음을 명시.
303: See Other, 요구한 데이터를 변경하지 않았기 때문에 문제가 있음.
304: Not modified
305: Use Proxy
400: Bad Request, 요청실패문법상 오류가 있어, 서버가 요청사항을 이해하지 못함, 클라이언트는 수정없이 요청사항을 반복하지 않을 것이다.
401.1: Unauthorized, 권한 없음 (접속실패)이 에러는 서버에 로그온 하려는 요청사항이 서버에 들어있는 권한과 비교했을 때 맞지 않을 경우 발생한다. 
이 경우, 여러분이 요청한 자원에 접근할 수 있는 권한을 부여받기 위해 서버 운영자에게 요청해야 할 것이다. 401.2: Unauthorized, 권한 없음(서버설정으로 인한 접속 실패)이 에러는 서버에 로그온 하려는 요청사항이 서버에 들어있는 권한과 비교했을 때 맞지않을 경우 발생한다.
이것은 일반적을 으로 적절한 www-authenticate head field를 전송하지 않아서 발생한다. 401.3: Unauthorized, 권한 없음(자원에 대한 ACL에 기인한 권한 없음)이 에러는 클라이언트가 특정 자원에 접근할 수 없을 때 발생한다.
이 자원은 페이지가 될 수도 있고 , 클라이언트의 주소 입력란에 명기된 파일일 수도 있다. 아니면 클라이언트가 행당 주소로 들어갈 때 이용되는 또 다른 파일일 수도 있다.
여러분이 접근할 전체 주소를 다시 확인해 보고 웹 서버 운영자에게 여러분이 자원에 접근할 권한이 있는지를 확인해 본다. 401.4: Unauthorized, 권한 없음(필터에 의한 권한 부여 실패)이 에러는 웹 서버가 서버에 접속하는 사용자들을 확인하기 위해 설치한 필터 프로그램이 있음을 의미한다.
서버에 접속한는 데 이용되는 인증 과정이 이런 필터 프로그램에 의해 거부되었다. 401.5: Unauthorized, 권한 없음(ISA PI/CGI 애플리케이션에 의한 권한부여 실패)이 에러는 여러분이 이용하려는 웹 서버의 어드레스에 ISA PI나 CGI프로그램이 설치되어 있어 사용자의 권한을 검증하고 있음을 의미한다.
서버에 접속하는 데 이용되는 인증 과정이 이 프로그램에 의해 거부되었다. 402: Payment Required, 예약됨. 403.1: Forbidden, 금지(수행접근 금지)이 오류는 CGI나 ISAPI,혹은 수행시키지 못하도록 되어있는 디렉토리 내의 실행 파일을 수행시키려고 했을 때 발생한다. 403.2: Forbidden, 금지(읽기 접근 금지)이 에러는 브라우저가 접근한 디렉토리에 가용한 디폴트 페이지가 없을 경우에 발생한다.
아니면 Eecute나 Script로 분한이 부여된 디렉토리에 들어있는 HTML페이지를 보려했을 때 발생한다. 403.4: Forbidden, 금지(SSL 필요함)이 에러는 여러분이 접근하려는 페이지가 SSL로 보안유지 되고 있는 것일 때 발생한다.
이것을 보기 위해서 여러분은 주소를 입력하기 전에 먼저 SSL을 이용할 수 있어야 한다. 403.5: Forbidden, 금지 (SSL 128필요함)이 에러는 접근하려는 페이지가 SSL로 보안유지 되고 있는 것일 때 발생한다.
이 자원을 보기 위해서는 여러분의 브라우저가 SSL의 행당 레벌을 지원해야 한다. 여러분의 브라우저가 128비트의 SSL을 지원하는 지를 확인해 본다. 403.6: Forbidden, 금지(IP 주소 거부됨)이 에러는 서버가 사이트에 접근이 허용되지 않은 IP주소를 갖고 있는데, 사용자가 이 주소로 접근하려 했을 때 발생한다. 403.7: Forbidden, 금지(클라이언트 확인 필요)이 에러는 여러분이 접근하려는 자원이 서버가 인식하기 위해 여러분의 브라우저에게 클라이언트 SSL을 요청하는 경우 발생한다.
이것은 여러분이 자원을 이용할 수 있는 상용자임을 입증하는데 사용된다. 403.8: Forbidden, 금지 (사이트 접근 거부됨)이 에러는 웹 서버가 요청사항을 수행하고 있지 않거나, 해당 사이트에 접근하는 것이 허락되지 않았을 경우 발생한다. 403.9: Forbidden, 접근 금지(연결된 사용자수 과다)이 에러는 웹서버 BUSY 상태에 있어서 여러분의 요청을 수행할수 없을 경우에 발생한다. 잠시 후에 다시 접근해 보도록 한다. 403.10: Forbidden, 접근금지(설정이 확실 하지 않음)이 순간 웹 서버의 설정쪽에 문제가 있다. 403.11: Forbidden, 접근금지(패스워드 변경됨)이 에러는 사용자 확인단계에서 잘못된 패스워드를 입력했을 경우 발생한다. 페이지를 갱신한 후 다시 시도해 본다. 403.12: Forbidden, 접근금지(Mapper 접근 금지됨)여러분의 클이언트 인증용 맵이 해당 웹 사이트에 접근하는 것이 거부되었다.
사이트 운영자에게 클라이언트 인증 허가를 요청한다. 또한 여러분은 여러분의 클라이언트 인증을 바꿀 수도 있다. 404: Not Found, 문서를 찾을 수 없음.웹 서버가 요청한 파일이나 스크립트를 찾지 못했다. URL을 다시 잘 보고 주소가 올바로 입력되었는지 확인해본다.
- 해결방법: a.도구 ▶ 인터넷옵션 ▶ 일반 ▶ 쿠키삭제, 파일삭제, 목록지우기
b.도구 ▶ 인터넷옵션 ▶ 고급 ▶ [URL을 항상 UTF-8FH로 보냄] 체크 해제. 405: Method not allowed, 메쏘드 허용안됨Request 라인에 명시된 메쏘드를 수행하기 위해 해당 자원의 이용이 허용되지 않았다. 여러분이 요청한 자원에 적절한 MIME 타입을 갖고 있는지 확인해 본다. 406: Not Acceptable, 받아들일 수 없음요청 사항에 필요한 자원은 요청 사항으로 전달된 Acceptheader에 따라 "Not Acceptable"인 내용을 가진 Response 개체만을 만들 수 있다. 407: Proxy Authentication Required, 대리(Proxy) 인증이 필요함해당 요청이 수행되도록 proxy 서버에게 인증을 받아야 한다. proxy서버로 로그온 한 후에 다기 시도해 본다. 408: Request timeout, 요청시간이 지남 409: Conflict 410: Gone, 영구적으로 사용할 수 없음. 411: Length Required 412: Precondition Failed, 선결조건 실패Request-header field에 하나 이상에 선결조건에 대한 값이 서버에서 테스트 결과 FALSE로 나왔을 경우에 발생한다.
현재 자원의 메타-정보가 하나 이상의 자원에 적용되는 것을 막기 위한 클라이언트 선결조건이 의도되어졌다. 413: Request entity too large 414: Request-URI too long, 요청한 URI가 너무 길다요청한 URI가 너무 길어서 서버가 요청 사항의 이행을 거부했다. 이렇게 희귀한 상황은 아래와 같은 경우에만 발생한다.
클라이언트가 긴 탐색용 정보를 가지고 POST 요청을 GET으로 부적절하게 전환했다. 클라이언트가 Redirection문제를 접하게 되었다. 서버가, 몇몇 서버가 사용하고 있는 요청한 URI 를 읽고 처리하는 고정된 길이의 메로리 버퍼를 이용해 보안체계에 들어가려는 , 클라이언트에 의한 공격을 받고 있다. 415: Unsupported media type 500: Internal Server Error, 서버 내부 오류웹 서버가 요청사항을 수행할 수 없다. 다시 한 번 요청해 본다. 501: Not Implemented, 적용안됨웹 서버가 요청사항을 수행하는 데 필요한 기능을 지원하지 않는다. 에러가 발생한 URL을 확인한 후에, 문제가 지속될 경우에는 웹 서버 운영자에게 연락한다. 502: Bad gateway, 게이트웨이 상태 나쁨/서버의 과부하 상태Gateway나 proxy로 활동하고 있는 서버가 요구 사항을 접수한 upstream 서버로부터 불명확한 답변을 접수 했을 때 발생한다. 만약 문제가 지속된다면 웹 서버 운영자와 상의해 본다. 503: Service Unavailable, 외부 서비스가 죽었거나 현재 멈춘 상태 또는 이용할 수 없는 서비스서버는 현재 일시적인 과부하 또는 관리(유지,보수) 때문에 요청을 처리할 수 없다.이것은 약간의 지연후 덜게될 일시적인 상태를 말한다.Retry-After 헤더에 지연의 길이가 표시하게 될지도 모른다.
만약 Retry-After를 받지 못했다면 클라이언트는 500 응답을 위해 하고자 했는것처럼 응답을 처리해야 한다. 상태코드의 존재는 서버가 과부하가 걸릴때 그것을 사용해야한다는 것을 말하는 것이 아니다. 몇몇 서버는 접속을 거부하는 것을 바랄지도 모른다. 504: Gateway timeout 505: HTTP Version Not Supported
Posted by bomsoft
unix 시스템에서, 현재의 시스템 시간을 변수로 담아서 사용하기 위해서는 다음과 같이 해야 합니다.

CHECK_DATE=`date "+%Y.%m.%d.%H.%M.%S"`

여기서,
포맷 스트링의 맨 앞의 "+"는 포맷을 지정한다는 의미이므로 반드시 필요하고, 나머지는 년,월,일,시,분,초 의 순서입니다.
시간 표시인 %H는 12시 이후의 시간으로 13, 14, 15 ... 형식으로 보여주고,
소문자로 %h와 같이 표시하면 12 시 이후의 시간이 다시 1, 2, 3시...와 같이 표시됩니다.

$ man date

를 참조하면 보다 자세한 정보를 알 수 있습니다. unix에서 man을 자주 활용하면 도움이 될 때가 많습니다.

Posted by bomsoft
TAG ksh, RP, shell, UNIX

[프로그램 언어] ksh script

[설명] 다른 user로 switch user하면서 바로 ksh을 실행하고 그 쉘에서 EOF를 만날때 까지의 명령어 리스트를 실행하는 스크립트 샘플입니다.

[샘플 코드]

su - sample_user -c ksh <<-EOF
                export BOMSOFT_HOME=/Bomsoft
                export JAVA_HOME=/opt/java1.4
                env | grep HOME
EOF

Posted by bomsoft
TAG ksh, RP, user