git bash 실행를 실행하고 아래 명령어를 입력해 주세요. 1. # 뒤의 내용은 주석입니다. 입력 안하셔도 됩니다. 2. 2단계의 경우 본문에서는 윈도우 탐색기에서 파일을 정상적으로 생성했다면 넘어가도 됩니다.
# 2단계. 새 프로젝트 폴더 생성, 그리고 git bash 실행
mkdir /c/Programming/
mkdir /c/Programming/firstgit
# 3단계. git 1 - 폴더 이동
cd /C/Programming/firstgit
# 4단계. git 사용자 정보 입력 (설치 후 한번만 실행)
git config --global user.name "abc"
git config --global user.email "abc@abc.com"
git config --list # 입력된 정보 확인
# 5단계. 초기화 git init
git init
git status # 6단계. 상태 확인0 git status
# 7단계. 작업 시작 - 파일, 폴더 만들기 및 확인
touch index.html
ls # 파일이 잘 생성되었는지 확인
git status # 8단계. 상태 확인1 git status, 파일 추적 전...
# 9단계. 변경된 내용 추적하기, git add
git add -A
git status # 10단계. 상태 확인2 git status
# 11단계. 확정하기 - git commit
git commit -m "index.html 파일 추가"
git log # 12단계. 확정(commit, 커밋)된 내용 확인하기 - git log
이번에는 제가 버전관리 하는 방법과 절차를 간단하게 설명하겠습니다. 저는 윈도우 운영체제 기준으로 설명하겠습니다.
버전관리 기초에서 프로그램은 git bash만 사용합니다. 보통은 Visual Studio Code, Visual Studio 같은 IDE로 작업하고 자체 git 플러그인을 사용하지만 여기서는 git bash 만 사용해서 진행합니다. 나중에 다른 프로젝트 진행할 때 git bash 를 연결하거나 자체 플러그인으로 버전관리 하는 법도 알려드리겠습니다.
github, nas 등의 원격저장소는 다음 글에서 다룰 예정입니다.
1단계. 설치
우선 컴퓨터에 git을 설치해야겠죠? git은 아래 사이트에 들어가서 운영체제에 맞는 버전을 설치하면 됩니다.
설치 과정은 생략하겠습니다. 설치 방법이 궁금하시면 아래 링크를 클릭해주세요.
설치가 완료되면 윈도우 버전의 경우 git bash 프로그램을 실행할 수 있습니다. 윈도우 기본 명령 프롬프트(CMD)에서도 실행은 가능하지만 기본 명령어 중에서 맥, 리눅스 명령어와 다른 내용이 있기 때문에 git bash로 따라하는 걸 추천합니다.
2단계. 새 프로젝트 폴더 생성, 그리고 git bash 실행
윈도우 탐색기에서 프로젝트 폴더를 하나 생성합니다. 저는 "C:\Programming\firstgit" 폴더를 만들었습니다.
그리고 아래 아이콘을 찾아서 git bash 프로그램을 실행합니다.
그러면 아래 그림과 같이 명령창이 나타납니다.
이렇게 되면 버전관리를 할 준비가 완료되었습니다.
3단계. git 1 - 폴더 이동
git bash 명령창에 "pwd" 를 입력하면 현재 폴더 위치가 나타납니다. (윈도우 프롬프트에서는 기본적으로 현재 위치가 표시됩니다. git bash에서도 원래는 디렉토리가 표시되지만 사용자의 홈 디렉토리인 경우에는 ~로 표시됩니다.) "cd C:/Programming/firstgit" 를 입력해서 새로 생성한 폴더로 입력합니다.
잠깐! 윈도우 프롬프트에서는 "cd C:\Programming\firstgit" 를 입력하면 됩니다만 git bash 에서는 리눅스 명령어를 사용하기 때문에 \ 표시를 전부 / 표시로 바꿔줘야 합니다. git bash에서 "cd C:\Programming\firstgit" 를 입력하면 아래와 같이 오류가 발생합니다.
이제부턴 캡처 화면 대신 글씨로 표현하겠습니다.
따라하실 때는 입력 또는 예시 오른쪽 칸의 $ 뒤에 있는 부분만 입력하시면 됩니다.
4단계. git 사용자 정보 입력 (설치 후 한번만 실행)
설정은 git을 처음 실행하였을 경우에만 하면 됩니다. 다음 프로젝트 부터는 이 과정을 생략해도 됩니다. 작성요령에서 "사용자이름" 대신에 작업하시는 분 이름 또는 별명을 입력해 주세요. "이메일주소" 대신에 작업하시는 분 이메일 주소를 입력해 주세요.
현재 폴더 내의 변경된 내용이 있는지 확인하는 방법은 "git status" 명령어를 입력하면 됩니다. 현재 아무 작업도 안했기 때문에 No commits yet, nothing to commit 이라는 결과가 나옵니다.
입력
$ git status
결과
On branch master No commits yet nothing to commit (create/copy files and use "git add" to track)
저 같은 경우에는 git status 는 작업하고 추가하기 전(8단계), 추가(git add) 후 커밋 전, 커밋(git commit) 후 확인할 때 사용합니다.
7단계. 작업 시작 - 파일, 폴더 만들기 및 확인
이 단계는 git이 아닌 리눅스 명령어 입니다.
이제 파일을 하나 만들어 보겠습니다. "touch index.html" 을 입력하면 입력 폴더에 새 파일이 생깁니다. 이제 파일이랑 폴더가 잘 생성되었는지 확인해 봅시다. "ls"를 입력하면 생성된 파일 및 폴더가 나타납니다.
작성요령1
$ touch 생성할파일이름(확장자포함)
작성요령1의 예시 - index.html 파일 생성 입력 - 생성된 파일, 폴더 확인
$ touch index.html $ ls
결과
index.html
8단계. 상태 확인1 git status, 파일 추적 전...
이제 다시 git status 를 입력해 보겠습니다. 6단계랑은 다르게 untracked file 목록에 index.html이 나타났습니다.
입력
$ git status
결과
On branch master No commits yet Untracked files: (use "git add ..." to include in what will be committed) index.html nothing added to commit but untracked files present (use "git add" to track)
9단계. 변경된 내용 추적하기, git add
이 파일을 추적하려면 git add index.html 을 입력하면 됩니다.
작성요령1 - 하나의 파일 추적 시작
$ git add 추적을시작할파일이름
작성요령1의 예시 - index.html의 변경내역을 추적 시작합니다.
$ git add index.html
추적할 파일이 여러개인 경우 하나하나 추가하기 힘들기 때문에 특별한 경우(파일마다 추적하는 내용이 달라서 commit을 따로 하고 싶은 경우)가 아니라면 보통은 git add -A 를 입력하여 모든 변경된 내역을 추적합니다.
입력
$ git add -A
예제에는 추적할 파일이 하나이니 때문에 git add index.html 과 git add -A 는 같은 같다고 보시면 됩니다.
10단계. 상태 확인2 git status
이제 추적할 파일이 잘 추가되었는지 확인해 볼까요? 다시한번 git status 명령어를 입력합니다. 그러면 8단계 결과와는 또 다르게 커밋의 내용과 파일명이 나타납니다. index.html 파일이 추가되었다고 나와있네요.
입력
$ git status
결과
On branch master No commits yet Changes to be committed: (use "git rm --cached ..." to unstage) new file: index.html
11단계. 확정하기 - git commit
추적할 파일들을 다 추가하였다면 이제 commit 하여 변경내역을 확정하고 기록합니다.
작성요령1
$ git commit -m "변경된내용"
작성요령1의 예시 - index.html 파일 추가라는 내용으로 변경내역을 기록하고 확정
$ git commit -m "index.html 파일 추가"
결과
[master (root-commit) e8e62de] index.html 파일 추가 1 file changed, 0 insertions(+), 0 deletions(-) create mode 100644 index.html
참고]git bash 글꼴 바꾸기 (예민하지 않은 분들은 넘어가도 상관없습니다.)
처음으로 한글이 나왔는데 한글 부분의 장평(글자와 글자 사이의 간격)이 넓게 나옵니다. 이 부분을 좀 더 깔끔하게 보고 싶으시다면 글꼴을 변경해 주면 됩니다. 우선 git bash 프로그램 오른쪽 상단에 있는 아이콘을 클릭하면 메뉴가 나타납니다. Options... 를 선택합니다.
Options... 를 선택하면 옵션 창이 나오는데요. 왼쪽 메뉴들 중 Text를 선택하면 오른쪽 부분이 아래 그림과 같이 바뀝니다. Font 를 바꿔주기 위해 Font 네모칸 안쪽의 오른쪽에 있는 Select... 버튼을 클릭합니다.
Select... 버튼을 클릭하면 아래 그림과 같이 폰트를 선택할 수 있는 창이 나옵니다. 한글폰트 중 원하는 폰트를 선택합니다. (해당도가 높고 화면이 작아서 글씨가 잘 안보이실 경우 글자 크기도 원하는 수준으로 키워주셔도 됩니다.) 저는 기존 Lucida Console 폰트에서 굴림체 폰트로 바꿨습니다. 확인 버튼을 클릭합니다.
확인 버튼을 클릭하면 아래 그림과 같이 선택한 폰트로 변경된 것을 확인하고 아래에 있는 Save 버튼을 클릭합니다.
Save 버튼을 클릭하면 아래 그림과 같이 한글도 깔끔하게 표시되네요.^^
12단계. 확정(commit, 커밋)된 내용 확인하기 - git log
수고하셨습니다. 첫번째 버전관리가 기록되었습니다. 이제 내용이 잘 기록되었는지 확인해 봅시다. git log 명령어를 입력하면 변경내역이 나타납니다. 현재는 한개의 commit 만 있습니다. commit 뒤에 있는 e8e6... 은 commit 일련번호입니다. 나중에 특정 커밋을 조회하거나 되돌리기 등의 기능을 사용할 때 필요합니다. 그 외에 작업한 사용자의 이름과 이메일, commit 일자, 내용이 나타납니다.
입력
$ git log
결과
commit e8e62de7dd605f6440a9e65eb9627444e14293f5 (HEAD -> master) Author: ilbbang7 <ilbbang7@gmail.com> Date: Fri May 24 00:42:03 2019 +0900 index.html 파일 추가
12단계 이후에 추가로 작업하고 변경하는 것은 7단계에서 html의 내용을 수정하거나 다른 파일(또는 폴더)을 추가하고 8단계에서 11단계까지 비슷하게 수행하면 됩니다. 12단계는 11단계까지 문제 없이 잘 되었나 확인하는 과정입니다. 우선은 직접 한번 해보세요. 추가 작업해서 2번째 커밋하고 확인하는 과정은 추후에 올리고 링크 남기겠습니다.
현재 작업은 한 장소에만 작업이 저장되어 있어 이 폴더를 지울 경우 버전관리된 내용이 전부 날아가게 됩니다. 따라서 원격 저장소를 생성하여 버전관리도 여러장소에 백업할 수 있습니다. 원격저장소 종류도 여러가지가 있습니다. 이 부분은 추후에 별도의 올리고 링크 남기겠습니다.
저도 아직 전문가는 아니고 공부한 내용을 나름대로 설명하다 보니 부족한 내용이 많습니다. 궁금하신 점이나 잘못 표현된 점이 있다면 댓글로 알려주세요.
버전 관리하는 방법을 설명하기 전에 그동안 제가 개발을 해왔던 내용 중 백업과 버전 관리 부분을 어떻게 해왔는지 공유해 보겠습니다.
1. 백업, 버전관리를 전혀 하지 않았음
1-1. 1대의 컴퓨터에서 작업
처음 개발을 할떄는 버전 관리를 전혀 하지 않았습니다. 처음에는 로컬에 작업 공간을 만들어서 개발을 진행했습니다. 저는 대부분 혼자서 개발을 해 왔고 한대의 컴퓨터에서만 작업할 때에는 별 문제점이 없었습니다.
1-2. 여러대 컴퓨터에서 작업할 때 - 외장 스토리지 사용
여러 컴퓨터에서 왔다 갔다 하면서 작업하기 위해서 USB나 외장하드를 이용해서 작업하곤 했었죠.
USB에서 직접 작업할 경우 속도도 문제이지만 (센디스크의 경우?) USB가 잠겨버려서 포맷도 안 되는 경우를 몇 번 경험했습니다.
외장 하드의 경우 휴대성이 약간 떨어지긴 하지만 직접 작업하는 데는 지장이 없었습니다. 잠겨버리는 경우도 아직 경험하진 못했고요. 선과 외장하드를 케이스에 넣고 빼기가 생각보다 귀찮습니다. 가끔 작업해야 되는데 두고 온 적도 종종 있습니다.
1-3. 나스(NAS) 구매
나스를 구매한 뒤로 원격에서도 해당 공간에 바로 접속해서 작업도 해봤습니다. (제가 구매한 나스는 시놀로지사의 DS218에 4TB HDD를 장착했습니다.) 내부 네트워크에서는 속도가 빨라서 문제점을 찾지 못했는데 원격으로 할 때는 인터넷 상태에 따라서 속도가 많이 느려지는 단점이 있습니다.
1의 방법들은 각각의 휴대/원격 공간에서 직접 작업하는 방법으로 작업공간은 어떻게든 하나만 존재합니다.이제부터 작업공간이 2개 이상 생겨서 백업을 한다고 볼 수 있습니다.
2. 백업, 버전관리 초보 - 동기화, 버전 별 압축하기
2-1. 동기화 프로그램 - 백업은 되지만 버전 관리는 안됨
로컬에서 작업을 한 뒤에 동기화 프로그램으로 동기화 해서 최신 버전을 유지하는 방법도 사용해 봤습니다. 무료 프로그램 중에서 FreeFileSync가 있는데 유용하게 잘 썼습니다.
하지만 여러 프로젝트를 진행하게 되면 스캔하고 동기화 할 때마다 적지 않은 시간이 소요됩니다. 그리고 항상 최신 버전으로 백업하기 때문에 버전 관리를 수동으로 해줘야 합니다.
2-2. 백업할 때마다 압축해서 날짜 적어놓기
백업 저장소에도 생각날 때 마다 압축파일을 만들어 날짜를 포함해서 다른 공간에 차곡차곡 쌓아두었습니다.
압축할 때마다 전체 프로젝트를 저장하게 되면 용량이 쓸데없이 많아집니다. 압축할 때마다 새로 고친 파일만 저장하게 되면 나중에 해당 버전을 쓸 때 추가로 작업할 내용이 많아 귀찮아집니다.
3. 드디어 버전관리도 시작? GIT 입문! 두둥
그러다가 최극 작업물부터 git을 활용해서 버전을 관리하기 시작했습니다. 아직 협업까지는 진행해 보지 않았지만 위에서 발생하는 문제점들을 잘 해결해 줬습니다. 아직 적응을 못해서 가끔 리모트 저장소에 push를 안 해놓고 가서 다른 장소에서 작업을 못 한 적이 있긴 하지만 작업 전 후 버전관리에 습관을 들인다면 이런 실수도 줄어들겠죠?
git도 관련 서비스가 엄청 많습니다. 저는 우선 git, git-server, github, TortoiseGit 정도 사용해 봤습니다.
최근 이 블로그에 애드센스가 승인되어서 쿠팡 파트너스도 가입하였습니다. 제가 IT잡동사니 제품에 관심이 많다보니 리뷰를 쓰고 해당 제품을 링크를 걸어볼까 합니다. (개인적인 만족여부를 쓸테니 구매는 여러분의 선택입니다...ㅎ)
요즘에 인터넷으로 제품을 구매할 때 쿠팡에서 많이 구매를 하고 있습니다. 그 이유는 로켓배송이 너무 좋아서인데요. 12시 전에 구매하면 다음날 도착하는게 너무 좋습니다. 가격차이가 많이 안나면 쿠팡에서 구매합니다.
사용중인 폰의 종류, 상태
저는 삼성 겔럭시 노트5(128G)를 메인으로 쓰고, S7 EDGE(128G)를 세컨드폰으로 사용 중입니다. 구매는 2년전에 S7 Edge를 새 폰으로 개통했고요. 개인적으로 노트기능이 좋아서 이후에 중고로 노트5를 구매했습니다. 노트5 중고는 사기를 당했습니다. 메인보드 불량인데 저한테 팔기 전에 상담기록이 남아있는걸 확인했습니다. 중고폰 사실 분들은 현장에서 확인한 후에 꼭 서비스센터에서 점검 받으세요.
구매 동기
그동안 계속 유선으로 충전을 했습니다. 두 폰 모두 고속충전을 지원합니다. 무선 충전도 지원하길래 확인해 봤더니 두 폰 모두 고속 무선 충전을 지원하더라고요. 그래서 구매했습니다. 쿠팡에서 가격 적당한 녀석으로 골랐습니다.
제품 링크
제가 구매한 제품은 "크레앙 울트라 부스트 9V 무선 충전기 + C타입 케이블 CREQWRPULT" 입니다.
로켓배송 가능하고요 5월 22일 현재 14,790원이네요. 제품 정보 및 구성품 등의 내용은 아래 링크를 클릭해서 확인해 주세요. 저는 후기글 안찾아보고 제품정보만 보고 구매했습니다...ㅎㅎ
우선 제가 가지고 있는 폰(삼성 겔럭시 노트5, S7 EDGE) 둘다 올려놓으면 고속무선충전이라는 글씨가 뜹니다. 아내는 S6 EDGE인데 일반무선충전으로 뜹니다. 유선충전보다 당연히 편합니다. 하지만 케이스에 링이 달렸거나 카드가 있는 경우에는 제거후에 올려놔야 하기 때문에 오히려 유선충전보다 불편합니다. 제품 설명을 보면 S6 EDGE 가 고속에도 있고 일반에도 있어서 혼동이 올 수 있는데 일반이네요... 아래 그림은 위 제품 설명 중 일부를 캡처했습니다.
테스트
토요일 어느날 집에만 있게 되어서 노트5로 테스트해봤습니다. 충전기는 제공되지 않아서 기존에 사용중인 5포트 고속충전기 중에서 퀄컴 퀵차지 2.0 포트로 연결했습니다. 시간 및 퍼센트를 엑셀로 정리했어요. 참고로 거울케이스를 낀 상태로 충전했습니다.
전체적으로 보면 9%에서 95%까지 충전 되는데 1시간 50분이 걸렸으니 2시간 정도면 완충된다고 보면 됩니다. 다만 속도가 들쑥날쑥한데 최고 컨디션으로 지속적으로 충전된다면 1시간 35분만에 완충될 수도 있겠네요.(완충까지걸리는시간 3번째 참고)
물론 위의 결과는 휴대폰 상태, 환경 등에 따라 많이 차이가 날 수 있습니다.
나중에 노트5 고속 유선충전과의 비교, s7 edge도 기회가 된다면 실험 후 이 글을 업데이트하겠습니다.
결론 및 추천여부
현재 만족하면서 쓰고 있습니다. 스마트폰이 고속 무선충전을 지원하고 케이스 뒷면에 링, 카드 등이 없는 단순한 케이스라면(지갑형은 상관 없을꺼 같습니다.) 추천합니다.
최근 구매한 샌 디스크 USB가 쓰기금지가 되서 수정 지우기는 물론 포멧도 안되게 되었습니다.
제가 특별한 작업을 한 것도 아니고 USB 내부에 있는 안드로이드 스튜디오 프로젝트가 로딩 된 상태에서 동영상 강의를 USB로 옮기자 중간에 속도가 느려지더니 쓰기 금지가 되어버렸습니다.(USB에서의 멀티 테스킹은 위험한가 봅니다.)
사실 이번이 처음이 아니고 몇 년전에 구매한 제품도 쓰기 금지가 되서 방치해 놨다가 도저히 안되겠어서 각 총판 AS사에 전화를 해 교환신청 택배를 보냈습니다.
하나는 AK, 다른 하나는 SOI 홀로그램이 붙어있었네요. 각 회사 연락처에 전화하면 문자를 보내줍니다.
[Web발신][소이전자AS안내] 경기도 과천시 찬우물로 21-5소이전자 2층 A/S담당자앞 Tel.02-6262-2000 한진택배(1588-0011)이용하셔서 성함, 연락처, 주소, 구입처, 불량증상을 간단히 적은 메모와 왕복 배송비 5,000원 동봉 후 착불로 발송 바랍니다. 한진택배 접수시 업체 신용코드번호 7자리 요청할 경우: 6006814 (등기 및 타 택배 선불로 발송시 2,500원만 동봉)
[Web발신][총판AK] 경기 파주 광탄면 용미리 325-2번지 AK물류센터 샌디스크 A/S담당자 앞 (10955) 현금2,500원과 성함,연락처,주소 기재한 메모 동봉 후 택배 선불접수로 보내주세요~^^ 데이터 폐기됨, 2주~3주 이상 소요, 파손은 AS 불가
그리고 민감한 자료가 들어있어서 고민하시는 분들은 제가 통화했던 내용을 들어 보고 판단해 주시면 좋겠습니다.
사실 저도 이전 USB를 방치한 것이 제가 개발한 여러가지 프로젝트 관련 자료가 들어있어서 교환을 망설였던 거였는데요. 서비스 센터의 이야기로는 USB 내부의 자료는 확인하지 않고 폐기한다고 합니다. 설사 확인을 하게 되면 하기 전에 저한테 연락을 줘서 동의를 받고 확인한다고 합니다. 저는 이 말을 믿고 그냥 보내기로 결심했습니다.
인터넷에 있는 쓰기 방지 풀기 방법이 있는데 이 방법은 쓰기 금지가 되고 나면 소용이 없습니다. 쓰기 금지가 되기 전에 각 USB에 조치를 취해주고 사용하는 모든 컴퓨터에 레지스트리를 추가해서 쓰기 금지가 안되도록 조치를 해 주세요. 저도 2개의 USB가 도착하면 조치할 예정입니다.
(모든 쓰기 금지 푸는 글에는 이에 대한 언급을 찾아보기 힘듭니다. 그래서 쓰기 금지가 되고 난 다음에 찾아서 해 보지만 개인의 힘으로는 절대로 풀 수 없습니다. 서비스 센터에서도 홀로그램 확인 후 새 제품으로 교환해 주는 방법밖에는 없다고 하네요.)
조치1. 모든 USB에 대하여 "diskpart" 프로그램으로 readonly 속성을 지워버립니다.
1. (윈도우 기준입니다.) "윈도우키+R" 키를 클릭합니다. 2. 입력창에 "cmd" 입력 후 "확인" 버튼 클릭합니다. 3. 명령 창에 "diskpart" 입력 후 "enter"키를 클릭합니다.(새 창에 disk part 프로그램이 실행됩니다.) 4. 명령 창에 "list disk" 입력 후 "enter"키를 클릭합니다.(디스크 목록이 나옵니다.) 5. 디스크 목록 중 USB 용량과 동일한 번호를 확인합니다. 예를 들어 번호가 3이라면 "select disk 3" 입력 후 "enter"키 클릭합니다.(해당 디스크가 선택되었다고 나옵니다.) 6. 명령 창에 "attributes disk clear readonly" 입력 후 "enter"키 (디스크 특성을 지웠습니다. 메시지를 확인합니다.)
조치1은 이렇게 끝났습니다.
조치2. 모든 사용하는 컴퓨터에 레지스트리를 등록 또는 수정합니다.
1. (윈도우기준입니다.) "윈도우키+R" 키를 클릭합니다. 2. 입력창에 "regedit" 입력 후 "확인" 버튼 클릭합니다. 3. "컴퓨터\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\" 폴더로 이동합니다. 4. "Control" 폴더에 마우스를 올리고, 마우스 오른쪽 버튼을 클릭해서 "새로만들기 - 키" 를 선택합니다. 5. 폴더 이름을 "Storage Device Policies"로 수정합니다. 6. "Storage Device Policies" 폴더에 마우스를 올리고, 마우스 오른쪽 버튼을 클릭해서 "새로만들기 - DWORD(32비트)" 를 선택합니다. 7. 값 이름을 "write protect"로 설정합니다. 8. 새로 만들면 기본값이 0이기 때문에 할 필요는 없습니다. 혹시 이미 이 값이 있고 값이 0이 아닌 경우에는 더블클릭해서 값을 0으로 수정합니다.
조치2도 이렇게 끝났습니다.
사실 이렇게 한다고 해도 쓰기 금지가 안 일어날 지는 미지수입니다. 그래도 최대한 조치를 해 놓고 사용하면 조금이라도 마음이 편하겠네요.