반응형
tar 아카이빙 유틸리티의 GNU 버젼
tar <Operation> [옵션들]

오퍼레이션
-c : 새로운 아카이브를 만든다.
-t : 아카이브의 내용을 본다.
-x : 아카이브를 푼다.

옵션
-v : 진행된 파일 목록을 설명한다.
-f : 아카이브 파일을 사용한다.
-z : gzip을 통해 아카이브를 압축한다.
-p : tar파일을 생성or풀때 원본 파일속성(퍼미션) 유지
--exclude PATTERN: 특정 PATTERN에 해당하는 파일을 제외한다.
반응형

'리눅스 shell' 카테고리의 다른 글

ftp  (0) 2010.02.18
rsh  (0) 2010.02.18
chown  (0) 2010.02.18
cp  (0) 2010.02.05
hostname  (0) 2010.01.25
반응형
파일 소유자나 그룹을 변경한다.

문법
chown [옵션]... [owner][:[group]] 파일...

옵션
-R, --recursive : 하위 디렉터리까지 포함하여 파일 소유자나 그룹을 변경한다.

예시)
chown abc:abc ???
??? 파일의 소유자와 그룹을 abc로 바꾼다.
반응형

'리눅스 shell' 카테고리의 다른 글

rsh  (0) 2010.02.18
tar  (0) 2010.02.18
cp  (0) 2010.02.05
hostname  (0) 2010.01.25
w  (0) 2010.01.25
반응형
FreeTDS
1. TDS
(1) TDS(Tabular Data Stream)
1) 개념 및 역사
  TDS는 Tabular Data Stream의 약자로 데이터베이스 서버와 클라이언트 사이에서 데이터를 전송하는데 사용되는 응용 계층 프로토콜이다. 데이터의 테이블들을 뜻하는 구조화된 바이트 스트림을 서버로 보내기 때문에 Tabular Data Stream이라는 이름이 붙여졌다.
  TDS는 1984년 처음으로 Sybase 회사에서 개발되고 설계되었다. 네트워크 프로토콜을 통해 두 컴퓨터 사이에 데이터를 전송하는 netlib, 클라이언트 프로그램에게 API를 제공하고 netlib을 통해 서버와 통신하는 DB-LIB으로 구성되어 있었다. 또한, 데이터베이스 테이블로 데이터를 더 빠르게 불러올 수 있는 blk(bulk copy) 라이브러리도 제공하였다.
1990년 Sybase 코드에 기반을 둔 MSSQL에 대해 마이크로소프트 기술 동의 협정을 채결하였다. 마이크로 소프트는 DB-LIB API를 유지하면서 ODBC를 추가 하였고 Sybase는 Open Client의 라이브러리인 DB-LIB, CT-LIB을 개발하였다. DB-LIB은 권장하지 않지만(deprecated) 널리 사용되고 있다.
2) TDS 프로토콜
TDS 프로토콜은 다양하게 나왔는데 대부분은 문서가 공개되지 않았다. 예외적으로 Sybase가TDS 5.0 프로토콜 문서를 이용가능 하도록 했다.
TDS 4.2 Sybase와 Microsoft
Sybase/Microsoft를 나누어서 사용하는 버전
TDS 5.0 Sybase
Sybase에서 소개. TDS 5.0은 프로토콜이 확장될 수 있기 때문에 Sybase의 새로운 TDS 버전을 보기는 힘들 것이다.
TDS 7.0 Microsoft
SQL 서버 7.0에서 소개. SQL 서버 7.0의 확장된 데이터 타입을 지원. (255자 이상의 char/varchar 필드) 또한, 유니코드를 지원.
TDS 8.0 Microsoft
SQL 서버 2000에서 소개. 64비트 정수와 “variant” 데이터 타입을 지원.

(2) 관련 용어
1) netlib
두 컴퓨터 사이에 데이터를 전송하는 역할을 한다. 이를 위해 기반이 되는 네트워크 프로토콜을 다루어야 했다. 요즘처럼 TCP/IP가 어디에서든 쓰이지 않았기 때문에 netlib은 TCP/IP 외에도 DECnet, IPX/SPX, NetBEUI 같은 통신망에서도 작동하였다.
2) DB-LIB
DB-LIB은 Sybase의 첫 번째 버전 라이브러리이다. 단점으로는 많은 데이터베이스 비일관성을 보인다. 그래서 새로운 Open Client 개발을 하려면 CT-LIB을 사용하는 것이 더 좋다.
참고주소 : http://www.freetds.org/userguide/dblib.api.summary.htm
3) CT-LIB
CT-LIB은 90년대 초기 발표된 Open Client의 재작성 버전이다. API는 DB-LIB과 완전히 다르지만 더 최신 것이며 데이터베이스의 일관성(Consistency)을 보여준다. 그래서 DB-LIB을 이용한 응용 프로그램은 CT-LIB을 사용하여 컴파일이 어렵고 포팅하기 위해 상당한 노력이 필요하다. DB-LIB은 더 이상 개발되지 않을 것이기 때문에 결국 새로운 응용프로그램은 CT-LIB을 사용하는 것이 좋다.
참고주소 : http://www.freetds.org/userguide/ctlib.api.summary.htm
4) ODBC
DBMS를 사용하기 위한 표준 소프트웨어 API 메소드를 제공한다. 각 데이터베이스의 차이는 ODBC 드라이버에 의해서 흡수되기 때문에 유저는 ODBC에 정해진 순서에 따라서 프로그램을 쓰면 어떠한 데이터베이스 관리 시스템에 관리되고 있는지 의식할 필요 없이 데이터베이스에 접근 할 수 있다.

2. FreeTDS
(1) FreeTDS
 TDS 프로토콜을 다시 구현한 무료 소프트웨어 라이브러리이다. DB-LIB이나 CT-LIB을 대신하여 사용할 수 있고 ODBC 라이브러리를 포함한다. 일반적으로 LGPL 라이선스가 적용되어 소스로부터 라이브러리를 컴파일하여 다른 응용프로그램이 FreeTDS 라이브러리를 링크하여 사용할 수 있도록 한다.
 스크립트 언어를 위해 FreeTDS는 펄, 파이썬, 루비, PHP등과 같은 언어의 모듈과 결합할 수 있다. 또한, jTDS는 FreeTDS의 자바 구현 버전이며 소스포지에서 사용가능하며 jBCP는 jTDS에서 BCP(Bulk Copy Program) 기능을 포함한다.
 현재 TDS 4.2, 5.0, 7.0, 8.0이 구현되었고 Sybase 뿐만 아니라 MSSQL 서버와도 통신할 수 있다. JDBC 드라이버도 BSD 라이선스에 의해 배포되며 다운로드 페이지(http://www.freetds.org/software.html)에서 받을 수 있다.
 FreeTDS는 다양한 용도로 사용할 수 있다. 유닉스/리눅스 웹서버를 통해 웹으로 SQL 서버에 저장된 데이터를 표현할 수 있고, NT에서 Unix로 SQL 서버 데이터베이스 코드를 이식할(port) 수 있고, 유닉스 소스로부터 SQL 서버로 데이터를 가지고 올 수 있으며, native 드라이버 없이 플랫폼에 대한 데이터베이스 접근을 제공한다.
(2) freetds.conf 파일 설정
1) 역할
파일 형식은 win.ini와 비슷하다. 하는 일은 데이터서버 이름(당신의 프로그램)을 기계이름(네트워크)으로 관련시킨다. 
configure 옵션의 –syscondir에 의해 freetds.conf의 위치가 결정된다. configure의 default 위치는 ‘/usr/local/etc/’ 이다.
freetds.conf는 2개의 섹션으로 구성된다. [global] 섹션은 모든 데이터 서버에 영향을 주지만 [dataserver] 섹션에서 오버라이딩할 수 있다.


2) 설정 값의 뜻
tds version= (4.2, 5.0, 7.0, 8.0) 
접속할 때 프로토콜 버전.
host= (호스트이름이나 IP주소)
데이터서버가 실행 중인 호스트.
port= (1433, 2638, 5000)
데이터서버가 사용할 포트 번호. 
FreeTDS는 TDS 프로토콜 버전에 따라 default 포트를 정한다. 5000은 TDS 5.0, 1433은 
다른 프로토콜에 사용.
참고주소 : http://www.freetds.org/userguide/freetdsconf.htm

(1)   DB-LIB을 이용하여 컴파일 하기

1)     빌드하기 위해 필요한 파일들

#include <sqlfront.h> /* sqlfront.h always comes first */

#include <sybdb.h>    /* sybdb.h is the only other file you need */

libsybdb.a 또는 libsybdb.so ( /usr/local/lib 폴더에 있습니다.)

 

2)     빌드 방법

cc -I /usr/local/include -Wl,-L/usr/local/lib -Wl,-R/usr/local/lib (소스파일) -lsybdb -o (실행파일)

-Idir : 헤더 파일이 검색되기 위한 리스트의 디렉터리를 추가한다.

-llibrary : 링킹할 때 library의 이름을 가진 라이브러리를 찾는다.

-Ldir : -l()에 대해 검색되기 위한 리스트의 디렉터리를 추가한다.

-ofile : 출력파일을 정하기 위해 file명을 적어줄 수 있다. (없으면 default로 출력파일은 a.out)

참고주소 : http://www.freetds.org/userguide/samplecode.htm

반응형
반응형
파일과 디렉터리를 복사한다.

문법
cp [옵션]... [-T] 원본 목적지
cp [옵션]... 원본... 디렉터리
cp [옵션]... -t 디렉터리 원본

원본에서 목적지 혹은 원본(들)에서 디렉터리로 복사한다.

옵션
-R, -r, --recursive
디렉터리들을 재귀적으로 복사한다. (하위 디렉터리들 까지 복사)
-p
--preserve=mode,ownership,timestamps와 같은 뜻이다
--preserve
특정 속성들을 유지한다. 만약 추가적인 속성들(links, all)이 가능하다면 보안 컨텍스트도 유지한다.
(디폴트: mode, ownership, timestamps)
반응형

'리눅스 shell' 카테고리의 다른 글

tar  (0) 2010.02.18
chown  (0) 2010.02.18
hostname  (0) 2010.01.25
w  (0) 2010.01.25
uptime  (0) 2010.01.25
반응형
시스템의 호스트네임을 출력하거나 변경한다.

문법
hostname [-v] [-a] [--alias] [-d] [--domain] [-f] [--fqdn] [-i] [--ip-address] [--long] [-s] [--short] [-y] [--yp] [--nis] [-n] [--node]

예시
현재 시스템의 호스트네임 확인
[root@host3 root]# hostname
host3.superuser.co.kr
[root@host3 root]#

호스트네임 변경
hostname [변경할호스트]

v옵션 실행예시
# hostname -v
gethostname()='######'
######

반응형

'리눅스 shell' 카테고리의 다른 글

chown  (0) 2010.02.18
cp  (0) 2010.02.05
w  (0) 2010.01.25
uptime  (0) 2010.01.25
last  (0) 2010.01.25
반응형
누가 로그인되었고 무엇을 하는지 알려준다.
서버에 접속한 사용자의 접속정보 및 작업정보를 확인하는 명령어
예시)
who am i : 접속한 나의 터미널 접속상태를 확인한다.
반응형

'리눅스 shell' 카테고리의 다른 글

cp  (0) 2010.02.05
hostname  (0) 2010.01.25
uptime  (0) 2010.01.25
last  (0) 2010.01.25
chattr  (0) 2010.01.25
반응형
시스템이 얼마나 오래동안 실행되었는지 알려준다.

보여주는 내용
1. 현재시간
2. 시스템이 부팅후에 얼마동안 꺼지지 않고 운용되었는가?
3. 현재 시스템에 로그인된 사용자수(/var/run/utmp파일을 참조함)
4. 각각 1분, 5분, 15분 동안의 시스템 평균 부하율
반응형

'리눅스 shell' 카테고리의 다른 글

hostname  (0) 2010.01.25
w  (0) 2010.01.25
last  (0) 2010.01.25
chattr  (0) 2010.01.25
chmod  (0) 2010.01.25
반응형
사용자들 중에서 마지막으로 로그인된 목록을 보여준다.
서버를 이용하는 각 계정사용자들의 로그인 정보를 보여준다.

문법
last [-R] [-num] [ -n num ] [-adiox] [ -f file ] [ -t YYYYMMDDHHMMSS ] [name...] [tty...]

예시
[root@host3 log] last 
모든 계정들의 접속정보를 볼 수 있다.
[root@host3 log] last 아이디
아이디의 접속정보만 보여준다.
[root@hotst3 log] last -숫자
숫자만큼의 줄 수로 결과를 보여준다.
[root@hotst3 log] last -a
마지막 열에 호스트이름을 출력한다.
반응형

'리눅스 shell' 카테고리의 다른 글

w  (0) 2010.01.25
uptime  (0) 2010.01.25
chattr  (0) 2010.01.25
chmod  (0) 2010.01.25
nice  (0) 2010.01.20
반응형

리눅스 ext2파일 시스템에서 파일 속성을 바꾼다.
문법
chattr [-RV] [-v 버젼] [모드] 파일...

옵션
-R : 대상이 디렉터리일 경우 그 하위 경로에 있는 파일과 디렉터리까지 모드를 적용한다.
-V : chattr의 출력과 프로그램 버젼을 출력한다.
-v 버젼
파일의 버젼/제너레이션 번호를 설정한다.

모드
+ : 모드를 추가한다.
- : 모드를 제거한다.
= : 모드를 설정한다. set
i : 파일을 read-only로만 열 수 있게 설정한다.  링크도 허용하지 않고 루트만이 이 모드를 제거할 수 있다.
a : 파일의 수정을 할 때 내용을 추가(append)할 수만 있다. 단, vi편집기로는 내용을 추가할 수 없다.

반응형

'리눅스 shell' 카테고리의 다른 글

uptime  (0) 2010.01.25
last  (0) 2010.01.25
chmod  (0) 2010.01.25
nice  (0) 2010.01.20
chroot  (0) 2010.01.20
반응형
파일 접근 권한을 바꾼다.

문법
chmod [옵션]... 모드[,모드]... 파일...
chmod [옵션]... 8진-모드 파일...
chmod [옵션]... --reference=참조파일 파일...

옵션
-c : 올바르게 변경된 파일들만 -v옵션을 적용하여 자세히 보여준다.
-f : 가능한 불필요한 메세지를 보여주지 않고 간략하게 보여준다.
-v : 실행과정을 자세하게 보여준다.
-R : 디렉터리와 그 안에 존재하는 서브디렉터리들까지 모두 적용한다.

모드
 퍼미션 일반적인 의미   파일  디렉터리
 r 읽기권한   파일을 읽을 수 있음 디렉터리의 내용을 볼 수 있음
(ls로 파일리스트 확인 가능) 
 w 쓰기권한  파일을 저장, 삭제할 수 있음  디렉터리에 파일저장, 디렉터리이름 변경, 삭제 등 가능
 x 실행권한   파일을 실행할 수 있음  디렉터리에 접근할 수 있음
(cd로 접근가능, ls로 리스트 불가)
 s  setUID, setGID 권한  파일소유자(setUID), 그룹소유자(setGID)의 권한으로 실행함.
 t  Sticky Bit 권한  공유디렉터리로 사용됨
u : 소유자(user)를 의미함
g : 그룹(group)을 의미함
o : 다른 사용자(others)들을 의미함
a : 모두(all)를 의미함(디폴트)
+ : (rwxst)권한을 부여한다.
- : (rwxst)권한을 제거한다.
반응형

'리눅스 shell' 카테고리의 다른 글

last  (0) 2010.01.25
chattr  (0) 2010.01.25
nice  (0) 2010.01.20
chroot  (0) 2010.01.20
find & grep  (0) 2010.01.19

+ Recent posts