Linux Admin-백업 및 복구
표준 백업 계획을 배포하기 위해 CentOS에 특정한 방법을 탐색하기 전에 먼저 표준 수준 백업 정책에 대한 일반적인 고려 사항에 대해 논의하겠습니다. 우리가 익숙해지기를 원하는 첫 번째 것은3-2-1 backup rule.
3-2-1 백업 전략
업계 전반에 걸쳐 3-2-1 백업 모델이라는 용어를 자주 듣게됩니다. 이것은 백업 계획을 구현할 때 매우 좋은 접근 방식입니다. 3-2-1은 다음과 같이 정의됩니다.3데이터 사본; 예를 들어 작업 사본이있을 수 있습니다. rsync를 사용하여 중복성을 위해 설계된 CentOS 서버에 복사 순환 된 오프 사이트 USB 백업은 백업 서버의 데이터에서 만들어집니다.2다른 백업 매체. 이 경우 실제로 세 가지 백업 매체가 있습니다. 노트북 또는 워크 스테이션의 SSD 작업 복사본, RADI6 어레이의 CentOS 서버 데이터, USB 드라이브에있는 오프 사이트 백업입니다.1오프 사이트 데이터 사본; 야간에 USB 드라이브를 오프 사이트로 교체하고 있습니다. 또 다른 현대적인 접근 방식은 클라우드 백업 공급자 일 수 있습니다.
시스템 복구
베어 메탈 복원 계획을은 단순히 그대로 모든 데이터를 온라인으로 중요한 시스템을 얻을 수있는 CentOS는 관리자에 의해 배치 계획입니다. 시스템 장애가 100 %이고 과거의 모든 시스템 하드웨어가 손실되었다고 가정 할 때 관리자는 가동 중지 시간을 최소화하면서 손상되지 않은 사용자 데이터로 가동 시간을 달성 할 계획을 가지고 있어야합니다. Linux에서 사용되는 모 놀리 식 커널은 실제로 Windows보다 시스템 이미지를 사용하여 베어 메탈 복원을 훨씬 쉽게 만듭니다. Windows가 마이크로 커널 아키텍처를 사용하는 경우.
전체 데이터 복원 및 베어 메탈 복구는 일반적으로 작업, 구성된 주요 운영 서버의 프로덕션 디스크 이미지, 3-2-1 규칙을 준수하는 사용자 데이터의 중복 백업을 포함한 방법의 조합을 통해 수행됩니다. 신뢰할 수있는 회사 직원에 대한 액세스가 제한된 안전한 내화 금고에 저장 될 수있는 일부 민감한 파일도 있습니다.
기본 CentOS 도구를 사용 하는 다단계 베어 메탈 복원 및 데이터 복구 계획 은 다음으로 구성 될 수 있습니다.
dd는 구성된 서버의 프로덕션 디스크 이미지를 만들고 복원합니다.
모든 사용자 데이터의 증분 백업을 만들기위한 rsync
tar 및 gzip을 사용하여 관리자의 암호 및 메모와 함께 암호화 된 파일 백업을 저장합니다. 일반적으로 이것은 USB 드라이브에 저장되고 암호화되어 선임 관리자가 액세스하는 금고에 잠글 수 있습니다. 또한 현재 관리자가 복권에 당첨되어 맑은 섬 어딘가로 사라질 경우 다른 사람이 중요한 보안 자격 증명을 알 수 있습니다.
하드웨어 오류 또는 재해로 인해 시스템이 충돌하는 경우 작업 복원의 다른 단계는 다음과 같습니다.
구성된 베어 메탈 이미지로 작업 서버 구축
백업에서 작업 서버로 데이터 복원
처음 두 작업을 수행하는 데 필요한 자격 증명에 물리적으로 액세스 할 수 있습니다.
파일 수준 백업에 rsync 사용
rsync 는 파일 디렉토리를 로컬 또는 다른 서버에 동기화하는 데 유용한 유틸리티입니다. rsync 는 시스템 관리자가 수년간 사용해 왔기 때문에 데이터 백업을 위해 매우 정제되었습니다. 저자의 의견으로는 동기화 의 가장 좋은 기능 중 하나 는 명령 줄에서 스크립팅 할 수 있다는 것입니다.
이 튜토리얼에서는 다양한 방법으로 rsync에 대해 논의 할 것입니다.
- 몇 가지 일반적인 옵션을 탐색하고 논의
- 로컬 백업 생성
- SSH를 통한 원격 백업 생성
- 로컬 백업 복원
rsync목적에 따라 이름이 지정되었습니다. Remote Sync 는 강력하고 유연하게 사용할 수 있습니다.
다음은 ssh를 통한 기본 rsync 원격 백업입니다.
MiNi:~ rdc$ rsync -aAvz --progress ./Desktop/ImportantStuff/
[email protected]:home/rdc/ Documents/RemoteStuff/
[email protected]'s password:
sending incremental file list
6,148 100% 0.00kB/s 0:00:00 (xfr#1, to-chk=23/25)
2017-02-14 16_26_47-002 - Veeam_Architecture001.png
33,144 100% 31.61MB/s 0:00:00 (xfr#2, to-chk=22/25)
A Guide to the WordPress REST API | Toptal.pdf
892,406 100% 25.03MB/s 0:00:00 (xfr#3, to-chk=21/25)
Rick Cardon Technologies, LLC..webloc
77 100% 2.21kB/s 0:00:00 (xfr#4, to-chk=20/25)
backbox-4.5.1-i386.iso
43,188,224 1% 4.26MB/s 0:08:29
sent 2,318,683,608 bytes received 446 bytes 7,302,941.90 bytes/sec
total size is 2,327,091,863 speedup is 1.00
MiNi:~ rdc$
다음 동기화는 LAN을 통해 거의 2.3GB의 데이터를 전송했습니다. rsync의 장점은 파일 단위로 블록 수준에서 점진적으로 작동한다는 것입니다. 즉, 1MB 텍스트 파일에서 두 문자 만 변경하면 다음 동기화시 LAN을 통해 하나 또는 두 개의 블록 만 전송됩니다!
또한 CPU 사용률을 낮추기 위해 더 많은 네트워크 대역폭을 사용하기 위해 증분 기능을 비활성화 할 수 있습니다. 1Gb 전용 Backup-Lan에서 10 분마다 여러 개의 10MB 데이터베이스 파일을 지속적으로 복사하는 경우이 방법이 권장 될 수 있습니다. 이유는 다음과 같습니다. 이는 항상 변경되며 10 분마다 점진적으로 전송되며 원격 CPU의 부하에 부담을 줄 수 있습니다. 총 전송로드는 5 분을 초과하지 않기 때문에 데이터베이스 파일 전체를 동기화하는 것이 좋습니다.
다음은 가장 일반적인 스위치입니다 rsync를 -
rsync syntax:
rsync [options] [local path] [[remote host:remote path] or [target path
스위치 | 동작 |
---|---|
-ㅏ | 아카이브 모드이며 -r, -p, -t, -g, -l 가정 |
-디 | 디렉터리 트리 만 동기화, 파일 없음 |
-아르 자형 | 디렉토리로 재귀 |
-엘 | 심볼릭 링크를 심볼릭 링크로 복사 |
-피 | 권한 유지 |
-지 | 그룹 보존 |
-V | 자세한 출력 |
-지 | 네트워크 링크를 통해 압축 |
-엑스 | 확장 된 속성 유지 |
-ㅏ | ACL 보존 |
-티 | 타임 스탬프 유지 |
-W | 증분 블록이 아닌 전체 파일 전송 |
-유 | 대상의 파일을 덮어 쓰지 마십시오. |
--진행 | 전송 진행률 표시 |
--지우다 | 대상에서 오래된 파일 삭제 |
-최대 크기 = XXX | 동기화 할 최대 파일 크기 |
rsync를 사용하는 경우
rsync 에 대한 개인적 선호 는 소스 호스트에서 대상 호스트로 파일을 백업 할 때입니다. 예를 들어, 데이터 복구를위한 모든 홈 디렉토리 또는 재해 복구를 위해 오프 사이트 및 클라우드로 이동합니다.
rsync를 사용한 로컬 백업
한 호스트에서 다른 호스트로 파일을 전송하는 방법을 이미 살펴 보았습니다. 동일한 방법을 사용하여 디렉터리와 파일을 로컬로 동기화 할 수 있습니다.
루트 사용자의 디렉토리에서 / etc / 의 수동 증분 백업을 만들어 보겠습니다 .
먼저 동기화 된 백업을 위해 ~ / root에 디렉토리를 만들어야합니다.
[root@localhost rdc]# mkdir /root/etc_baks
그런 다음 사용 가능한 디스크 공간이 충분한 지 확인하십시오.
[root@localhost rdc]# du -h --summarize /etc/
49M /etc/
[root@localhost rdc]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/cl-root 43G 15G 28G 35% /
우리는 전체 / etc / 디렉토리를 동기화하는 데 좋습니다.
rsync -aAvr /etc/ /root/etc_baks/
동기화 된 / etc / 디렉토리-
[root@localhost etc_baks]# ls -l ./
total 1436
drwxr-xr-x. 3 root root 101 Feb 1 19:40 abrt
-rw-r--r--. 1 root root 16 Feb 1 19:51 adjtime
-rw-r--r--. 1 root root 1518 Jun 7 2013 aliases
-rw-r--r--. 1 root root 12288 Feb 27 19:06 aliases.db
drwxr-xr-x. 2 root root 51 Feb 1 19:41 alsa
drwxr-xr-x. 2 root root 4096 Feb 27 17:11 alternatives
-rw-------. 1 root root 541 Mar 31 2016 anacrontab
-rw-r--r--. 1 root root 55 Nov 4 12:29 asound.conf
-rw-r--r--. 1 root root 1 Nov 5 14:16 at.deny
drwxr-xr-x. 2 root root 32 Feb 1 19:40 at-spi2
--{ condensed output }--
이제 증분 rsync를 해봅시다.
[root@localhost etc_baks]# rsync -aAvr --progress /etc/ /root/etc_baks/
sending incremental file list
test_incremental.txt
0 100% 0.00kB/s 0:00:00 (xfer#1, to-check=1145/1282)
sent 204620 bytes received 2321 bytes 413882.00 bytes/sec
total size is 80245040 speedup is 387.77
[root@localhost etc_baks]#
test_incremental.txt 파일 만 복사되었습니다.
rsync를 사용한 원격 차등 백업
백업 계획이 배포 된 서버로 초기 rsync 전체 백업을 수행해 보겠습니다. 이 예는 실제로 Mac OS X Workstation의 폴더를 CentOS 서버에 백업하는 것입니다. rsync의 또 다른 장점은 rsync가 포팅 된 모든 플랫폼에서 사용할 수 있다는 것입니다.
MiNi:~ rdc$ rsync -aAvz Desktop/ImportanStuff/
[email protected]:Documents/RemoteStuff
[email protected]'s password:
sending incremental file list
./
A Guide to the WordPress REST API | Toptal.pdf
Rick Cardon Tech LLC.webloc
VeeamDiagram.png
backbox-4.5.1-i386.iso
dhcp_admin_script_update.py
DDWRT/
DDWRT/.DS_Store
DDWRT/ddwrt-linksys-wrt1200acv2-webflash.bin
DDWRT/ddwrt_mod_notes.docx
DDWRT/factory-to-ddwrt.bin
open_ldap_config_notes/
open_ldap_config_notes/ldap_directory_a.png
open_ldap_config_notes/open_ldap_notes.txt
perl_scripts/
perl_scripts/mysnmp.pl
php_scripts/
php_scripts/chunked.php
php_scripts/gettingURL.php
sent 2,318,281,023 bytes received 336 bytes 9,720,257.27 bytes/sec
total size is 2,326,636,892 speedup is 1.00
MiNi:~ rdc$
이제 오프 사이트에 저장된 순환 재해 복구 미디어를 사용하여 워크 스테이션에서 RAID6 볼륨을 실행하는 서버로 폴더를 백업했습니다. rsync를 사용하면 값 비싼 중복 디스크 어레이와 순환 차등 백업이있는 단 하나의 서버로 표준 3-2-1 백업이 제공되었습니다.
이제 test_file.txt 라는 단일 새 파일 이 추가 된 후 rsync를 사용하여 동일한 폴더를 다시 백업 해 보겠습니다 .
MiNi:~ rdc$ rsync -aAvz Desktop/ImportanStuff/
[email protected]:Documents/RemoteStuff
[email protected]'s password:
sending incremental file list
./
test_file.txt
sent 814 bytes received 61 bytes 134.62 bytes/sec
total size is 2,326,636,910 speedup is 2,659,013.61
MiNi:~ rdc$
보시다시피 rsync 를 통해 새 파일 만 서버에 전달되었습니다 . 차등 비교는 파일별로 이루어졌습니다.
몇 가지 유의해야 할 사항은 다음과 같습니다. 변경 사항이있는 유일한 파일이기 때문에 새 파일 test_file.txt 만 복사합니다. rsync는 ssh를 사용합니다. 우리는 어느 시스템에서도 루트 계정을 사용할 필요가 없었습니다.
간단하고 강력하며 효과적인 rsync 는 전체 폴더 및 디렉토리 구조를 백업하는 데 적합합니다. 그러나 rsync 자체는 프로세스를 자동화하지 않습니다. 여기에서 도구 상자를 자세히 살펴보고 작업에 가장 적합한 작고 간단한 도구를 찾아야합니다.
cronjobs로 rsync 백업을 자동화하려면 SSH 사용자가 인증을 위해 SSH 키를 사용하여 설정되어야합니다. 이것은 cronjobs와 결합되어 시간 간격으로 rsync가 자동으로 수행되도록합니다.
블록 별 베어 메탈 복구 이미지에 DD 사용
DD는 GNU 유틸리티를 충족하는 Linux 커널이 시작된 이래로 사용되어 온 Linux 유틸리티입니다.
dd 는 가장 간단한 용어로 선택한 디스크 영역의 이미지를 복사합니다. 그런 다음 물리적 디스크의 선택된 블록을 복사하는 기능을 제공합니다. 따라서 백업이 없으면 dd가 디스크에 쓰면 모든 블록이 교체됩니다. 이전 데이터 손실은 고가의 전문가 수준 데이터 복구를위한 복구 기능을 능가합니다.
dd 로 부팅 가능한 시스템 이미지를 만드는 전체 프로세스 는 다음과 같습니다.
- 부팅 가능한 Linux 배포를 사용하여 CentOS 서버에서 부팅
- 이미징 할 부팅 가능한 디스크의 지정을 찾습니다.
- 복구 이미지를 저장할 위치 결정
- 디스크에서 사용 된 블록 크기 찾기
- dd 이미지 작업 시작
이 자습서에서는 시간과 단순성을 위해 CentOS 가상 머신에서 마스터 부트 레코드의 ISO 이미지를 생성합니다. 그런 다음이 이미지를 오프 사이트에 저장합니다. MBR이 손상되어 복원해야하는 경우 전체 부팅 디스크 또는 파티션에 동일한 프로세스를 적용 할 수 있습니다. 그러나 필요한 시간과 디스크 공간은이 자습서에서 실제로 약간 초과됩니다.
CentOS 관리자는 테스트 환경에서 완전히 부팅 가능한 디스크 / 파티션을 복원하고 베어 메탈 복원을 수행하는 데 능숙 해 지도록 권장됩니다. 이는 결국 관리자와 수십 명의 최종 사용자가 다운 타임을 계산하는 실제 상황에서 연습을 완료해야 할 때 많은 부담을 덜어줍니다. 이런 경우 10 분 동안 알아내는 것은 영원처럼 보이고 땀을 흘릴 수 있습니다.
Note− dd를 사용할 때 소스와 타겟 볼륨을 혼동하지 않도록하십시오. 백업 위치를 부팅 드라이브에 복사하여 데이터와 부팅 가능한 서버를 파괴 할 수 있습니다. 또는 DD를 사용하여 매우 낮은 수준의 데이터를 복사하여 데이터를 영원히 파괴 할 수도 있습니다.
공통 명령 줄 스위치 및 매개 변수는 다음과 DD는 -
스위치 | 동작 |
---|---|
if = | 복사 할 파일 또는 소스 |
of = | 아웃 파일 또는 인 파일의 사본 |
bs | 입력 및 출력 블록 크기 설정 |
obs | 출력 파일 블록 크기 설정 |
ibs | 입력 파일 블록 크기 설정 |
카운트 | 복사 할 블록 수 설정 |
전환 | 이미징을 위해 추가 할 추가 옵션 |
오류 없음 | 오류 처리를 중지하지 마십시오. |
동조 | 오류 또는 정렬 불량이 발생하는 경우 적합하지 않은 입력 블록을 채 웁니다. |
Note on block size− dd의 기본 블록 크기는 512 바이트입니다. 이것은 저밀도 하드 디스크 드라이브의 표준 블록 크기였습니다. 오늘날 고밀도 HDD는 1TB 이상의 디스크를 허용하기 위해 4096 바이트 (4kB) 블록 크기로 증가했습니다. 따라서 새롭고 용량이 큰 하드 디스크에서 dd를 사용하기 전에 디스크 블록 크기를 확인해야합니다.
이 튜토리얼에서는 dd 로 프로덕션 서버에서 작업하는 대신 VMWare에서 실행되는 CentOS 설치를 사용합니다. 또한 부팅 가능한 USB 스틱으로 작업하는 대신 부팅 가능한 Linux ISO 이미지를 부팅하도록 VMWare를 구성합니다.
먼저 CentOS Gnome ISO 라는 제목의 CentOS 이미지를 다운로드해야합니다 . 이는 거의 3GB이며 부팅 가능한 USB 썸 드라이브를 만들고 문제 해결 및 베어 메탈 이미지를 위해 가상 서버 설치로 부팅하기위한 사본을 항상 보관하는 것이 좋습니다.
다른 부팅 가능한 Linux 배포판도 마찬가지로 작동합니다. Linux Mint는 뛰어난 하드웨어 지원과 유지 관리를위한 세련된 GUI 디스크 도구를 제공하므로 부팅 가능한 ISO에 사용할 수 있습니다.
CentOS GNOME Live 부팅 가능 이미지는 다음에서 다운로드 할 수 있습니다. http://buildlogs.centos.org/rolling/7/isos/x86_64/CentOS-7-x86_64-LiveGNOME.iso
Linux 부팅 가능 이미지에서 부팅하도록 VMWare Workstation 설치를 구성 해 보겠습니다. 단계는 OS X의 VMWare를위한 것입니다. 그러나 Linux, Windows 및 Virtual Box의 VMWare Workstation에서도 비슷합니다.
Note− Virtual Box 또는 VMWare Workstation과 같은 가상 데스크톱 솔루션을 사용하는 것은 CentOS 관리 작업을 학습하기위한 랩 시나리오를 설정하는 좋은 방법입니다. 여러 CentOS 설치를 설치할 수있는 기능을 제공하며, 사실상 하드웨어 구성이 없어 사용자가 관리에 집중할 수 있으며 변경하기 전에 서버 상태를 저장할 수도 있습니다.
먼저 가상 CD-ROM을 구성하고 가상 CentOS 서버 설치 대신 부팅에 ISO 이미지를 첨부하겠습니다.
이제 시동 디스크를 설정하십시오-
이제 부팅되면 가상 머신이 CentOS 부팅 가능 ISO 이미지에서 부팅되고 이전에 구성된 Virtual CentOS 서버의 파일에 대한 액세스를 허용합니다.
디스크를 확인하여 MBR을 복사 할 위치를 살펴 보겠습니다 (축약 된 출력은 다음과 같습니다).
MiNt ~ # fdisk -l
Disk /dev/sda: 60 GiB, 21474836480 bytes, 41943040 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk /dev/sdb: 20 GiB, 21474836480 bytes, 41943040 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
우리는 물리적 디스크 sda 및 sdb를 모두 찾았습니다 . 각 블록 크기는 512 바이트입니다. 이제 dd 명령을 실행하여 SDA1의 MBR에 대한 처음 512 바이트를 복사합니다.
이를 수행하는 가장 좋은 방법은-
[root@mint rdc]# dd if=/dev/sda bs=512 count=1 | gzip -c >
/mnt/sdb/images/mbr.iso.gz
1+0 records in
1+0 records out
512 bytes copied, 0.000171388 s, 3.0 MB/s
[root@mint rdc]# ls /mnt/sdb/
mbr-iso.gz
[root@mint rdc]#
마찬가지로, 우리는 마스터 부트 레코드의 전체 이미지를 가지고 있습니다. 부팅 드라이브를 이미지화 할 공간이 충분하다면 전체 시스템 부팅 이미지를 쉽게 만들 수 있습니다.
dd if=/dev/INPUT/DEVICE-NAME-HERE conv=sync,noerror bs=4K | gzip -c >
/mnt/sdb/boot-server-centos-image.iso.gz
전환 = 동기화가 바이트가 물리적 매체에 대해 정렬되어야 할 때 사용된다. 이 경우 정확한 4K 정렬을 읽지 않으면 dd에 오류가 발생할 수 있습니다 (예 : 3K에 불과하지만 디스크에서 최소 단일 4K 블록을 가져와야하는 파일). 또는 단순히 오류를 읽고 dd는 파일을 읽을 수 없습니다.). 따라서 dd with conv = sync, noerror 는 사소하지만 유용한 데이터로 4K 블록 정렬의 물리적 매체에 3K를 채 웁니다 . 대규모 작업을 종료 할 수있는 오류를 표시하지 않습니다.
디스크의 데이터로 작업 할 때 항상 conv = sync, noerror 매개 변수 를 포함하려고합니다 .
이는 디스크가 TCP 데이터와 같은 스트림이 아니기 때문입니다. 특정 크기로 정렬 된 블록으로 구성됩니다. 예를 들어, 512 바이트 블록이있는 경우 300 바이트의 파일에는 여전히 전체 512 바이트의 디스크 공간이 필요합니다 (권한 및 기타 파일 시스템 정보와 같은 inode 정보에 대해 2 블록).
보안 저장소에 gzip 및 tar 사용
gzip과 tar는 CentOS 관리자가 사용하는 데 익숙해 져야하는 두 가지 유틸리티입니다. 단순히 아카이브의 압축을 푸는 것보다 훨씬 더 많이 사용됩니다.
CentOS Linux에서 Gnu Tar 사용
Tar는 Windows의 winrar 와 유사한 보관 유틸리티 입니다. tar로 줄여서 테이프 아카이브 라는 이름 은 유틸리티를 거의 요약합니다. tar 는 논리적 편의를 위해 파일을 가져 와서 아카이브에 저장합니다. 따라서 / etc에 저장된 수십 개의 파일 대신. 백업 및 저장 편의를 위해 아카이브에 "타르"할 수 있습니다.
tar 는 수년 동안 Unix 및 Linux에 아카이브 파일을 저장하는 표준이었습니다. 따라서 tar를 gzip 또는 bzip 과 함께 사용 하는 것은 각 시스템의 아카이브에 대한 모범 사례로 간주됩니다.
다음은 tar와 함께 사용되는 일반적인 명령 줄 스위치 및 옵션 목록입니다.
스위치 | 동작 |
---|---|
-씨 | 새 .tar 아카이브를 만듭니다. |
-씨 | 다른 디렉토리로 추출 |
-제이 | bzip2 압축 사용 |
-지 | gzip 압축 사용 |
-V | 자세한 내용은 보관 진행 상황을 표시합니다. |
-티 | 아카이브 내용을 나열합니다. |
-에프 | 아카이브의 파일 이름 |
-엑스 | tar 아카이브 추출 |
다음은 tar 아카이브 를 만들기위한 기본 구문입니다 .
tar -cvf [tar archive name]
Note on Compression mechanisms with tar− tar를 사용할 때 두 가지 일반적인 압축 방식 중 하나 인 gzip 및 bzip2를 고수하는 것이 좋습니다. gzip 파일은 CPU 리소스를 덜 사용하지만 일반적으로 크기가 더 큽니다. bzip2는 압축하는 데 더 오래 걸리지 만 더 많은 CPU 리소스를 사용합니다. 그러나 최종 파일 크기가 더 작아집니다.
파일 압축을 사용할 때 우리는 항상 표준 파일 확장자를 사용하여 아카이브를 추출하는 데 필요한 압축 체계를 우리 자신을 포함한 모든 사람이 알 수 있도록 (시행 착오를 통해 추측 할 수 있음) 원할 것입니다.
bzip2 | .tbz |
bzip2 | .tar.tbz |
bzip2 | .tb2 |
gzip | .tar.gz |
gzip | .tgz |
Windows 상자에서 또는 Windows에서 사용하기 위해 아카이브를 추출 해야하는 경우 대부분의 세 문자 단일 확장이 Windows 및 Windows 전용 관리자를 혼동 하므로 .tar.tbz 또는 .tar.gz 를 사용하는 것이 좋습니다. 때로는 원하는 결과)
Mac 워크 스테이션에서 복사 한 원격 백업에서 gzip 압축 된 tar 아카이브를 생성 해 보겠습니다.
[rdc@mint Documents]$ tar -cvz -f RemoteStuff.tgz ./RemoteStuff/
./RemoteStuff/
./RemoteStuff/.DS_Store
./RemoteStuff/DDWRT/
./RemoteStuff/DDWRT/.DS_Store
./RemoteStuff/DDWRT/ddwrt-linksys-wrt1200acv2-webflash.bin
./RemoteStuff/DDWRT/ddwrt_mod_notes.docx
./RemoteStuff/DDWRT/factory-to-ddwrt.bin
./RemoteStuff/open_ldap_config_notes/
./RemoteStuff/open_ldap_config_notes/ldap_directory_a.png
./RemoteStuff/open_ldap_config_notes/open_ldap_notes.txt
./RemoteStuff/perl_scripts/
./RemoteStuff/perl_scripts/mysnmp.pl
./RemoteStuff/php_scripts/
./RemoteStuff/php_scripts/chunked.php
./RemoteStuff/php_scripts/gettingURL.php
./RemoteStuff/A Guide to the WordPress REST API | Toptal.pdf
./RemoteStuff/Rick Cardon Tech LLC.webloc
./RemoteStuff/VeeamDiagram.png
./RemoteStuff/backbox-4.5.1-i386.iso
./RemoteStuff/dhcp_admin_script_update.py
./RemoteStuff/test_file.txt
[rdc@mint Documents]$ ls -ld RemoteStuff.tgz
-rw-rw-r--. 1 rdc rdc 2317140451 Mar 12 06:10 RemoteStuff.tgz
Note− 모든 파일을 아카이브에 직접 추가하는 대신 RemoteStuff 폴더 전체를 아카이브했습니다 . 이것이 가장 쉬운 방법입니다. 추출 할 때 전체 디렉토리 RemoteStuff 가 현재 작업 디렉토리 내의 모든 파일과 함께 ./currentWorkingDirectory/RemoteStuff/ 로 추출되기 때문입니다.
이제 / root / 홈 디렉토리 에서 아카이브를 추출해 보겠습니다 .
[root@centos ~]# tar -zxvf RemoteStuff.tgz
./RemoteStuff/
./RemoteStuff/.DS_Store
./RemoteStuff/DDWRT/
./RemoteStuff/DDWRT/.DS_Store
./RemoteStuff/DDWRT/ddwrt-linksys-wrt1200acv2-webflash.bin
./RemoteStuff/DDWRT/ddwrt_mod_notes.docx
./RemoteStuff/DDWRT/factory-to-ddwrt.bin
./RemoteStuff/open_ldap_config_notes/
./RemoteStuff/open_ldap_config_notes/ldap_directory_a.png
./RemoteStuff/open_ldap_config_notes/open_ldap_notes.txt
./RemoteStuff/perl_scripts/
./RemoteStuff/perl_scripts/mysnmp.pl
./RemoteStuff/php_scripts/
./RemoteStuff/php_scripts/chunked.php
./RemoteStuff/php_scripts/gettingURL.php
./RemoteStuff/A Guide to the WordPress REST API | Toptal.pdf
./RemoteStuff/Rick Cardon Tech LLC.webloc
./RemoteStuff/VeeamDiagram.png
./RemoteStuff/backbox-4.5.1-i386.iso
./RemoteStuff/dhcp_admin_script_update.py
./RemoteStuff/test_file.txt
[root@mint ~]# ping www.google.com
위에서 볼 수 있듯이 모든 파일은 현재 작업 디렉토리 내의 포함 디렉토리로 간단히 추출되었습니다.
[root@centos ~]# ls -l
total 2262872
-rw-------. 1 root root 1752 Feb 1 19:52 anaconda-ks.cfg
drwxr-xr-x. 137 root root 8192 Mar 9 04:42 etc_baks
-rw-r--r--. 1 root root 1800 Feb 2 03:14 initial-setup-ks.cfg
drwxr-xr-x. 6 rdc rdc 4096 Mar 10 22:20 RemoteStuff
-rw-r--r--. 1 root root 2317140451 Mar 12 07:12 RemoteStuff.tgz
-rw-r--r--. 1 root root 9446 Feb 25 05:09 ssl.conf [root@centos ~]#
gzip을 사용하여 파일 백업 압축
앞서 언급했듯이 tar에서 bzip2 또는 gzip을 사용할 수 있습니다. -j 또는 -z명령 줄 스위치. gzip을 사용하여 개별 파일을 압축 할 수도 있습니다. 그러나 bzip 또는 gzip 만 사용하면 tar 와 결합 할 때만 큼 많은 기능을 제공하지 않습니다 .
gzip을 사용할 때 기본 작업은 원본 파일을 제거하고 각 파일을 .gz 확장자를 추가하는 압축 된 버전으로 바꾸는 것입니다.
gzip의 일반적인 명령 줄 스위치는 다음과 같습니다.
스위치 | 동작 |
---|---|
-씨 | 아카이브에 배치 한 후 파일 유지 |
-엘 | 압축 된 아카이브에 대한 통계 가져 오기 |
-아르 자형 | 디렉토리의 파일을 재귀 적으로 압축합니다. |
-1에서 9까지 | 1에서 9까지의 비율로 압축 수준을 지정합니다. |
gzip 은 일부 Windows O / S zip 유틸리티와 같이 아카이브 기반이 아니라 파일별로 작동합니다. 그 주된 이유는 tar가 이미 고급 아카이브 기능을 제공하기 때문입니다. gzip 은 압축 메커니즘 만 제공하도록 설계되었습니다.
따라서 gzip 을 생각할 때 단일 파일을 생각하십시오. 여러 파일을 생각할 때 tar 아카이브를 생각하십시오 . 이제 이전 tar 아카이브에서 이것을 살펴 보겠습니다 .
Note − 노련한 Linux 전문가는 종종 타르 된 아카이브를 타르볼이라고합니다.
rsync 백업 에서 또 다른 tar 아카이브를 만들어 보겠습니다 .
[root@centos Documents]# tar -cvf RemoteStuff.tar ./RemoteStuff/
[root@centos Documents]# ls
RemoteStuff.tar RemoteStuff/
데모 용의가하자 gzip을 새로 생성 된 타르볼을하고, 말 gzip으로 이전 파일을 유지. 기본적으로 -c 옵션이 없으면 gzip은 전체 tar 아카이브를 .gz 파일로 대체 합니다.
[root@centos Documents]# gzip -c RemoteStuff.tar > RemoteStuff.tar.gz
[root@centos Documents]# ls
RemoteStuff RemoteStuff.tar RemoteStuff.tar.gz
We now have our original directory, our tarred directory and finally our gziped tarball.
gzip으로 -l 스위치 를 테스트 해 보겠습니다 .
[root@centos Documents]# gzip -l RemoteStuff.tar.gz
compressed uncompressed ratio uncompressed_name
2317140467 2326661120 0.4% RemoteStuff.tar
[root@centos Documents]#
gzip 이 Windows Zip 유틸리티와 어떻게 다른지 보여주기 위해 텍스트 파일 폴더에서 gzip을 실행 해 보겠습니다.
[root@centos Documents]# ls text_files/
file1.txt file2.txt file3.txt file4.txt file5.txt
[root@centos Documents]#
이제 -r 옵션을 사용하여 디렉토리의 모든 텍스트 파일을 재귀 적으로 압축 해 보겠습니다.
[root@centos Documents]# gzip -9 -r text_files/
[root@centos Documents]# ls ./text_files/
file1.txt.gz file2.txt.gz file3.txt.gz file4.txt.gz file5.txt.gz
[root@centos Documents]#
보다? 일부 사람들이 예상했던 것과는 다릅니다. 모든 원본 텍스트 파일이 제거되고 각각 개별적으로 압축되었습니다. 이 동작 때문에 단일 파일에서 작업해야 할 때 gzip 만 생각하는 것이 가장 좋습니다 .
작업 타르볼 ,의 우리 추출 할 수 rsynced 새 디렉토리에 타르볼.
[root@centos Documents]# tar -C /tmp -zxvf RemoteStuff.tar.gz
./RemoteStuff/
./RemoteStuff/.DS_Store
./RemoteStuff/DDWRT/
./RemoteStuff/DDWRT/.DS_Store
./RemoteStuff/DDWRT/ddwrt-linksys-wrt1200acv2-webflash.bin
./RemoteStuff/DDWRT/ddwrt_mod_notes.docx
./RemoteStuff/DDWRT/factory-to-ddwrt.bin
./RemoteStuff/open_ldap_config_notes/
./RemoteStuff/open_ldap_config_notes/ldap_directory_a.png
./RemoteStuff/open_ldap_config_notes/open_ldap_notes.txt
./RemoteStuff/perl_scripts/
./RemoteStuff/perl_scripts/mysnmp.pl
./RemoteStuff/php_scripts/
./RemoteStuff/php_scripts/chunked.php
위에서 본 것처럼 tarball을 / tmp 디렉토리에 추출하고 압축을 풉니 다.
[root@centos Documents]# ls /tmp
hsperfdata_root
RemoteStuff
TarBall 아카이브 암호화
재해 복구시 조직의 다른 직원이 액세스해야하는 보안 문서를 저장하기 위해 tarball 아카이브를 암호화하는 것은 까다로운 개념 일 수 있습니다. 기본적으로이를 수행하는 세 가지 방법이 있습니다. GnuPG를 사용하거나 openssl을 사용하거나 세 번째 부분 유틸리티를 사용합니다.
GnuPG는 주로 비대칭 암호화를 위해 설계되었으며 암호가 아닌 신원 연결을 염두에두고 있습니다. 사실, 대칭 암호화와 함께 사용할 수 있지만 이것이 GnuPG의 주요 강점은 아닙니다. 따라서 원래 사람보다 더 많은 사람이 액세스해야하는 경우 (예 : 왕국의 모든 키를 레버리지로 보유하고있는 관리자로부터 보호하려는 기업 관리자) 물리적 보안이있는 아카이브 저장에 대해 GnuPG를 할인합니다.
GnuPG와 같은 Openssl은 우리가 원하는 것을 할 수 있으며 CentOS와 함께 제공됩니다. 그러나 다시 말하지만, 우리가 원하는 것을 수행하도록 특별히 설계되지 않았으며 보안 커뮤니티에서 암호화에 대한 질문이있었습니다.
우리의 선택은 7zip. 7zip은 gzip 과 같은 압축 유틸리티 이지만 더 많은 기능이 있습니다. Gnu Gzip과 마찬가지로 7zip과 그 표준은 오픈 소스 커뮤니티에 있습니다. EHEL Repository에서 7zip을 설치하기 만하면됩니다 (다음 장에서는 Extended Enterprise Repositories 설치에 대해 자세히 다룹니다).
Centos에 7zip 설치
7zip은 EHEL 리포지토리가 CentOS에로드되고 구성되면 간단한 설치입니다.
[root@centos Documents]# yum -y install p7zip.x86_64 p7zip-plugins.x86_64
Loaded plugins: fastestmirror, langpacks
base
| 3.6 kB 00:00:00
epel/x86_64/metalink
| 13 kB 00:00:00
epel
| 4.3 kB 00:00:00
extras
| 3.4 kB 00:00:00
updates
| 3.4 kB 00:00:00
(1/2): epel/x86_64/updateinfo
| 756 kB 00:00:04
(2/2):
epel/x86_64/primary_db
| 4.6 MB 00:00:18
Loading mirror speeds from cached hostfile
--> Running transaction check
---> Package p7zip.x86_64 0:16.02-2.el7 will be installed
---> Package p7zip-plugins.x86_64 0:16.02-2.el7 will be installed
--> Finished Dependency Resolution
Dependencies Resolved
간단하게 7zip이 설치되어 tarball 아카이브를위한 256 비트 AES 암호화와 함께 사용할 준비가되었습니다.
이제 7z를 사용하여 gzip으로 압축 된 아카이브를 암호로 암호화 해 보겠습니다. 이를위한 구문은 매우 간단합니다.
7z a -p <output filename><input filename>
어디, a: 아카이브에 추가 및 -p: 암호를 암호화하고 확인
[root@centos Documents]# 7z a -p RemoteStuff.tgz.7z RemoteStuff.tar.gz
7-Zip [64] 16.02 : Copyright (c) 1999-2016 Igor Pavlov : 2016-05-21
p7zip Version 16.02 (locale=en_US.UTF-8,Utf16=on,HugeFiles=on,64 bits,1 CPU Intel(R)
Core(TM) i5-4278U CPU @ 2.60GHz (40651),ASM,AES-NI)
Scanning the drive:
1 file, 2317140467 bytes (2210 MiB)
Creating archive: RemoteStuff.tgz.7z
Items to compress: 1
Enter password (will not be echoed):
Verify password (will not be echoed) :
Files read from disk: 1
Archive size: 2280453410 bytes (2175 MiB)
Everything is Ok
[root@centos Documents]# ls
RemoteStuff RemoteStuff.tar RemoteStuff.tar.gz RemoteStuff.tgz.7z slapD
text_files
[root@centos Documents]#
이제 256 비트 AES로 gzip 압축 된 tarball을 암호화하는 .7z 아카이브가 있습니다.
Note− 7zip은 암호 및 카운터의 SHA-256 해시와 함께 AES 256 비트 암호화를 사용하며 키 파생을 위해 최대 512K까지 반복됩니다. 복잡한 키를 사용하는 경우 충분히 안전해야합니다.
아카이브를 암호화하고 다시 압축하는 프로세스는 더 큰 아카이브의 경우 다소 시간이 걸릴 수 있습니다.
7zip은 gzip 또는 bzip2보다 더 많은 기능을 제공하는 고급 제품입니다. 그러나 CentOS 또는 Linux 세계에서는 표준이 아닙니다. 따라서 가능한 한 자주 다른 유틸리티를 사용해야합니다.