SlideShare a Scribd company logo
조성수
오픈스택 swift로 시작하는 오픈소스 분석 삽질기
경희대학교 컴퓨터공학과
2015.10.28
발표자 소개
조 성 수
• A2 Company 인턴
• 경희대학교 컴퓨터공학과 3학년
• SW Maestro 1기
• 선린인터넷고등학교 졸업
• 관심분야 : 백엔드 개발, Cloud
System
오늘 제가 할 이야기는?
지난 1년간의 오픈스택 Swift 와 함께한
‘개발’과 관련된 삽질 이야기입니다.
공부 사용 코드분석 개발
발단
2014년 3월. 군대에서 막 전역 후 회사에 인턴으로 들어가게 되었습니다.
들어가자마자 부여받은 업무. ‘Object Storage’를 구축해야한다.
당시 팀에는 저 포함 2명
Openstack Swift에 대해 먼저 공부하자.
공부
우선 공식홈페이지에 있는 문서를 훑어봤습니다
공부
지금와서 보면 정말 정리가 잘 되어있는 1등급 문서
하지만 당시에는…
http://hamnice51.tistory.com/entry/파워패스로-하기-싫은-공부-시작하기-ㅠㅠ
공부
거대한 시스템을 다루기 위해서 개념에 대한 이해가 필요하다 생각해서
계속 문서만 열심히 읽었습니다
공부
일단 써보자
Openstack Swift 의 구성 요소
X 4
X 6
Daemon
Openstack Swift 의 구성 요소
Proxy-Server
Account Server
Container Server
Object Server
A/C/O Server
A/C/O Server
A/C/O Server
Ring
Openstack Swift 의 구성 요소
Proxy-Server
Daemon
Daemon
Daemon
Openstack Swift 의 구성 요소
Python
Swift 를 써보려고만해도 서버 10대가 필요했습니다
A/C/O Server 를 서버 한 대로 구성해도, 4대의 서버가 필요
당시 저는 MacBook 13 inch Mid 2010 을 쓰고 있었습니다.
Intel Core 2 Duo 4GB RAM
VM 4개를 돌리기엔
맥북이 힘들어합니다
SAIO (Swift All In One)
처음 프로젝트 설명을 들으면서 SAIO라는 것이 있다고 들었습니다
SAIO : Swift All In One
SWIFT
SAIO (Swift All In One)
SAIO (Swift All In One)
SAIO (Swift All In One)
SAIO (Swift All In One)
SAIO (Swift All In One)
Devstack
One Click, Install Openstack
Devstack
git clone https://git.openstack.org/openstack-dev/devstack
1. devstack 스크립트를 다운로드 받는다.
2. swift 관련 간단한 설정을 해준다.
3. 스크립트를 실행한다
cd devstack; ./stack.sh
Devstack
SWIFT
최소 2core, 2GB VM 으로 간단하게 swift 환경 구축
[ 2015 SOSCON ]오픈스택 swift로 시작하는 오픈소스 분석 삽질기
다음 임무 – 추가 기능 개발
< 새로운 임무 >
추가 기능 개발
Swift에 Object Lifecycle 을 더하다
< 추가 기능 >
Swift에 Object Lifecycle 기능 추가
Swift에 Object Lifecycle 을 더하다
사실, Swift에도 object lifecycle 이 있습니다.
Swift에 Object Lifecycle 을 더하다
Swift에 Object Lifecycle 을 더하다
이 모든것을
Swift 원본 코드 수정 없이!
Swift에 Object Lifecycle 을 더하다
Swift
마치 3rd party 처럼 Swift의 부가기능으로
Object Lifecycle을 구현해야한다
+
Object
Lifecycle
Swift에 Object Lifecycle 을 더하다
이미 Swift에는 부가기능을 하는 Middleware 라는 개념이 있습니다
Healthcheck Auth Multipart
upload
proxy-server
Middleware 개발
Middleware 개발
Middleware 개발
Middleware 개발
Middleware 개발
Middleware 개발
Middleware 개발
공식홈페이지의 예제는 빈약했지만
Swift 코드 내에 참고할만한 많은
Middleware 코드가 있었습니다
Middleware 분석
공식 홈페이지의 Middleware 소개 문서를 보고, 제일 쉬울만한 것을 하나 골라
코드 분석을 시작했습니다
Middleware 분석
눈으로
코드를 한줄 한줄
분석했습니다
Middleware 분석
눈으로
Middleware 분석
분석 하는데 한계가 생겼습니다.
Middleware 분석
사실 PyCharm 이라는 IDE를 쓰고 있어서 분석은 용이했습니다.
예를 들면, 코드 reference 따라가기 / 되돌아오기
a.py
def func1():
…..
.....
.....
func2()
.....
.....
b.py
def func2():
…..
.....
.....
.....
.....
.....
Middleware 분석
어렴풋이 어떻게 동작하는지는 알겠는데..
변수에 어떤 값이 들어가고, 어떻게 값이 변화하는지를
모르니 완벽하게 이해하기 어려웠습니다
Middleware 분석
변수값을 확인하고 싶다
Middleware 분석
실행할 수 있는 환경은 이미 있다
간단하지만 만능의 디버깅도구 - print
Middleware 분석
원하는 곳에 print [변수] 만 하면 언제든지 변수 값 확인이 가능합니다.
나름 체계화한다고 print [식별자] [변수]
Middleware 분석
실상은 눈알 빠지게 PRINT 된 내용을 찾아야하지만,
그럭저럭 할만했습니다
Swift 코드 분석
Middleware 분석이 어느정도 되고나니 개발에 감이 잡혔습니다
근데 제가 개발해야하는 것이…
Swift 코드 분석
Swift 내부 원리를 이해하지 못하면, 구현하지 못하는 기능
결국 Swift 코드도 분석하고 디버깅하기 시작했습니다.
http://m.bdkrnews.com/bbs/board.php?bo_table=good_02&wr_id=8887
Swift 코드 분석
Print , 즉 로그 분석만으로는 감당하기 힘든 스케일.
IDE를 쓰는데 IDE를 쓰는게 아닌 느낌..
뭔가 다른 방법이 필요하다
Swift 코드 분석
Remote Debugging with Remote Interpreter
Swift 코드 분석
devstack vm
/usr/bin/python2.7
현재 Swift 서버가 실행중인 모습
devstack vm안에서 직접 실행되어있다.
Swift 코드 분석
devstack vm
/usr/bin/python2.7
Pycharm이 vm의 Python Interpreter 를 직접 실행하도록 설정
Swift 코드 분석
IDE를 IDE답게 사용할 수 있게 되었다!!
STEP INTO / OVER
변수 여러개의 상태를 동시에 확인
심지어 변수값도 실행중에 바꿀 수 있다.
[ 2015 SOSCON ]오픈스택 swift로 시작하는 오픈소스 분석 삽질기
[ 2015 SOSCON ]오픈스택 swift로 시작하는 오픈소스 분석 삽질기
그래서
약 6개월 동안
[ 2015 SOSCON ]오픈스택 swift로 시작하는 오픈소스 분석 삽질기
Swift 코드 분석도 하고
Object Lifecycle 도 개발하고
Middleware : 4개
Daemon : 5개
만들어 냈습니다
코드는..
http://toothfairy.tistory.com/467
Swift 코드 분석 과정
Swift 코드 분석 과정
1. API 의 흐름 파악
API를 하나하나 호출해가면서 Swift 코드의 어느 부분을 거쳐가는지
대략적으로 파악
API 흐름에 있는 코드만 제대로 분석해도 Swift 의 절반을 알 수 있다.
나머지는 50%는 Consistency 유지를 위한 Daemon과, 유틸리티
Swift 코드 분석 과정
2. 기능의 개발 과정을 역추적
지금 내가 보고 있는 이 코드는 수 많은 고민과 토론을 통해 나온 코드
처음에 코드만 봐서는 왜 이렇게 처리했는지 파악이 잘 안될 수 있다
커밋로그, 코드리뷰 사이트를 통해 기능 개발 과정을 역추적하며 파악
Swift 코드 분석 과정
2. 기능의 개발 과정을 역추적
Swift 코드 분석 과정
3. UML을 찾기란 하늘의 별따기
ERD, Flowchart 등 UML은 의외로 없었다.
기능을 제안한 사람의 github, blog에만 간단히 남아있는 정도
운이 좋으면 IRC 로그에서 다이어그램 링크를 획득할 수도 있다.
Swift 코드 분석 과정
4. Openstack Swift Contributor 들의 작업 과정 추적
의외로 공식 문서를 뒤적이다보면 유용한 링크가 많이 나온다
프로젝트 대시보드, 아이디어목록, 우선순위 별 리뷰목록 등..
하나하나 들어가서 구경하면서, 어떤식으로 작업이 이루어지는지 파악
Swift 코드 분석 과정
4. Openstack Swift Contributor 들의 작업 과정 추적
새로운 기능
Blueprint -> 검토 -> 승인 -> 개발 -> 코드리뷰 -> 반영
Spec제안 -> 검토 -> 승인 -> 개발 -> 코드리뷰 -> 반영
Swift 코드 분석 과정
4. Openstack Swift Contributor 들의 작업 과정 추적
Comment 를 통해 어디서 해당 기능이 토의되었는지 적어주는 경우도 있다
Swift 코드 분석 과정
4. Openstack Swift Contributor 들의 작업 과정 추적
Swift 코드 분석 과정
4. Openstack Swift Contributor 들의 작업 과정 추적
공식 문서에서는 볼 수 없던, 기능 개발 Trello 사이트 발견
Swift 코드 분석 과정
5. 모르는건 IRC에 질문
이상하게 말해도 찰떡같이 알아들으니, 철판깔고 질문을 하면 됩니다
기능하나 개발하려다
Swift를 분석해버리고 말았습니다
정리
오픈소스 라이브러리던, 시스템이던
일단 써본다
공식 문서를 꼼꼼히 읽어가면서
기능, 구조를 명확히 파악하고
디버깅 가능한 환경을 구축하고
디버깅을 하며 코드를 분석한다
IRC와 같은 개발자 채널이 있다면
무작정 들어가서 어떤 이야기가 오고가는지 알아보고
어떻게 개발이 이루어지는지 파악한다
그리고 현재 진행중인 논의가 무엇인지도..
그러다보면 어느새 버그리포팅도 하고
Contribution도 하는 날이 오지않을까요?
긴 시간 저의 삽질 이야기를 들어주셔서
대단히 감사합니다
휴.. 끝났다
짤방을 제외한 아이콘은 IconFinder 에서 가져왔습니다.
짤방은 구글링으로 찾았고, 사진아래 출처를 달아뒀습니다
그외 그림은 직접 캡쳐했습니다
THANK YOU!

More Related Content

PPTX
2015 SW마에스트로 100+ 컨퍼런스_오픈스택 Swift로 시작하는 오픈소스 분석 삽질기
2015 SW마에스트로 100+ 컨퍼런스
 
PDF
파일기반 동기식 메세지큐를 이용한 간단한 레스토랑 서비스 시뮬레이션 구현
nexusz99
 
PDF
오픈스택! 이틀이면할수있다! 시즌2
Nalee Jang
 
PDF
오픈소스 개발 Upstream - ONOS/CORD 워킹 그룹 2차 세미나
Ian Choi
 
PDF
오픈스택 커뮤니티 소개 및 기술 동향
Nalee Jang
 
PDF
devon2013: 사내Git저장소개발사례
Daehyun Kim
 
PPTX
[MeetUp][3rd] Prometheus 와 함께하는 모니터링 및 시각화
InfraEngineer
 
PDF
OpenStack 커뮤니티 상반기 스터디
OpenStack Korea Community
 
2015 SW마에스트로 100+ 컨퍼런스_오픈스택 Swift로 시작하는 오픈소스 분석 삽질기
2015 SW마에스트로 100+ 컨퍼런스
 
파일기반 동기식 메세지큐를 이용한 간단한 레스토랑 서비스 시뮬레이션 구현
nexusz99
 
오픈스택! 이틀이면할수있다! 시즌2
Nalee Jang
 
오픈소스 개발 Upstream - ONOS/CORD 워킹 그룹 2차 세미나
Ian Choi
 
오픈스택 커뮤니티 소개 및 기술 동향
Nalee Jang
 
devon2013: 사내Git저장소개발사례
Daehyun Kim
 
[MeetUp][3rd] Prometheus 와 함께하는 모니터링 및 시각화
InfraEngineer
 
OpenStack 커뮤니티 상반기 스터디
OpenStack Korea Community
 

What's hot (20)

PPTX
[H3 2012] 오픈소스로 개발 실력 쌓기
KTH, 케이티하이텔
 
PDF
[네이버오픈소스세미나] egjs-view360 개발기 - 김희재
NAVER D2
 
PDF
『오픈스택 인 액션』 - 맛보기
복연 이
 
PPTX
[141] 오픈소스를 쓰려는 자, 리베이스의 무게를 견뎌라
NAVER D2
 
PDF
[네이버오픈소스세미나] Next Generation Spring Security OAuth2.0 - 이명현
NAVER Engineering
 
PDF
Spring Framework 튜토리얼 - 네이버 최영목님
NAVER D2
 
PDF
Launchpad 활용 사례 in OpenStack: 다루어본 Bug & Blueprint를 중심으로
Ian Choi
 
PDF
[17.02.09] Github introduction (Korean Version)
Ildoo Kim
 
PDF
네이버 오픈소스 세미나 - 나의코드에서 모두의 코드로 UNIST 이한
NAVER Engineering
 
PDF
[111]open, share, enjoy 네이버의 오픈소스 활동
NAVER D2
 
PDF
오픈스택을다루는기술 집필후기
Nalee Jang
 
PDF
도커 무작정 따라하기: 도커가 처음인 사람도 60분이면 웹 서버를 올릴 수 있습니다!
pyrasis
 
PDF
도커를 이용한 파이썬 모듈 배포하기
JunSeok Seo
 
PPT
Share some development
Ji Heon Kim
 
PDF
[17.01.19] docker introduction (Korean Version)
Ildoo Kim
 
PDF
[OpenStack Day in Korea] Introduction to open stack
Nalee Jang
 
PDF
Swift package manager
성관 윤
 
PDF
Kcd open stack
Nalee Jang
 
PDF
제 5회 D2 CAMPUS SEMINAR - Swift로 만든 serverframework 개발기
NAVER D2
 
PDF
가장 빨리 만나는 Docker 출간 후기
pyrasis
 
[H3 2012] 오픈소스로 개발 실력 쌓기
KTH, 케이티하이텔
 
[네이버오픈소스세미나] egjs-view360 개발기 - 김희재
NAVER D2
 
『오픈스택 인 액션』 - 맛보기
복연 이
 
[141] 오픈소스를 쓰려는 자, 리베이스의 무게를 견뎌라
NAVER D2
 
[네이버오픈소스세미나] Next Generation Spring Security OAuth2.0 - 이명현
NAVER Engineering
 
Spring Framework 튜토리얼 - 네이버 최영목님
NAVER D2
 
Launchpad 활용 사례 in OpenStack: 다루어본 Bug & Blueprint를 중심으로
Ian Choi
 
[17.02.09] Github introduction (Korean Version)
Ildoo Kim
 
네이버 오픈소스 세미나 - 나의코드에서 모두의 코드로 UNIST 이한
NAVER Engineering
 
[111]open, share, enjoy 네이버의 오픈소스 활동
NAVER D2
 
오픈스택을다루는기술 집필후기
Nalee Jang
 
도커 무작정 따라하기: 도커가 처음인 사람도 60분이면 웹 서버를 올릴 수 있습니다!
pyrasis
 
도커를 이용한 파이썬 모듈 배포하기
JunSeok Seo
 
Share some development
Ji Heon Kim
 
[17.01.19] docker introduction (Korean Version)
Ildoo Kim
 
[OpenStack Day in Korea] Introduction to open stack
Nalee Jang
 
Swift package manager
성관 윤
 
Kcd open stack
Nalee Jang
 
제 5회 D2 CAMPUS SEMINAR - Swift로 만든 serverframework 개발기
NAVER D2
 
가장 빨리 만나는 Docker 출간 후기
pyrasis
 
Ad

Viewers also liked (20)

PDF
Openstack Swift overview
어형 이
 
PDF
[OpenStack Days Korea 2016] Track1 - Red Hat enterprise Linux OpenStack Platform
OpenStack Korea Community
 
PDF
[OpenStack Days Korea 2016] Track1 - Mellanox CloudX - Acceleration for Cloud...
OpenStack Korea Community
 
PDF
Swift 세미나
용재 김
 
PPTX
데이터베이스 정규화
Lee Seongje
 
PPTX
Installation Openstack Swift
ymtech
 
PPTX
Heat
Maurice Verreck
 
PPTX
Swift 0x01 환경 설정
Hyun Jin Moon
 
PDF
[OpenStack Day in Korea] 15분만에 구축하는 오픈스택 기반 크라우드 솔루션: HP CloudSystem
Sungjin Kang
 
PPT
데이터베이스의 이해
Byung Kook Ha
 
PPSX
오픈소스의 이해(교육자료)
정명훈 Jerry Jeong
 
PDF
OpenStack 개요 및 활용 사례 @ Community Open Camp with Microsoft
Ian Choi
 
PDF
Pr프로그램의기획및실행 _PRidean_BonnieLim
SoHyun Bonnie Lim
 
PPT
Ndc2011 성능 향상을_위한_데이터베이스_아키텍쳐_구축_및_개발_가이드
cranbe95
 
PPTX
DB 설계 과제
Dong-Jin Park
 
PPTX
OpenStack Heat Orchestration
WooKyun Jeon
 
PPTX
공간정보거점대학 1.geo server_고급과정
BJ Jang
 
PPTX
OpenStack Orchestration (Heat)
Jimi Chen
 
PDF
데이터베이스 베이직 소개
Hoyoung Jung
 
PDF
An Introduction to OpenStack Heat
Mirantis
 
Openstack Swift overview
어형 이
 
[OpenStack Days Korea 2016] Track1 - Red Hat enterprise Linux OpenStack Platform
OpenStack Korea Community
 
[OpenStack Days Korea 2016] Track1 - Mellanox CloudX - Acceleration for Cloud...
OpenStack Korea Community
 
Swift 세미나
용재 김
 
데이터베이스 정규화
Lee Seongje
 
Installation Openstack Swift
ymtech
 
Swift 0x01 환경 설정
Hyun Jin Moon
 
[OpenStack Day in Korea] 15분만에 구축하는 오픈스택 기반 크라우드 솔루션: HP CloudSystem
Sungjin Kang
 
데이터베이스의 이해
Byung Kook Ha
 
오픈소스의 이해(교육자료)
정명훈 Jerry Jeong
 
OpenStack 개요 및 활용 사례 @ Community Open Camp with Microsoft
Ian Choi
 
Pr프로그램의기획및실행 _PRidean_BonnieLim
SoHyun Bonnie Lim
 
Ndc2011 성능 향상을_위한_데이터베이스_아키텍쳐_구축_및_개발_가이드
cranbe95
 
DB 설계 과제
Dong-Jin Park
 
OpenStack Heat Orchestration
WooKyun Jeon
 
공간정보거점대학 1.geo server_고급과정
BJ Jang
 
OpenStack Orchestration (Heat)
Jimi Chen
 
데이터베이스 베이직 소개
Hoyoung Jung
 
An Introduction to OpenStack Heat
Mirantis
 
Ad

Similar to [ 2015 SOSCON ]오픈스택 swift로 시작하는 오픈소스 분석 삽질기 (20)

PPTX
2022.08 멘토링 자료.pptx
ssuserf875e6
 
PDF
CleanSwift 적용기
ssuser86e2971
 
PPTX
Continuous Integration
Donghyun Seo
 
PDF
학교에선 알려주지 않는 오픈소스이야기 - 박치완님
NAVER D2
 
PPTX
졸업후 취업까지.ssul
승표 홍
 
PDF
지속적인 통합
중선 곽
 
PDF
개발자로써 갖춰야할 스킬들 - 최용호
용호 최
 
PPTX
[123] electron 김성훈
NAVER D2
 
PPTX
141118 최창원 웹크롤러제작
Changwon Choe
 
PDF
커뮤니티와 함께한 예비개발자 성장기- 조성수님
NAVER D2
 
PPTX
최광훈 포트폴리오
Kwanghoon Choi
 
PDF
[H3 2012] 앱(APP) 중심으로 생각하기 - DevOps와 자동화
KTH, 케이티하이텔
 
PDF
코프링 프로젝트 투입 일주일 전: 주니어 개발자의 코틀린 도입 이야기
Seokjae Lee
 
PDF
DevOps와 자동화
DONGSU KIM
 
PDF
메이븐 기본 이해
중선 곽
 
PDF
D2 캠퍼스 세미나 - 학생 개발자에서 신입 개발자로 한단계 업그레이드 하기
Soojin Ro
 
PDF
AWS와 함께하는 DevOps이야기 :: 박선용 :: AWS Summit Seoul 2016
Amazon Web Services Korea
 
PDF
빌드 버튼이 눌린다음에 무슨일이 일어나는 걸까?
hyunho Lee
 
PPTX
반복적인 코드 작업 자동화, Codebone으로 손쉽게
Sungju Jin
 
PPT
개발자의 첫단계
yejiHong7
 
2022.08 멘토링 자료.pptx
ssuserf875e6
 
CleanSwift 적용기
ssuser86e2971
 
Continuous Integration
Donghyun Seo
 
학교에선 알려주지 않는 오픈소스이야기 - 박치완님
NAVER D2
 
졸업후 취업까지.ssul
승표 홍
 
지속적인 통합
중선 곽
 
개발자로써 갖춰야할 스킬들 - 최용호
용호 최
 
[123] electron 김성훈
NAVER D2
 
141118 최창원 웹크롤러제작
Changwon Choe
 
커뮤니티와 함께한 예비개발자 성장기- 조성수님
NAVER D2
 
최광훈 포트폴리오
Kwanghoon Choi
 
[H3 2012] 앱(APP) 중심으로 생각하기 - DevOps와 자동화
KTH, 케이티하이텔
 
코프링 프로젝트 투입 일주일 전: 주니어 개발자의 코틀린 도입 이야기
Seokjae Lee
 
DevOps와 자동화
DONGSU KIM
 
메이븐 기본 이해
중선 곽
 
D2 캠퍼스 세미나 - 학생 개발자에서 신입 개발자로 한단계 업그레이드 하기
Soojin Ro
 
AWS와 함께하는 DevOps이야기 :: 박선용 :: AWS Summit Seoul 2016
Amazon Web Services Korea
 
빌드 버튼이 눌린다음에 무슨일이 일어나는 걸까?
hyunho Lee
 
반복적인 코드 작업 자동화, Codebone으로 손쉽게
Sungju Jin
 
개발자의 첫단계
yejiHong7
 

More from nexusz99 (9)

PDF
[2017 파이썬 연말 세미나] PyCon APAC 2017 참가 후기
nexusz99
 
PDF
스마트 홈 Io t 서비스를 위한 분산 데이터베이스 설계 및 구현
nexusz99
 
PDF
분산형 데이터베이스 기반 비중앙식 IoT 플랫폼을 이용한 스마트 홈 서비스
nexusz99
 
PDF
Github 으로 학교 팀 프로젝트 하기
nexusz99
 
PPTX
Dropbox와 같은 시스템은 파일을 어떻게 저장할까?
nexusz99
 
PDF
태그기반 파일관리시스템을 적용한 스토리지 시스템
nexusz99
 
PPTX
Cache cloud 최종
nexusz99
 
PDF
REST API 디자인 개요
nexusz99
 
PDF
서버 개발자가 되기 위한 첫 걸음
nexusz99
 
[2017 파이썬 연말 세미나] PyCon APAC 2017 참가 후기
nexusz99
 
스마트 홈 Io t 서비스를 위한 분산 데이터베이스 설계 및 구현
nexusz99
 
분산형 데이터베이스 기반 비중앙식 IoT 플랫폼을 이용한 스마트 홈 서비스
nexusz99
 
Github 으로 학교 팀 프로젝트 하기
nexusz99
 
Dropbox와 같은 시스템은 파일을 어떻게 저장할까?
nexusz99
 
태그기반 파일관리시스템을 적용한 스토리지 시스템
nexusz99
 
Cache cloud 최종
nexusz99
 
REST API 디자인 개요
nexusz99
 
서버 개발자가 되기 위한 첫 걸음
nexusz99
 

[ 2015 SOSCON ]오픈스택 swift로 시작하는 오픈소스 분석 삽질기