[TIP] git을 sql로 확인하기~ 막일을 줄이기 위한 유용한 팁 3

git 을 sql로 질의하다

이번 시리즈는 사실 개발자의 막일을 줄인다기 보다 git 정보를 재미나게(?) 볼 수 있는 툴 하나를 소개 하려한다.

gitql 은 git 레포지토리를 sql로 볼 수 있는 툴이다. go로 개발되어 있으며 gitql을 설치 한 후 기존 레포지토리에서 명령어와 함께 sql을 보고자 하는 필드와 테이블을 지정하여 실행시키면 (예를 들어 git log 메시지를 쿼리로 확인) 된다.

설치와 관련된 사항은 다음과 같다. (Max OS기준)

1. 우선 Go와 cmake가 설치 되어 있어야 한다.

Go설치와 관련해서는 https://golang.org/dl/ 를 참고한다.

2. go 관련 환경 설정은 다음과 같다.

- export GOROOT=/usr/local/go

- export GOPATH=$HOME/go

- export PATH=$PATH:$GOROOT/bin

3. gitql을 go로 github에서 가져온다.

- go get -u -d github.com/cloudson/gitql

4. 해당 디렉토리로 이동하여 다음의 명령으로 설치한다.

- cd $GOPATH/src/github.com/cloudson/gitql

- make

- sudo make install

- export DYLD_LIBRARY_PATH=$PWD/libgit2/install/lib

사용방법은 다음과 같다.

기존 git repository에서 gitql 명령을 수행하면 된다.

우선 git commit log에서 hash와 작성자와 메시지 등의 정보를 5건 출력해보자

1
2
3
4
5
6
7
8
9
10
11
12
13
14
jerryjung-2:druid jerryjung$ gitql "select hash, author, message from commits limit 5"
  |----------------------------------------------------------------------------------------------------------------------------------------------|
  | Hash                                     | Author        | Message                                                                           |
  |----------------------------------------------------------------------------------------------------------------------------------------------|
  | 8cac7105462ff244f2ca52159f3d351215de1f4b | Charles Allen | Async lookups-cached-global by default (#3074)                                    |
  |----------------------------------------------------------------------------------------------------------------------------------------------|
  | a2290a8f05d2c42462aa5d39737893706f5cf6ca | David Lim     | support seamless config changes (#3051)                                           |
  |----------------------------------------------------------------------------------------------------------------------------------------------|
  | 6d38dde2f869bb4cbd8b383882a757abdc3c6546 | David Lim     | exclude slf4j-log4j12 (#3075)                                                     |
  |----------------------------------------------------------------------------------------------------------------------------------------------|
  | 54139c68159149017ea4ed9510346934d4e68997 | Gian Merlino  | Fix NPE in registeredLookup extractionFn when "optimize" is not provided. (#3064) |
  |----------------------------------------------------------------------------------------------------------------------------------------------|
  | 2db5f49f3526ec16e7535cebdb977b65cb762583 | Gian Merlino  | Fix JavaScriptConfig. (#3062)                                                     |
  |----------------------------------------------------------------------------------------------------------------------------------------------|

아래 예제는 comment에서 'hell'이나 'Fuck'을 언급한 상당히 거친 메시지를 던진 git log를 찾는 쿼리이다.

1
2
3
4
5
6
7
8
9
10
jerryjung-2:druid jerryjung$ gitql "select hash, message from commits where 'hell' in full_message or 'Fuck' in full_message"
  |------------------------------------------------------------------------------------------------------------------|
  | Hash                                     | Message                                                               |
  |------------------------------------------------------------------------------------------------------------------|
  | 23ebca6d32a0d5c1f602942227f3990b48391b4f | more hadoop dependency hell, getting the right urls to hadoop is hard |
  |------------------------------------------------------------------------------------------------------------------|
  | 8c8d83830eeef5de2b8913127cbaf70afb45d926 | Merge pull request #300 from metamx/dependency-version-hell           |
  |------------------------------------------------------------------------------------------------------------------|
  | 0d3c26d64f725715e745d278ca6a4d114f2e0f53 | Merge pull request #299 from metamx/dependency-version-hell           |
  |------------------------------------------------------------------------------------------------------------------|

특정 이슈 번호 #307X로 시작되는 commit만 추출하는 질의이다.

1
2
3
4
5
6
7
8
jerryjung-2:druid jerryjung$ gitql "select hash,message,author from commits where '#307' in message limit 10"
  |-----------------------------------------------------------------------------------------------------------|
  | Hash                                     | Message                                        | Author        |
  |-----------------------------------------------------------------------------------------------------------|
  | 8cac7105462ff244f2ca52159f3d351215de1f4b | Async lookups-cached-global by default (#3074) | Charles Allen |
  |-----------------------------------------------------------------------------------------------------------|
  | 6d38dde2f869bb4cbd8b383882a757abdc3c6546 | exclude slf4j-log4j12 (#3075)                  | David Lim     |
  |-----------------------------------------------------------------------------------------------------------|

이외에도 다음과 같은 질의를 수행할 수 있다.

  • select hash, message, author_email from commits where author = 'cloudson' 특정 사용자 찾아내기
  • select date, message from commits where date < '2014-04-10' 날짜 기준으로 찾기
  • select message from commits where 'hell' in message order by date asc 날짜기준으로 소팅

gitql은 csv나 tsv를 파싱하여 sql질의를 할 수 있는 textql 에서 영감을 받았다고 한다.

https://github.com/cloudson/gitql/blob/develop/tables.md 여기에는 gitql로 질의 가능한 테이블과 필드에 대한 정보이다.

gitql -show-tables 명령어로 질의 가능한 테이블/필드 정보를 확인 할 수 있다.

기능이 제한적이지만 재미도 있고 봇으로도 만들어서 사용도 하면 유용할 듯 하다.

내부적으로 git api를 통해 외부 git의 특정 사용자의 commit 이슈만 걷어내어 내부 브랜치에 머지하는 방식으로 사용하였는데 일부분을 걷어내고 요걸로 대체해도 될듯하다.

https://github.com/gitql/gitql 레포지토리의 경우 최근에도 commit이 올라오고 있다. 실행파일을 바이너리 파일로 받을 수 있어 설치가 용이하며 사용방법은 유사하다. 여기도 참고해보면 좋을듯 하다.

막일 방지를 위한 팁은 TO BE CONTINUED ...

이전 팁 들은 여길 참고하시길


Popit은 페이스북 댓글만 사용하고 있습니다. 페이스북 로그인 후 글을 보시면 댓글이 나타납니다.