이 아이노드는 파일이 실제로 어디에 저장되어 있는지, 파일의 크기, 수정 시간 등 파일에 관한 다양한 정보를 관리합니다.
아이노드는 무엇을 관리할까요?
아이노드는 파일에 대한 중요한 정보를 포함하고 있습니다.
이 정보는 다음과 같습니다:
파일 소유권과 접근 권한: 이 파일을누가 소유하고, 어떤권한을 가지고 있는지.
파일 내용이 저장된 물리적 주소: 파일의데이터가 실제로 어디에 위치하는지.
파일의 링크 수: 파일을참조하는 링크가 몇 개 있는지.
파일의 크기: 파일이 차지하는크기.
파일 생성 시간, 최근 사용 시간, 최근 수정 시간: 파일이 언제 만들어졌고, 언제 마지막으로 사용되었는지, 수정되었는지에 대한 정보.
아이노드의 최근 수정 시간: 아이노드 자체가수정된 시간.
이 정보들은 파일 시스템에서 파일이 어떻게 저장되고 관리되는지에 대한 중요한 정보를 제공합니다.
아이노드는 어떻게 구성될까요?
아이노드는 64바이트 크기의 표로, 파일에 대한 모든 정보를 담고 있습니다.
그리고 이 아이노드들은 아이노드 블록에 저장되며, 전체 디스크의 약 1% 정도를 차지합니다.
파일이나 디렉토리가 생성되면, 해당 파일을 관리할 아이노드가 만들어지고, 이 아이노드는 아이노드 테이블에 등록되어 관리됩니다.
- 아이노드(inode): 파일이나 디렉토리의 중요한 정보를 담고 있는 64바이트 크기의 데이터 구조입니다. - 아이노드 테이블(inode table): 시스템 내의 모든 파일과 디렉토리의 아이노드를 관리하는 표입니다. - 아이노드 번호(inumber): 아이노드가 아이노드 테이블에서 고유하게 등록된 번호입니다.
아이노드 테이블의 역할
아이노드 테이블은 파일 시스템에서 파일이나 디렉토리들이 어디에 저장되고 있는지 추적하는 역할을 합니다. 파일이나 디렉토리가 생성되면, 아이노드 번호는 i-list라는 표에 등록되고, 이 번호를 통해 해당 파일에 대한 정보를 빠르게 찾을 수 있습니다.
이번 시간에는 아이노드에 대해 살펴보았습니다.
다음 시간에는 아이노드와 관련된 심볼릭 링크(소프트링크)와 하드링크에 대해 알아보겠습니다.
원본 파일과 하드링크가 같은 아이노드 번호를 가집니다. 즉, 이 두 파일은 사실상 같은 파일입니다.
왜 하드링크를 배워야 할까요?
여러분은 파일을 여러 곳에서 사용해야할때 어떻게 합니까? 같은 파일을 여러 이름으로 저장하거나, 다른 위치에서 바로 접근할 수 있다면 더 효율적으로 관리할 수 있겠죠? 하드링크는 이런 문제를 해결해 줍니다.
시스템에서 파일 중복을 줄이고 디스크 공간을 절약할 수 있기 때문입니다.
예를 들어, 백업 시스템에서 동일한 파일을 여러 장소에 두고 관리해야 할 때, 하드링크를 사용하면 실제 파일을 복사하지 않고도 여러 위치에서 동일한 파일을 참조할 수 있습니다.
비유 법으로 배워봅시다 "이름 바꾸기"
하드링크는 마치 "이름을 바꾼 파일"과 같습니다.
예를 들어, 당신이 친구에게 '홍길동'이라는 이름을 줬다면, '홍길동'이라는 이름으로 불리는 사람이 바로 그 친구입니다.
이제 '길동이'라는 이름을 다시 붙였다고 생각해 보세요.
그 친구는 여전히 같은 사람이지만, 두 이름을 다 사용할 수 있게 된 것입니다. 이 경우 '홍길동'과 '길동이'는 사실 같은 사람(파일)입니다.
같은 아이노드 번호: 하드링크 파일은 원본 파일과 정확히 동일한 데이터 블록을 가리킵니다. 즉, 파일의 실제 내용은 동일합니다.
변경사항 동기화: 만약 '홍길동' 이름으로 파일을 수정하고, '길동이' 이름으로도 파일을 수정하면, 두 이름 모두 동일한 내용을 가리키고 있기 때문에 수정 사항이동기화됩니다.
파일 삭제: 원본 파일(홍길동)을 삭제해도, '길동이'는 여전히 존재하고, 그 파일의 내용은 변하지 않습니다. 사실 원본 파일이 삭제되었을 때는, 그 파일을 참조하는 다른 링크가 남아있기 때문에 파일이 삭제되지 않은 것처럼 보입니다.
파일 시스템에서 중요한 데이터 파일을 여러 곳에서 참조해야 할 때, 하드링크를 사용하면 데이터 중복을 줄이고 디스크 공간을 절약할 수 있습니다.
예를 들어, 서버의 데이터베이스 파일이 여러 디렉토리에서 필요할 때, 하드링크를 사용하여 하나의 원본 파일을 여러 이름으로 참조할 수 있습니다.
하드링크는 복사본을 만들지 않고도 파일을 여러 곳에서 사용할 수 있게 해 줍니다.
원본 파일 test.txt가 있다고 가정해 보겠습니다.
하드링크 test_link.txt를 만들면, 두 파일은같은 아이노드를 가리킵니다.
두 파일 중 하나를 수정하면 다른 파일에도 수정 사항이 반영됩니다. 원본 파일을 삭제해도, 하드링크가 여전히 동일한 파일을 가리키고 있으므로 파일이 그대로 남아 있습니다.
소프트링크 (Soft Link, Symbolic Link)
소프트링크(심볼릭 링크)는 원본 파일을 가리키는 "통로" 역할을 합니다.
소프트링크는 원본 파일의 경로를 저장하는 별도의 파일로, 실제 데이터는 저장하지 않습니다.
이 링크는 원본 파일의 위치를 알려주는 주소와 같은 역할을 합니다.
왜 소프트링크를 배워야 할까요?
소프트링크는 시스템 관리에서 파일 경로를 효율적으로 관리하는 데 매우 유용합니다.
예를 들어, 자주 변경되는 설정 파일이나 라이브러리 파일에 대한 경로를 소프트링크로 관리하면, 시스템 업데이트나 변경이 있을 때 소프트링크만 수정하면 되기 때문에 관리가 용이해집니다.
또한, 시스템 설정이나 프로그램 파일들을 여러 곳에서 사용할 때, 소프트링크를 사용하여 경로를 간편하게 지정할 수 있습니다.
비유 법으로 배워봅시다 "주소를 적어 놓은 종이"
소프트링크는 마치 원본 집의 주소를 적어 놓은 종이와 같습니다.
예를 들어, 당신이 친구 집에 가고 싶을 때, 친구의 집 주소를 적어놓은 종이를 받고, 그 주소로 가면 친구를 만날 수 있죠.
이 주소 종이(소프트링크)는 원본 집(파일)의 위치를 가리키고 있습니다.
그러나 이 종이 자체는 집이 아니고, 그저 집의 위치를 알려주는 역할만 합니다.
만약 친구 집이 이사를 가면, 그 주소 종이는 더 이상 유효하지 않게 됩니다.
다른 아이노드 번호: 소프트링크는 원본 파일과 다른 아이노드 번호를 가집니다. 소프트링크 파일은 원본 파일의 경로를 가리키는 문자열로 존재합니다.
동기화 없음: 소프트링크에서 수정한 내용은 원본 파일에 영향을 주지 않습니다. 소프트링크 파일을 수정한다고 해서 원본 파일의 내용은 바뀌지 않습니다.
원본 삭제 시 깨짐: 원본 파일이 삭제되면, 소프트링크는 더 이상 유효하지 않게 됩니다. 즉, 원본 파일이 사라지면, 소프트링크는 '깨진 링크'가 되어 더 이상 작동하지 않습니다.
소프트링크는 파일 경로를 효율적으로 관리하고, 시스템 환경에서 파일을 쉽게 참조할 수 있게 해줍니다. 예를 들어, 여러 버전의 소프트웨어가 설치되어 있을 때, 최신 버전의 소프트웨어를 소프트링크로 가리키면, 소프트웨어 경로를 쉽게 변경할 수 있습니다. 또한, 프로그램의 설정 파일이 여러 디렉토리에서 필요할 때, 소프트링크를 사용하여 중앙 집중식으로 관리할 수 있습니다.
원본 파일 test.txt가 있고, 소프트링크 test_link.txt를 만들었다고 합시다.
소프트링크 파일은 test.txt라는 파일의 위치만 알고 있을 뿐, 파일 자체를 가지고 있지 않습니다.
test_link.txt를 열면, 자동으로 test.txt로 이동하여 내용을 볼 수 있습니다. 하지만 원본 파일을 삭제하면, test_link.txt를 열려고 할 때 오류가 발생할 것입니다. (깨진 링크)
bee@bee-box:~$
bee@bee-box:~$cd /var/www/bWAPP
bee@bee-box:/var/www/bWAPP$
root@bee-box:/var/www/bWAPP# mysql -u root -p
Enter password: bug
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 5.0.96-0ubuntu3 (Ubuntu)
Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| bWAPP |
| drupageddon |
| mysql |
+--------------------+
4 rows in set (0.00 sec)
cd /var/www/bWAPP를 이용하여
bWAPP 디렉터리로 이동합니다.
mysql -u root -p명령어와 패스워드
bug를 이용하여Mysql 로컬 접속을 실시합니다.
show databases를 이용하여
데이터베이스를 확인합니다.
가장 위에 있는Information_schema는
Mysql에서 운영되는 데이터베이스,
테이블, 칼럼의 모든 정보를 관리하는 DB입니다.
아래 보이는bWAPP과 drupageddon은
bWAPP 시나리오에 사용하는 DB이며
맨 아래mysql은 Mysql 운영과 관련된
정보가 저장된 DB입니다.
DataBase 생성 및 삭제
mysql> create database test;
Query OK, 1 row affected (0.00 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| bWAPP |
| drupageddon |
| test |
| mysql |
+--------------------+
5 rows in set (0.00 sec)
mysql> drop database test;
Query OK, 0 rows affected (0.00 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| bWAPP |
| drupageddon |
| mysql |
+--------------------+
4 rows in set (0.00 sec)
create database ;명령어를 이용하여
데이트베이스를 생성하고
drop database ; 명령어로
데이터베이스를 삭제할 수 있습니다
(test 데이터베이스 생성)
테이블 생성 및 삭제
mysql> use test;
Database changed
mysql> show tables;
Empty set (0.00 sec)
mysql> create table linux (id int, login varchar(10), password varchar(10), username varchar(20), age int);
Query OK, 0 rows affected (0.01 sec)
mysql> show tables;
+------------------+
| Tables_in_test |
+------------------+
| linux |
+------------------+
1 row in set (0.00 sec)
mysql> create table cisco (id int, login varchar(10), password varchar(10), username varchar(20), age int);
Query OK, 0 rows affected (0.00 sec)
mysql> create table security (id int, login varchar(10), password varchar(10), username varchar(20), age int);
Query OK, 0 rows affected (0.00 sec)
mysql> create table java (id int, login varchar(10), password varchar(10), username varchar(20), age int);
Query OK, 0 rows affected (0.00 sec)
mysql> show tables;
+------------------+
| Tables_in_test |
+------------------+
| cisco |
| java |
| linux |
| security |
+------------------+
4 rows in set (0.00 sec)
mysql> drop table java;
Query OK, 0 rows affected (0.00 sec)
mysql> show tables;
+------------------+
| Tables_in_test |
+------------------+
| cisco |
| linux |
| security |
+------------------+
3 rows in set (0.00 sec)
데이터베이스 생성 및 삭제: CREATE DATABASE test;와 DROP DATABASE test; 명령어 직후에 각 명령어가 데이터베이스를 생성하고 삭제하는 기능을 수행한다는 설명을 추가합니다.
예: "CREATE DATABASE test; 명령어는 'test'라는 이름의 새로운 데이터베이스를 생성합니다. 이때, 데이터베이스 이름은 고유해야 합니다. DROP DATABASE test; 명령어는 'test' 데이터베이스를 시스템에서 완전히 제거합니다."
테이블 생성, 데이터 입력, 수정 및 삭제: 각 CREATE TABLE, INSERT INTO, UPDATE, DELETE 명령어 사용 직후에 명령어의 기능을 간략하게 설명합니다.
예: "CREATE TABLE 명령어는 새로운 테이블을 생성합니다. INSERT INTO 명령어는 테이블에 새로운 행을 추가합니다. UPDATE 명령어는 테이블의 데이터를 수정하고, DELETE 명령어는 데이터를 삭제합니다."
오늘은 Mysql을 알아본 후 어떤 식으로 mysql을 사용하는 건지 간단한 실습을 통해서 Mysql에 접속해 보고, Database를 생성하고 삭제해 보고, 테이블을 생성하고 삭제해 보고, 테이블 안에 컬럼 속성을 확인해 보고, 값을 입력하고 수정해 보고 삭제해 보고, 속성 정보를 변경해 보고, 칼럼을 추가하고 수정하고 삭제까지 해봤습니다.
아직까지 정말 많이 쓰이고 있는mysql은
어느 곳에 속하여 일을 하시던지
알고 계시면 분명 도움이 될만한 내용이라고 생각합니다.
보안 관련 주의사항 및 안전한 사용법: mysql -u root -p 명령어를 사용하여 접속하는 방법을 설명하는 부분에 보안 주의사항을 추가합니다.
예: "MySQL을 사용할 때는 보안을 항상 유념해야 합니다. 예제에서 사용한 'root' 계정과 'bug'라는 비밀번호는 테스트 목적으로만 사용해야 합니다. 실제 환경에서는 강력한 비밀번호를 설정하고, 필요한 최소한의 권한을 가진 사용자 계정을 생성하여 사용하는 것이 좋습니다."
실습 후 데이터베이스와 테이블 정리: MySQL 실습을 마친 후, 생성한 데이터베이스와 테이블을 어떻게 정리해야 하는지에 대한 방법을 설명합니다.
예: "실습을 마친 후에는 사용한 데이터베이스와 테이블을 정리하는 것이 좋습니다. 이를 위해 DROP DATABASE 명령어와 DROP TABLE 명령어를 사용하여 더 이상 필요하지 않은 데이터베이스와 테이블을 삭제할 수 있습니다. 이 과정은 실습 환경을 깔끔하게 유지하고, 불필요한 데이터의 축적을 방지합니다
궁금하신 사항은 댓글에 남겨주세요 댓글에 남겨주신 내용은 추후 정리해서 올려드리겠습니다 구독 신청하시면 업로드 시 알려드릴게요! - 조금이라도 도움이 되셨다면 공감&댓글 부탁드리겠습니다 감사합니다!