ncftp 를 이용한 백업 스크립트ncftp 를 이용한 백업 스크립트

Posted at 2013. 9. 10. 08:41 | Posted in Server
반응형

ncftp를 이용한 백업 스크립트입니다. 

# vi /root/backup.sh 
#!/bin/bash 

#### 공통설정 
export Today="`date '+%y-%m-%d'`" 
backup_dir="/home/file/backup" 
backup_day="1" # 보관일(1일) 

#### 디비설정 
DB_user="root"; 
DB_pass="비밀번호"; 


#### 원격설정 
FTP_addr="접속아이피"; 
FTP_user="아이디"; 
FTP_pass="비밀번호"; 


########### 오래된 백업데이터 삭제 
dirlists=`/bin/ls -t $backup_dir 2>/dev/null` 
i=1 
for dir in $dirlists ; do 
  if [ "$i" -ge $backup_day ] ; then 
    /bin/rm -rf "$backup_dir/$dir" 
  fi 
  i=$(($i+1)) 
done 

####### 새로운 디렉토리 생성 
if [ ! -d "${backup_dir}/${Today}" ] 
then 
/bin/mkdir -p ${backup_dir}/$Today 
/bin/mkdir -p ${backup_dir}/$Today/homedir 
/bin/mkdir -p ${backup_dir}/$Today/databass 
/bin/mkdir -p ${backup_dir}/$Today/system 
fi 

####### databass를 사용자별로 백업을 한다. 
for database in `mysqlshow -u ${DB_user} -p${DB_pass} | awk -F" " '{ print $2 }' | grep -v "^$" |grep -v "Databases"` ; do 
  mysqldump -u ${DB_user} -p${DB_pass}  "${database}" ${table} > ${backup_dir}/${Today}/databass/${database}.sql 
done 

####### 시스템 디렉토리를 백업한다 
tar cvfpz ${backup_dir}/$Today/system/usr.local.tar.gz /usr/local 
tar cvfpz ${backup_dir}/$Today/system/etc.tar.gz /etc 
tar cvfpz ${backup_dir}/$Today/system/var.named.tar.gz /var/named 

####### home 디렉토리에 사용자별로 백업을 한다. 
dirlists=`/bin/ls -t /home 2>/dev/null` 
for dir in $dirlists ; do 
  tar cvfpz ${backup_dir}/$Today/homedir/$dir.tar.gz /home/$dir 
done 

####### 링크를 만들어 준다. 
rm -rf ${backup_dir}/today 
ln -s ${backup_dir}/$Today /${backup_dir}/today 

####### 원격 데이타백업을 시작한다. 
ncftp -u${FTP_user} -p${FTP_pass} ${FTP_addr} << ./backup 
put -R ${backup_dir}/$Today 
bye 

  
* 파일 경로 주의하시고 이메일주소 변경해서 사용하세요. 


# crontab -e 

05 00 * * * '/usr/bin/rdate -s time.bora.net && /sbin/clock -w' 
00 04 * * * su - root -c '/root/backup.sh | mail -s "시스템 백업 결과보고"e-mail 주소 '; 



반응형

//

Linux에 아파치 서버 설치하기Linux에 아파치 서버 설치하기

Posted at 2013. 9. 10. 08:35 | Posted in Server
반응형

오늘은 linux에서 apache 설치하는 방법을 알려 드리겠습니다.


Apache Httpd (2.2.3) 설치 
1. gcc compiler 설치 
    1.1 gcc compiler 설치 - System Administrator에 부탁해서 CD설치를 권장합니다. 
    1.2 gcc PATH에 등록 

2. apache httpd 소스 다운로드(http://www.apache.org)&Compile(httpd-2.2.3 다운 받은 directory로 이동후 실시) 

    2.1 ./configure <enter> 
    2.2 make <enter> 
    2.3 make install <enter> - root 권한 필요함 
    2.4 sh buildconf - 수행하기전 autoconf, libtool 등 유틸이 설치되었는지 확인 
        2.4.1 autoconf 설치 
            2.4.1.1 autoconf download (http://ftp.gnu.org/gnu/autoconf/) 
            2.4.1.2 ./configure <enter> 
            2.4.1.3 make <enter> 
            2.4.1.4 make install <enter> - root 권한 필요함 
        2.4.2 libtool 설치 
            2.4.2.1 libtool download (ftp://ftp.gnu.org/gnu/libtool/) 
            2.4.2.2 ./configure <enter> 
            2.4.2.3 make <enter> 
            2.4.2.4 make install <enter> - root 권한 필요함 
    2.5 ./configure --with-mod_jk <enter> 
    2.6 make <enter> 
    2.7 make install <enter> 

* 2.5 부분은 tomcat과 ajp connector를 연결하기 위해서 새로 컴파일하는 과정 


반응형

'Server' 카테고리의 다른 글

호스트네임 바꾸기  (0) 2013.09.11
ncftp 를 이용한 백업 스크립트  (0) 2013.09.10
etc/fstab 파일 설명  (0) 2013.09.10
vsftp에서 500 OOPS : cannot change directory 오류가 나올때  (0) 2013.09.05
vsftpd 설정  (0) 2013.09.04

//

etc/fstab 파일 설명etc/fstab 파일 설명

Posted at 2013. 9. 10. 08:31 | Posted in Server
반응형

/etc/fstab은 파일 시스템을 구성하는 파티션이나 리무버블 디스크 등의 마운트 포인트가 기록되어 있는 파일이다 

형식 : device  mount_point  Fs_type  options    dump_freq  fsck_order 

- device 

LABLE 사용시 : /, /boot, /home, /usr, /var, /etc ... 

장치명 사용시 : /dev/sda1, /dev/sda2, /dev/sdb1, /dev/sdb2 ... 


- mount_point: /, /boot, /home, /usr, /var, /etc, /mnt/cdrom ... 

- Fs_type : 파일 시스템 종류 

ext, ext2, ext3, iso9660, nfs, swap, ufs, ntfs ... 


- options 

defaults : mount option을 나타내며 여러 개의 옵션을 지정할 때는 " , " 로 구분한다. 이 옵션은 다음 옵션을 모두 포함하는 옵션이다 

rw(read write), nouser(일반 사용자는 마운트 할수 없다), auto(부팅하면서 자동으로 마운트), exec(해당 파일 시스템에 실행 권한이 주어졌을때 실행 가능하도록 함), suid(set uid가 설정되어 사용되도록 함) 

auto : 부팅하면서 자동으로 마운트 

noauto : 부팅하면서 자동으로 마운트 하지 않는다 

noexec : 파일시스템에 들어간 파일들이 실행 설정 되어 있어도 실행하지 않는다 

nosuid : uid와 gid가 적용되지 않는다 

ro : 읽기 전용 

usrquota, grpquota(사용자, 그룹별로 quota 마운트 설정) 


- dump_freq 

0 : dump로 데이터 백업이 되지 않는 파일 시스템을 의미 

1 : dump로 데이터 백업이 가능한 파일 시스템을 의미 


- fsck_order 

0 : 부팅시에 파일 시스템 점검을 하지 않음 

1 : 루트 파일 시스템으로서 부팅시에 파일 시스템 점검을 함 

2 : 루트 파일 시스템 이외의 파일 시스템으로서 부팅시에 파일 시스템 점검을 함 



반응형

'Server' 카테고리의 다른 글

ncftp 를 이용한 백업 스크립트  (0) 2013.09.10
Linux에 아파치 서버 설치하기  (0) 2013.09.10
vsftp에서 500 OOPS : cannot change directory 오류가 나올때  (0) 2013.09.05
vsftpd 설정  (0) 2013.09.04
apache 재시작  (0) 2010.10.07

//

vsftp에서 500 OOPS : cannot change directory 오류가 나올때vsftp에서 500 OOPS : cannot change directory 오류가 나올때

Posted at 2013. 9. 5. 08:33 | Posted in Server
반응형

vsftpd(vsftp 데몬)의 상태를 보기
service vsftpd status

iptables(방화벽)의 상태를 보기
service iptables status

반응형

'Server' 카테고리의 다른 글

Linux에 아파치 서버 설치하기  (0) 2013.09.10
etc/fstab 파일 설명  (0) 2013.09.10
vsftpd 설정  (0) 2013.09.04
apache 재시작  (0) 2010.10.07
apache의 httpd.conf 설정 팁  (0) 2010.10.07

//

vsftpd 설정vsftpd 설정

Posted at 2013. 9. 4. 15:25 | Posted in Server
반응형

# vi vsftpd.conf

#chroot_list_enable=YES --------------------------------------주석해제
# (default follows)
#chroot_list_file=/etc/vsftpd/chroot_list ------------------주석해제
#chroot_local_user=YES ----------------------------------------추가

자동실행

 chmod 755 /etc/rc.d/init.d/vsftpd
[root@localhost vsftpd]# chkconfig --add vsftpd
[root@localhost vsftpd]# chkconfig --level 5 vsftpd on
[root@localhost vsftpd]# chkconfig --level 3 vsftpd on
[root@localhost vsftpd]# chkconfig --list|grep vsftpd
 

F.T.P 접속시  에러

500 OOPS: cannot change directory:/home/jooken
500 OOPS: child died

원격 호스트에 의해 연결이 닫혔습니다.

# service vsftpd stop

# vsftpd

# setsebool -P ftp_home_dir=1

# modprobe ip_conntrack_ftp

# service iptables restart 




vsftpd.conf


반응형

//

apache 재시작apache 재시작

Posted at 2010. 10. 7. 08:23 | Posted in Server
반응형

1.telnet 접근 user 계정

2.root 권한 변경

3./usr/local/apache/bin 이동

4. ./apachectl stop

5. ./apachectl start

혹은 ./apachectl restart

이렇게 해주셔도 됩니다..

반응형

//

apache의 httpd.conf 설정 팁apache의 httpd.conf 설정 팁

Posted at 2010. 10. 7. 08:22 | Posted in Server
반응형
httpd.conf 

apache컴파일하기 전에 
# vi 아파치경로/server/mpm/prefork/prefork.c 
[EDITOR]#define DEFAULT_SERVER_LIMIT 256 을 
[EDITOR]#define DEFAULT_SERVER_LIMIT 1280 으로 수정 
저장하고 아웃 
# vi 아파치 경로/server/mpm/worker/worker.c 
[EDITOR]#define DEFAULT_SERVER_LIMIT 16 을 
[EDITOR]#define DEFAULT_SERVER_LIMIT 20 으로 수정 
저장하고 아웃 하셔야 합니다. 

설정 개념 

먼저, KeepAlive On 으로 세팅합니다. KeepAlive 는 접속 유지 개념으로, 만약 접속중에 다른 이미지를 호출하면 새로운 연결을 만들지 않고 (새로운 쓰레드나 프로세스를 띄우지 않고) 그냥 있는 연결로 이미지를 보여주겠다는 개념인데요 
이게 중요한 이유가, <img src=xxx> 인 경우 그때마다 연결을 새로 만들거든요.. KeepAlive Off 인경우 말입니다. 
그런데..KeepAlive 는 양날의 검인것이, KeepAliveTimeout 에 적혀 있는 시간이 지날때까지 
접속이 안끊깁니다. 즉, 계속 연결이 살아 있으니, 동시접속 한계에 부딪치게 되죠. 
따라서 

KeepAlive On 
KeepAliveTimeout 2 
(2초간 접속을 끊지 않고 기다린다..) 
이렇게 설정하는것이 최상입니다. 경우에 따라서는 KeepAliveTimeout 1 이렇게 1초만 설정하기도 하죠. 
1초~2초 사이를 줍니다. 

1초, 2초의 기준은 사이트를 직접 운영하면서, 스코아 보드를 보면서 셋팅해야 되요. 이정도가 적당하겠구나.. 하구요 

그다음 중요한 설정이 
Timeout 30 
이부분입니다. 아파치 디펄트는 Timeout 300 으로 되어 있는데요 
"아무 신호가 들어오지 않더라도 접속을 유지시켜 주는 시간" 을 말합니다. 
대형사이트의 경우 Timeout 10 이런식으로 아주 작게 잡습니다. 
dos 공격을 방지하기 위해서죠. 

그다음.. 설정이, prefork 이냐 worker 이냐에 따라 다른데요 
(이건 컴파일때 설정..) 
참고로 fork 란, 아파치 버젼 1.3 대에서 사용하는 방법으로 
실행중인 프로세스를 똑같이 복사해 냅니다. 이때 메모리까지 똑같이 복사하기 때문에, 프로세스가 소비하는 메모리를 그대로 소비합니다. 
(메모리를 많이 먹죠) 

worker 는 2.0 대에 나온 개념으로 모든걸 쓰레드로 처리하면, 굉장히 불안해 집니다. 
단 하나의 쓰레드에 문제가 생기면, 해당 쓰레드가 물려있는 모든 프레세스들이 다 문제가 생깁니다. 
아파치가 궁리끝에 내어놓은 대안은 "하나의 프로세스가 만들어내는 최대 쓰레드 갯수는 64개로 제한한다" 입니다. 
즉, 쓰레드 하나가 문제 생겨도 해당 64 개 만 문제가 생기지 나머지는 괜찮은 겁니다. 
ServerLimit 20 --> 서버 갯수를 설정합니다. 
StartServers 20 --> 아파치를 처음 시작할때 생성하는 서버 갯수입니다. 
MaxClients 500 --> ThreadsPerChild * StartServers 값입니다. 
ThreadsPerChild 25 --> 서버 하나가 만들어 낼수 있는 쓰레드 갯수입니다. 최대 64개 입니다. 
MinSpareThreads --> 서버 하나가 만들어 낼수 있는 쓰레드의 최소 갯수입니다. 보통은 ThreadsPerChild 와 맞추어 줍니다. 
MaxSpareThreads --> 시스템 전체에서 만들어 낼수 있는 쓰레드 갯수의 최대치 입니다. 
ThreadsPerChild * StartServers 값이며, 보통 MaxClients 와 맞추어 줍니다. 
MaxRequestsPerChild --> 서버 하나가 만들어 내는 접속의 최대치 입니다. 0 일경우 무한대 이며, 숫자를 적으면 그 숫자만큼 접속되고 나면 서버를 죽였다 살립니다. 

MaxRequestsPerChild란? 
웹서버란게 100% 완벽하지 않을수 있습니다. 
그경우, 메모리 누수.. 등 메모리 에러가 날수 있는데요 
그런경우 MaxRequestsPerChild 에 값을 적어 놓으면 MaxRequestsPerChild 1000 이렇게 설정하면 클라이언트 접속을 1000 번만 처리하고 죽어 버립니다. 
물론 죽고난 다음 다시 살아나죠.. 
그렇게 하면, 에러를 최소화 할수 있는데요 
보통은 0 으로 해 놓고 무제한 처리하게 합니다. 자꾸 죽었다 살아나면, 그것도 시스템 부하니까요. 

결국 ServerLimit 와 ThreadsPerChild 이 두개 값으로 아파치 동시 접속자수를 결정 짓습니다. 
나머지는 곱하기 해서 구하죠... 
그리고 곱하기 한 값을, 다른데 적어 두고.. 비슷한 내용은 똑같이 맞춰 버리고 이렇게 하면 셋팅 완료.. 

ExtendedStatus On 

SetHandler server-status 
Order deny,allow 
# Deny from all 
# Allow from .example.com 


이부분을 찾아서, 모든 사용자에게 server-status 를 허용한다고 셋팅한 다음에 

http://도메인/server-status 

이렇게 하면 아파치 상태를 직방으로 볼수 있습니다. 

W_________K_K__________K_....................................... 
______K_K_C_____KK__C____....................................... 
_WKK___K_________________....................................... 
C__KK__________K_________....................................... 
K_____K__W________W______....................................... 
_K_______K_________K____W....................................... 
______KW_________CK__K___....................................... 
__K_CWKK_________________....................................... 
_________W_______K___K__K....................................... 
____________W_K____K__K__....................................... 
_____C__CW__WK__________W....................................... 
______K__K__CC_____C_____....................................... 
___CW___________K_K___K_C....................................... 
__K__K______________C__W_....................................... 
KW_K___________K_W___K_K_....................................... 
________K__K_________K___....................................... 
_W__C___________K________....................................... 
________CK___K______K____....................................... 
_C____W_CK_____KK______K_....................................... 
__KK___K______K____C_____....................................... 

Scoreboard Key: 
"_" Waiting for Connection, "S" Starting up, "R" Reading Request, 
"W" Sending Reply, "K" Keepalive (read), "D" DNS Lookup, 
"C" Closing connection, "L" Logging, "G" Gracefully finishing, 
"I" Idle cleanup of worker, "." Open slot with no current process 

한줄에 서버 1개 입니다.. 


출처 : http://www.phpschool.com/gnuboard4/bbs/board.php?bo_table=tipntech&wr_id=58809
반응형

'Server' 카테고리의 다른 글

vsftpd 설정  (0) 2013.09.04
apache 재시작  (0) 2010.10.07
.htaccess를 이용한 특정 디렉토리 접근 관리하기  (0) 2010.10.07
Mysql 사용자 추가  (0) 2010.10.05
F.T.P 사용자 격리 설정  (0) 2010.10.05

//

.htaccess를 이용한 특정 디렉토리 접근 관리하기.htaccess를 이용한 특정 디렉토리 접근 관리하기

Posted at 2010. 10. 7. 08:21 | Posted in Server
반응형

서버안에
.htpasswd 파일을 만들어주고

디렉토리 안에 
.htaccess 파일을 만들면 끝...



1. 먼저 인증할 user와 password를 설정합니다.

/usr/local/apache/bin/htpasswd -c /지정할경로/.htpasswd 등록할ID

-> 패스워드를 입력합니다.

그럼 해당 경로에 .htpasswd 파일이 생성됩니다.

일반적으로 사용하는 경로입니다.
/usr/local/apache/htdocs/.htpasswd 

2번째 패스워드부터는 -c 를 빼고 합니다. (주의)
/usr/local/apache/bin/htpasswd /지정할경로/.htpasswd 등록할ID

이렇게 하면 패스워드가 계속 추가됩니다.

하지만, 조금 귀찮더라도 
.htpasswd 
.htaccess 
이 2개의 파일을 각 계정 안에 있는 임의의 하나의 디렉토리 안에 만들고 
개별 경로를 따로 지정해 주는 쪽이 보안에 유리합니다... ;;
참... 디렉토리 권한은 701로 파일 권한은 644로 해 주세요... ^^*




2. 그리고 vi나 기타 에디터를 이용하여 .htaccess 파일을 생성합니다.

--------------------------------------------------------------------
AuthUserFile /지정한 경로/.htpasswd
AuthName "인증시 나타날 제목"
AuthType Basic

<Limit GET POST>
require valid-user
</Limit>
--------------------------------------------------------------------



여기서 부터 아래쪽은 트래픽 확인을 위한 관리를 위한 응용입니다.

아파치 설정파일 httpd.conf 파일
마지막 부분에 다음과 같이 입력합니다.

--------------------------------------------------------------------
# 사용자 트래픽 제한
<IfModule mod_throttle.c>
ThrottlePolicy None

<Location /throttle-status>
SetHandler throttle-status

# 여기서 부터 --

AuthName "인증시 나타날 제목"
AuthType Basic
AuthUserFile /지정한경로/.htpasswd
require valid-user

# 여기까지 ---

</Location>


<Location /throttle-me>
SetHandler throttle-me
</Location>

</IfModule>

반응형

'Server' 카테고리의 다른 글

apache 재시작  (0) 2010.10.07
apache의 httpd.conf 설정 팁  (0) 2010.10.07
Mysql 사용자 추가  (0) 2010.10.05
F.T.P 사용자 격리 설정  (0) 2010.10.05
리눅스 백업 스크립트  (0) 2010.10.05

//

Mysql 사용자 추가Mysql 사용자 추가

Posted at 2010. 10. 5. 13:14 | Posted in Server
반응형
CREATE DATABASE DBNAME; 

USE mysql; 

INSERT INTO user (host, user, password) VALUES ('localhost','아이디',password('패스워드')); 

INSERT INTO db (Host, Db, User, Select_priv, Insert_priv, Update_priv, Delete_priv, Create_priv, Drop_priv) 
VALUES('%', '데이터베이스', '아이디', 'Y', 'Y', 'Y', 'Y','Y','Y'); 


GRANT ALL on 데이터베이스.* TO 아이디; 

FLUSH PRIVILEGES;
반응형

//

F.T.P 사용자 격리 설정F.T.P 사용자 격리 설정

Posted at 2010. 10. 5. 13:14 | Posted in Server
반응형
반응형

//