comphy’s profile
2014년
대한민국 공군 사이버전실습 및 대응체계 개발:평택공군제7전대
에스테크스타닷컴 에스천사게임즈 오픈
ebook 출판 예정
2013년
KT BIT OSS 프로젝트
2012년
삼성전자 가전사업부 표준화파트너 시스템 개발 (Java,JSP,Oracle)
행안부 종합장애대응체계 / 복지부 행복e음 유지보수
2011년
삼성전자 스마트그리드 서버 및 스마트TV 앱 검증 서버
삼성bada 2.0 검증 어플리케이션 개발 (MWC2011출품)
2010년
[LGU+] 패킷관련 프로젝트
[수원,구미] 삼성전자 MMP 프로젝트 (터치모바일플랫폼) : 피쳐폰의 스마트화
2009년
[천안] 삼성코닝 정밀유리 : S-Contour 프로젝트
2008년
삼성전자 소프트웨어연구소 QMO과제 수행
![]()
네 시작은 미약하였으나 네 나중은 심히 창대하리라.
Web Cloud & mobile App Business working Link
Web Cloud & mobile App Business working Link
- Biz Design Workplace
- Axure : https://www.axure.com/
- Mockplus https://www.mockplus.com/
- Balsamiq Mockups : https://balsamiq.com/
- Enterprise Architect : http://www.sparxsystems.com/
- pinterest [아이디어 영감] : https://www.pinterest.co.kr
- Biz marketing tools Workplace
- google : http://www.google.com
- 훗스위트 : https://blog.hootsuite.com/hootsuite-releases-korean/
- 메일침프 : https://mailchimp.com/
- IFTT : https://ifttt.com/
- Biz reference datas
- 프리렌서 업무 [크몽] : https://kmong.com/
- 모바일 앱 시장조사 [와이즈앱] : https://www.wiseapp.co.kr/
- 프리렌서 업무 [위시켓] : https://www.wishket.com
- 프리랜서 업무 [프리모아] : http://www.freemoa.net/
- 프리렌서 업무 [이렌서] : http://www.elancer.co.kr/
- Biz online Developing tool
- cloud9 : https://c9.io/
- ai2live : http://appybuilder.com/
- appypie : http://snappy.appypie.com/app/creator-software/
- bitbucket : https://bitbucket.org/
- PhoneGap Build (adobe) : https://build.phonegap.com/
- cloud developer console
- microsoft azure : https://azure.microsoft.com/ko-kr
- google developer console : https://console.cloud.google.com/?hl=ko
- amazon AWS : https://aws.amazon.com/ko/console/
- Mobile App Biz market
- android developer console : https://play.google.com/apps/publish/?hl=ko
- onestore (T Store) : http://dev.onestore.co.kr/devpoc/index.omp
- apple app store : https://developer.apple.com/app-store/
- 지적재산권 등록
- 특허정보검색(KIPRIS) : http://www.kipris.or.kr/khome/main.jsp
- 특허로(특허출원) : http://www.patent.go.kr/portal/Main.do
![]()
매일 들르는 곳 : nooksurfer : ホームページの閲覧えつらん者しゃ
매일 들르는 곳 : nooksurfer : ホームページの閲覧えつらん者しゃ
- 임베스트 기술사 : http://limbest.com/user/index.php [국가기술자격 기술사 대비]
- packt 출판사 : https://www.packtpub.com/ [신기술 서적 plain english 출판]
- itfind : http://www.itfind.or.kr/main.do [국내 IT기술정보동향 및 정책]
- 취미 전자공학 사이트 : http://www.piclist.com/images/www/hobby_elec/
- 완성도 좋은 오픈소스 arduino 응용 설계 cad : http://fritzing.org/home/
- 미리안 : http://mirian.kisti.re.kr/index.jsp [해외 과학기술 정보]
- 보안뉴스 : http://www.boannews.com/ [국내 보안 시장 뉴스]
- 아마존 킨들 : https://www.amazon.com/Kindle-eBooks/ [영어 EBOOK 서적 판매]
- codeproject : https://www.codeproject.com/ [(MS위주) 프로그래밍 개발 자료]
- software developer news : https://www.developer-tech.com/ [개발자 뉴스 ]
- 디지털타임즈 : http://www.dt.co.kr/ [국내 디지털 전자 뉴스]
- 당신을 위한 오프소스 : http://opensourceforu.com/ [오스소스 매거진]
- 자바세상 : http://www.javaworld.com/ [프로그래밍 언어 Java 뉴스]
- 데이터베이스 모델링 예제 : http://databaseanswers.org/ [RDB 모델링 예제]
- 각 언어별 gui 프로그래밍 예제 : http://zetcode.com/ [프로그래밍 예제]
- 자바 프로그래밍 스니핏 : http://www.java2s.com/ [java2s]
- Java code Samples : http://www.java2s.com/
- 온라인 동영상 강좌 [미주] : https://www.udemy.com/
- 온라인 동영상 강좌 [미주/구주] : https://tutsplus.com/
- 온라인 동영상 IT 강좌 [국내] : https://www.inflearn.com/
- 미술 드로잉 온라인 동영상강좌 : http://www.doyacart.com/ [도약아트]
- 한빛 출판 네트워크 : http://www.hanbit.co.kr/
- 한국 데이터베이스 진흥원 : http://www.dbguide.net/index.db
- 국가기술자격 [공학 기사][산업 기사] [기술사] 및 전문자격 : http://www.q-net.or.kr/
- 국가기술자격 [정보보안기사] : https://kisq.or.kr/
- 한국콘텐츠아카데미 : https://edu.kocca.kr/
- 미국 콘텐츠 뉴스 : https://www.yahoo.com/
- 미국 온라인 콘텐츠 : https://www.netflix.com/kr/
- 일본 콘텐츠 뉴스 : https://www.yahoo.co.jp/
- 일본 한게임 : http://www.hangame.co.jp/
- 한일 동시방영 애니메 : http://www.aniplustv.com/
- 한일 동시방영 일드 : http://www.chw.co.kr/
- 글로벌 사진 이미지 게시판 : http://www.4chan.org/
- [보안] 해커뉴스 : https://news.ycombinator.com/
- [보안] exploitDB : https://www.exploit-db.com/
- OLC Center : http://olc.kr [오픈소스 동영상 강좌-한국]
- tutorialpoint : https://www.tutorialspoint.com/index.htm [프로그래밍 튜토리얼]
- 스토리텔링 작성 : http://www.storyhelper.co.kr/ [스토리헬퍼]
- 특허정보검색(KIPRIS) : http://www.kipris.or.kr/khome/main.jsp
- 특허청(특허로) : http://www.patent.go.kr/portal/Main.do [지적재산권등록]
- 컴퓨터 소프트웨어 스킬 교육 (한국어) : http://www.ib96.com [IB96 아이비컴퓨터교육닷컴]
- EZen 이젠 온라인 에듀 : http://edu.ezenac.co.kr/
자주 들르는 곳 : Frequent stop : 贔屓のだんな
- happy codings : http://happycodings.com/ [source code sample]
- IONIC App framework : https://ionicframework.com/ [하이브리드 모바일앱 DEV]
- phaser : https://phaser.io/ [웹 HTML5 Game Dev]
- MongoDB ; https://www.mongodb.com/ [문서형 NoSQL DB]
- Cloudera : https://www.cloudera.com/ [빅데이터 Hadoop 배포판]
- cordova : https://cordova.apache.org/ [hybrid app framework]
- phonegap : http://phonegap.com/ [hybrid app framework]
- dbpia : http://www.dbpia.co.kr/Home [국내 논문 자료모음]
- 디바이스 마트 : http://www.devicemart.co.kr/ [국내 전자 재료 온라인 백화점][온라인 광도백화점]
- 메가스터디 대학과정 강좌 : http://www.megaenglish.net/university/
- EBS 직업 교육 방송 : http://www.ebs.co.kr/job
- 쓸만한 전자캐드 (Autodesk사) : https://www.autodesk.com/products/eagle/
- 日本 MSN : http://www.msn.com/ja-jp/?ocid=iehp&pc=EUPP_
- 스타트업 실패 사례 연구 : http://startupgraveyard.io/ 스타업 무덤
- 알고리즘 대회 : https://www.topcoder.com/ [topcoder]
- 데이터분석 대회 : https://www.kaggle.com/ [kaggle]
- 단계별 (step by step) 드로잉 강좌 : http://www.drawinghowtodraw.com/stepbystepdrawinglessons/
모바일 (게임)개발툴 사이트
- Unity : https://unity3d.com/kr/
- Corona Labs : https://coronalabs.com/
- YoYo Games : http://www.yoyogames.com/
- Contruct 2 : https://www.scirra.com/construct2
- firebase : https://firebase.google.com/
- parse : http://parseplatform.org/
- backendless : https://backendless.com/
- tyrano builder : http://tyranobuilder.com/
- rpg maker mv : http://www.rpgmakerweb.com/products/programs/rpg-maker-mv
- Phaser : https://phaser.io/
웹 (사이트) 개발
- 전자정부 표준 프레임워크 : https://www.egovframe.go.kr/
- 스프링 프레임워크 : https://projects.spring.io/spring-framework/
- django python : https://www.djangoproject.com/
- python micro framework : http://flask.pocoo.org/
- wordpress : https://ko.wordpress.org/
- 제로보드 xe: https://www.xpressengine.com/
- jQuery UI : https://jqueryui.com/
- jQuery Mobile : https://jquerymobile.com/
- Mean Stack : http://mean.io/
- Angular JS : https://angularjs.org/
- jqWidget : https://www.jqwidgets.com/
디지털 마켓
- MS Component market : https://www.componentsource.com/
- codecayon : https://codecanyon.net/
- http://www.chupamobile.com/
- ragdogstudios : http://ragdogstudios.com/
- 웹 디자인 시안 (아사달) : http://www.asadal.com/
멀티미디어 리소스 (마켓)
- 스프라이트 리소스 : https://www.spriters-resource.com/
- 스프라이트 데이터베이스 : http://spritedatabase.net/
- 오픈게임아트 : https://opengameart.org/content/700-sprites
- 게임아트 2D : http://www.gameart2d.com/
- 프리사운드 : https://www.freesound.org/
- 프리사운드이펙트 : http://soundbible.com/
- 블랜더 3D 모델링 : https://www.blender-models.com/
- 게임 3D model source : https://opengameart.org/content/game-ready-3d-models
- 게임 3D 캐릭터 model : https://free3d.com/3d-models/game-characters
- 구글 스케치업 모델 : https://3dwarehouse.sketchup.com/
- 블랜더 3D 모델 : https://blenderartists.org/
- 다양한 모델 다양한 포멧 : https://free3d.com
- 프리3d : https://free3d.com/
인문학과 사회와 재경학에 관심을 가져보자
- 와이즈리서치 : http://www.snscon.com/ [통계분석 리서치교육 : 사회조사분석사 대비]
오프라인 교육 기관
- 한국 사이버 보안 인재 센터(한국인터넷진흥원) : https://academy.kisa.or.kr/main.kisa
- 빅 데이터 아카데미 (한국데이터진흥원) : http://www.dbguide.net/bigacademy.db
![]()
stechstar.com 핫 이슈 연구 자료 [study data]
stechstar.com 핫 이슈 연구 자료 [study data]
- 인공지능 작곡 / 드로잉 (google tensorflow) Magenta(마젠타) : https://magenta.tensorflow.org/
- tensorflow mobile : https://www.tensorflow.org/mobile/
- pyClips (python Clips interface) : http://pyclips.sourceforge.net/web/
![]()
[一日30分 인생승리의 학습법] 소프트웨어 공학의 법칙들
[一日30分 인생승리의 학습법] 소프트웨어 공학의 법칙들
소프트웨어 공학의 법칙들
(lawsofsoftwareengineering.com)
- 소프트웨어 시스템, 팀, 의사결정에 영향을 미치는 56가지 원칙과 패턴을 한곳에 모은 컬렉션으로, 팀 운영부터 아키텍처, 품질, 설계, 의사결정까지 폭넓은 영역을 포괄
- Conway의 법칙, Brooks의 법칙, Dunbar의 수 등 팀 관련 법칙들은 조직 구조가 시스템 설계와 생산성에 직접적으로 영향을 미침
- 아키텍처 영역에서는 Hyrum의 법칙, CAP 정리, Gall의 법칙 등 복잡한 시스템 설계 시 반드시 고려해야 할 제약과 원칙을 정리
- 품질 관련 법칙들은 기술 부채, 테스팅 피라미드, Kernighan의 법칙 등 코드 품질 유지와 디버깅의 현실적 어려움을 다룸
- 의사결정 영역에서는 Dunning-Kruger 효과, 매몰 비용 오류, 파레토 원칙 등 개발 과정에서 빠지기 쉬운 인지 편향과 판단 기준을 포괄
팀(Teams)
1. Conway의 법칙 (Conway’s Law)
조직은 자신의 커뮤니케이션 구조를 그대로 반영하는 시스템을 설계한다
- 소프트웨어 아키텍처는 그것을 만든 조직의 소통 구조를 자연스럽게 따라가는 현상
- 팀이 3개로 나뉘어 있으면 시스템도 3개의 큰 모듈로 나뉘는 경향이 있음
- 이를 역으로 활용하는 “역 Conway 전략”(Inverse Conway Maneuver)도 존재: 원하는 아키텍처에 맞춰 팀 구조를 먼저 재편하는 접근
- 마이크로서비스 도입 시 팀 경계와 서비스 경계를 일치시키는 것이 효과적
2. Brooks의 법칙 (Brooks’s Law)
지연된 소프트웨어 프로젝트에 인력을 추가하면 오히려 더 늦어진다
- 신규 인력이 합류하면 기존 팀원이 교육과 조율에 시간을 소모하여 전체 생산성이 일시 저하
- 팀원이 늘어나면 커뮤니케이션 경로가 기하급수적으로 증가 (n명일 때 n(n-1)/2개)
- Frederick Brooks가 IBM OS/360 프로젝트 경험을 바탕으로 1975년 저서 The Mythical Man-Month에서 정립
- Little의 법칙(L = λ × W)으로 정량적 설명 가능: 인력 추가 시 WIP(작업 중인 항목)는 증가하지만 처리량(throughput)은 정체되어 리드 타임이 오히려 증가
- 해결책은 인력 추가가 아닌 범위 조정 또는 일정 변경
3. Dunbar의 수 (Dunbar’s Number)
한 사람이 안정적으로 유지할 수 있는 관계의 인지적 한계는 약 150명
- Robin Dunbar가 영장류 뇌 크기와 사회 집단 규모의 상관관계에서 도출한 수치
- Dunbar의 사회적 계층 구조: ~5명(친밀한 관계), ~15명(신뢰할 수 있는 협력자), ~50명(가까운 업무 관계), ~150명(안정적 사회적 연결)
- 엔지니어링 조직이 150명을 넘으면 비공식적 소통이 한계에 도달하여 공식적 계층과 프로세스 필요
- Amazon의 “Two-Pizza Team”(5~10명)은 150명 내에서도 실질적 협업은 더 작은 단위에서 일어남을 반영
4. Ringelmann 효과 (The Ringelmann Effect)
그룹 규모가 커질수록 개인의 생산성은 감소한다
- 그룹 구성원이 많아질수록 각 개인의 기여도가 줄어드는 “사회적 태만”(social loafing) 현상
- 소프트웨어 팀에서도 팀 크기가 커지면 개별 책임감이 희석되고 조율 비용이 증가
- 소규모 팀이 1인당 더 높은 산출물을 내는 이유를 설명
5. Price의 법칙 (Price’s Law)
전체 참여자 수의 제곱근에 해당하는 인원이 전체 작업의 50%를 수행한다
- 100명의 조직에서는 약 10명이 전체 작업의 절반을 담당
- 조직이 커질수록 소수의 고성과자에 대한 의존도가 심화
- 팀 확장 시 생산성이 선형으로 증가하지 않는 이유를 설명
6. Putt의 법칙 (Putt’s Law)
기술을 이해하는 사람은 관리하지 않고, 관리하는 사람은 기술을 이해하지 못한다
- 기술 조직에서 관리 역할과 기술 전문성의 괴리를 풍자적으로 표현
- 기술 리더십 구조를 설계할 때 이 간극을 인식하고 보완 장치를 마련해야 함
7. Peter 원칙 (Peter Principle)
조직 내에서 모든 직원은 자신의 무능력 수준까지 승진하는 경향이 있다
- 특정 역할에서 유능한 사람이 승진하여 새로운 역할에서는 무능력해지는 패턴
- 뛰어난 개발자가 반드시 좋은 매니저가 되지는 않는 현실을 반영
- IC(Individual Contributor) 트랙과 매니지먼트 트랙을 분리하는 듀얼 래더 체계의 필요성
8. Bus Factor
프로젝트가 심각한 위험에 처할 수 있는 최소 팀원 이탈 수
- Bus Factor가 1이면 단일 장애점(Single Point of Failure)이 존재하는 상태
- 지식 공유, 페어 프로그래밍, 문서화를 통해 Bus Factor를 높이는 것이 중요
- 코드 리뷰와 크로스 트레이닝이 Bus Factor를 개선하는 실질적 방법
9. Dilbert 원칙 (Dilbert Principle)
기업은 무능한 직원을 관리직으로 승진시켜 피해를 제한하는 경향이 있다
- Scott Adams가 제안한 풍자적 관찰로, Peter 원칙의 변형
- 관리직이 실무에서 가장 적은 피해를 주는 자리로 여겨지는 역설적 조직 현상
계획(Planning)
10. 조기 최적화 / Knuth의 최적화 원칙 (Premature Optimization)
조기 최적화는 모든 악의 근원이다
- Donald Knuth가 1974년 논문에서 제시: “약 97%의 경우에서 작은 효율성은 무시해야 한다”
- 코드의 약 20%가 실행 시간의 80%를 차지하므로, 나머지 80% 코드를 최적화하는 것은 낭비
- 올바른 순서: 먼저 동작하게 만들고 → 올바르게 만들고 → 필요하면 빠르게 만들 것
- 최적화된 코드는 복잡성이 높아지므로, 프로파일링을 통해 실제 병목 지점을 확인한 후 수행해야 함
11. Parkinson의 법칙 (Parkinson’s Law)
업무는 주어진 시간을 모두 채울 때까지 확장한다
- 데드라인이 2주면 2주, 4주면 4주 동안 일이 늘어나는 현상
- 소프트웨어 프로젝트에서 짧고 명확한 마일스톤 설정이 중요한 이유
- 스프린트 기반 애자일이 이 법칙에 대한 실질적 대응 방법
12. 90-90 법칙 (The Ninety-Ninety Rule)
코드의 처음 90%가 개발 시간의 90%를 차지하고, 나머지 10%가 또 다른 90%의 시간을 차지한다
- 소프트웨어 프로젝트의 마지막 10%(엣지 케이스, 폴리싱, 버그 수정)가 예상보다 훨씬 오래 걸림을 경고
- “거의 완성”이라는 말이 실제로는 전체 일정의 절반 지점일 수 있음
13. Hofstadter의 법칙 (Hofstadter’s Law)
Hofstadter의 법칙을 고려하더라도 항상 예상보다 오래 걸린다
- 재귀적 자기 참조 구조를 가진 법칙으로, 소프트웨어 일정 추정의 본질적 어려움을 표현
- 버퍼를 추가해도 여전히 일정이 초과되는 현실
- Douglas Hofstadter가 1979년 저서 Gödel, Escher, Bach에서 소개
14. Goodhart의 법칙 (Goodhart’s Law)
측정 지표가 목표가 되면 더 이상 좋은 측정 지표가 아니다
- 코드 커버리지를 KPI로 설정하면 의미 없는 테스트를 양산하는 현상이 대표적 사례
- 코드 라인 수(LOC)로 생산성을 측정하면 불필요하게 장황한 코드가 생산됨
- 지표 최적화가 아닌 본질적 가치 달성에 집중해야 함
15. Gilb의 법칙 (Gilb’s Law)
정량화가 필요한 것은 측정하지 않는 것보다 어떤 방식으로든 측정하는 것이 나다
- 완벽한 측정이 불가능하더라도 대략적 측정이 무측정보다 항상 유익
- 소프트웨어 품질, 사용자 만족도 등 정량화가 어려운 항목에도 적용
아키텍처(Architecture)
16. Hyrum의 법칙 (Hyrum’s Law)
API 사용자가 충분히 많으면, 시스템의 모든 관찰 가능한 동작에 누군가 의존한다
- 공식 API 명세뿐 아니라 타이밍, 에러 메시지 형식, 정렬 순서 등 비공식적 동작도 의존 대상이 됨
- Microsoft Windows가 과거 문서화되지 않은 동작과 버그에 의존하는 서드파티 앱 호환을 위해 구버전 동작을 유지한 사례
- Google의 Hyrum Wright가 2011-2012년경 Google 내부 라이브러리 변경 경험에서 관찰
- 동료 Titus Winters가 “Hyrum’s Law”라는 이름을 붙임 (Software Engineering at Google 수록)
- 실질적 계약은 공식 API가 아니라 실제 관찰되는 동작 전체
17. Gall의 법칙 (Gall’s Law)
작동하는 복잡한 시스템은 반드시 작동하는 단순한 시스템에서 진화한 결과이다
- 처음부터 복잡한 시스템을 설계하면 검증되지 않은 미지의 변수가 너무 많아 실패 확률이 높음
- MVP(Minimum Viable Product) 접근의 이론적 근거
- Facebook이 2004년 Harvard 학생용 단순 프로필 시스템에서 시작하여 점진적으로 확장한 사례
- 마이크로서비스 전환 시에도 모놀리스에서 시작하여 점진적으로 분리하는 것이 유리
- John Gall이 1975년 저서 Systemantics에서 제시 (30개 출판사가 거절 후 출간된 컬트 클래식)
18. 누수 추상화의 법칙 (The Law of Leaky Abstractions)
모든 비자명(non-trivial) 추상화는 어느 정도 누수가 발생한다
- ORM이 SQL을 숨기지만 성능 문제가 발생하면 결국 생성되는 쿼리를 확인해야 하는 상황이 대표 사례
- Java/Python의 가비지 컬렉션도 추상화이지만 GC 일시정지 같은 내부 동작이 성능에 영향을 미침
- 추상화 자체가 나쁜 것이 아니라, 추상화가 깨질 때를 대비해야 한다는 교훈
- Joel Spolsky가 2002년 블로그 포스트에서 TCP, 가상 메모리 등의 사례와 함께 소개
- George Box의 “모든 모델은 틀렸지만, 일부는 유용하다“와도 맥락 연결
19. Tesler의 법칙 / 복잡성 보존 법칙 (Tesler’s Law)
모든 애플리케이션에는 제거할 수 없는 고유 복잡성이 있으며, 이동만 가능하고 제거는 불가능하다
- 핵심 질문: 복잡성을 누가 감당할 것인가 (사용자 vs 시스템)
- Calendly는 일정 조율의 복잡성을 시스템이 흡수하고, 이메일 스레드는 사용자에게 전가하는 차이
- 좋은 설계는 복잡성을 사용자 경험에서 시스템 내부로 이동시킴
- Larry Tesler가 Apple Lisa 및 초기 GUI 작업 중 1980년대에 정립
20. CAP 정리 (CAP Theorem)
분산 시스템은 일관성(C), 가용성(A), 분할 내성(P) 중 두 가지만 보장 가능하다
- 네트워크 파티션은 현실에서 불가피하므로, 실질적 선택은 일관성 vs 가용성
- CP 시스템 (예: MongoDB): 파티션 발생 시 쓰기를 차단하여 모든 레플리카 동기화 유지
- AP 시스템 (예: Cassandra, DNS): 파티션 중에도 요청 응답 유지, 레플리카 간 일시적 불일치 허용
- Eric Brewer가 2000년에 웹 서비스 맥락에서 제안, Gilbert & Lynch가 2002년에 공식 증명
21. Second-System 효과 (Second-System Effect)
작고 성공적인 시스템 다음에는 과도하게 설계된 비대한 후속 시스템이 뒤따르는 경향
- 첫 번째 시스템의 성공에 자신감을 얻어 두 번째 시스템에 모든 아이디어를 쏟아붓는 패턴
- 기능 과잉(feature creep)과 과도한 일반화(over-generalization)가 주된 원인
- Frederick Brooks가 The Mythical Man-Month에서 식별
22. 분산 컴퓨팅의 오류 (Fallacies of Distributed Computing)
분산 시스템을 처음 설계하는 사람들이 흔히 갖는 8가지 잘못된 가정
- 8가지 오류: (1) 네트워크는 신뢰할 수 있다, (2) 지연 시간은 0이다, (3) 대역폭은 무한하다, (4) 네트워크는 안전하다, (5) 토폴로지는 변하지 않는다, (6) 관리자가 한 명이다, (7) 전송 비용은 0이다, (8) 네트워크는 균일하다
- 이 가정들을 기반으로 설계하면 프로덕션에서 예기치 않은 장애와 성능 문제가 발생
23. 의도하지 않은 결과의 법칙 (Law of Unintended Consequences)
복잡한 시스템을 변경하면 예기치 않은 결과를 예상해야 한다
- 시스템 하나의 컴포넌트를 변경하면 예측하지 못한 곳에서 부작용이 발생
- 카오스 엔지니어링과 포괄적 테스팅의 필요성을 뒷받침하는 원칙
24. Zawinski의 법칙 (Zawinski’s Law)
모든 프로그램은 메일을 읽을 수 있을 때까지 확장을 시도한다
- 소프트웨어가 성공하면 점점 더 많은 기능을 추가하려는 기능 팽창(feature bloat) 현상을 풍자
- Jamie Zawinski(Netscape 초기 개발자)가 관찰
- 단순한 도구가 시간이 지나면 만능 플랫폼이 되려 하는 경향에 대한 경고
품질(Quality)
25. Boy Scout 규칙 (The Boy Scout Rule)
코드를 발견한 것보다 더 나은 상태로 남겨야 한다
- 대규모 리팩토링이 아닌 지속적이고 점진적인 개선이 핵심
- 혼란스러운 함수명 수정, 중복 코드 제거, 누락된 테스트 추가 등 매번 작은 개선을 실천
- Robert C. Martin(Uncle Bob)이 Clean Code(2008)에서 소프트웨어 개발에 적용
- Google 엔지니어들의 원칙 “If you touch it, you own it” — 코드를 수정하면 그 품질에 대한 책임도 함께 가져감
- 이 규칙을 실천하면 깨진 유리창 효과(Broken Windows)를 예방하고 기술 부채 축적을 방지
26. Murphy의 법칙 (Murphy’s Law)
잘못될 수 있는 것은 반드시 잘못된다
- 방어적 프로그래밍, 예외 처리, 장애 대비 설계의 근거
- 소프트웨어에서는 “일어날 수 있는 에러는 반드시 일어난다”는 자세로 에러 핸들링과 폴백을 설계해야 함
27. Postel의 법칙 / 견고성 원칙 (Postel’s Law)
자신이 하는 일에는 보수적으로, 타인으로부터 받는 것에는 관대하게
- API 설계 시 출력은 엄격하게 스펙을 준수하되, 입력은 다양한 형식을 유연하게 수용하는 원칙
- Jon Postel이 TCP/IP 프로토콜 설계 시 수립한 견고성 원칙(Robustness Principle)
- 시스템 간 상호운용성을 높이는 실질적 가이드라인
28. 깨진 유리창 이론 (Broken Windows Theory)
나쁜 설계, 잘못된 결정, 저품질 코드를 방치하지 말 것
- 하나의 “깨진 유리창”(나쁜 코드)이 방치되면 추가적인 품질 저하를 유발
- 코드베이스에 TODO 주석, 죽은 코드, 미해결 경고가 쌓이면 새로운 코드도 낮은 수준으로 작성되는 경향
- 발견 즉시 작은 문제라도 수정하는 문화가 중요
29. 기술 부채 (Technical Debt)
소프트웨어 개발 속도를 저하시키는 모든 요소
- Ward Cunningham이 1992년 OOPSLA에서 금융 메타포로 처음 사용: 코드 지름길을 택하면 미래에서 시간을 빌리는 것
- 원금(수정 비용) + 이자(지저분한 코드로 인한 지속적 생산성 저하)
- 의도적 기술 부채는 때로 합리적 (시장 출시 타이밍, 프로토타이핑)이지만 상환 계획이 필수
- 자동화 테스트 생략이 대표적 사례: 릴리스는 성공하지만 이후 변경 시마다 예상치 못한 버그 발생
- 해결 방법: 리팩토링, 누락 테스트 추가, 설계 개선
30. Linus의 법칙 (Linus’s Law)
충분한 수의 검토자가 있으면 모든 버그는 쉽게 발견된다
- 오픈소스 개발의 핵심 원리: 다수의 눈이 코드를 검토하면 버그가 사소한 문제가 됨
- Eric Raymond가 The Cathedral and the Bazaar에서 Linus Torvalds의 이름을 따 명명
- 코드 리뷰 문화의 중요성을 뒷받침
31. Kernighan의 법칙 (Kernighan’s Law)
디버깅은 코드를 처음 작성하는 것보다 두 배 어렵다
- 따라서 최대한 영리하게 코드를 작성하면, 디버깅할 때 충분히 영리하지 못하게 됨
- 가독성 높은 단순한 코드를 작성해야 하는 이유
- Brian Kernighan이 The Elements of Programming Style에서 제시
32. 테스팅 피라미드 (Testing Pyramid)
프로젝트는 빠른 단위 테스트를 많이, 통합 테스트는 적게, UI 테스트는 소수만 보유해야 한다
- 단위 테스트(하단): 빠르고 저비용, 가장 많이 작성
- 통합 테스트(중간): 컴포넌트 간 상호작용 검증
- UI/E2E 테스트(상단): 느리고 깨지기 쉬우므로 최소화
- Mike Cohn이 Succeeding with Agile에서 소개한 테스트 전략 모델
33. 살충제 역설 (Pesticide Paradox)
동일한 테스트를 반복 실행하면 시간이 지남에 따라 효과가 감소한다
- 기존 테스트가 이미 잡을 수 있는 버그는 다 잡았으므로, 새로운 테스트 케이스를 지속적으로 추가해야 함
- 테스트 세트를 정기적으로 검토하고 업데이트하는 것이 필수
34. Lehman의 소프트웨어 진화 법칙 (Lehman’s Laws of Software Evolution)
현실 세계를 반영하는 소프트웨어는 반드시 진화해야 하며, 그 진화에는 예측 가능한 한계가 존재한다
- E-type(현실 세계를 반영하는) 소프트웨어는 사용되려면 지속적 변경이 불가피
- 변경 시마다 복잡성이 증가하며, 이를 적극적으로 관리하지 않으면 품질이 저하
35. Sturgeon의 법칙 (Sturgeon’s Law)
모든 것의 90%는 쓸모없다
- Theodore Sturgeon이 SF 문학 비평에 대응하여 제시
- 소프트웨어에도 적용: 대부분의 코드, 도구, 프레임워크 중 진정으로 훌륭한 것은 소수
- 품질에 대한 높은 기준을 유지하고, 가치 있는 10%에 집중하는 자세 필요
스케일(Scale)
36. Amdahl의 법칙 (Amdahl’s Law)
병렬화로 인한 속도 향상은 병렬화할 수 없는 작업 비율에 의해 제한된다
- 프로그램의 5%가 순차적이면 아무리 많은 프로세서를 투입해도 이론적 최대 속도 향상은 20배
- 병렬화의 한계를 인식하고 순차적 병목 구간을 줄이는 것이 더 효과적
- Gene Amdahl이 1967년에 제시
37. Gustafson의 법칙 (Gustafson’s Law)
문제 크기를 늘림으로써 병렬 처리에서 상당한 속도 향상을 달성할 수 있다
- Amdahl의 법칙에 대한 보완적 관점: 고정된 문제가 아닌 확장 가능한 문제에서는 프로세서 추가가 효과적
- 빅데이터 처리, 과학 시뮬레이션 등에서 더 많은 리소스로 더 큰 문제를 풀 수 있음
38. Metcalfe의 법칙 (Metcalfe’s Law)
네트워크의 가치는 사용자 수의 제곱에 비례한다
- 사용자가 10명이면 가치는 100 단위, 100명이면 10,000 단위로 증가
- 소셜 네트워크, 메신저, 마켓플레이스 등 네트워크 효과의 이론적 기반
- Robert Metcalfe가 이더넷 기술의 가치를 설명하기 위해 제시
설계(Design)
39. DRY 원칙 (Don’t Repeat Yourself)
모든 지식은 단일하고 명확하며 권위 있는 하나의 표현만 가져야 한다
- 코드 중복뿐 아니라 지식, 로직, 데이터의 중복도 포함
- 중복은 변경 시 여러 곳을 동시에 수정해야 하므로 버그와 불일치의 원인
- Andy Hunt와 Dave Thomas가 The Pragmatic Programmer에서 정립
40. KISS 원칙 (Keep It Simple, Stupid)
설계와 시스템은 가능한 한 단순해야 한다
- 복잡성은 이해, 유지보수, 디버깅의 비용을 증가시킴
- 단순한 해결책이 대부분의 경우 더 효과적이며 결함 가능성도 낮음
- 미국 해군이 1960년대에 제시한 설계 원칙에서 유래
41. SOLID 원칙 (SOLID Principles)
소프트웨어 설계를 향상시키는 5가지 핵심 가이드라인
- S — 단일 책임 원칙(Single Responsibility): 클래스는 하나의 이유로만 변경
- O — 개방-폐쇄 원칙(Open-Closed): 확장에 열려 있고 수정에 닫혀 있어야 함
- L — Liskov 치환 원칙: 하위 타입은 상위 타입을 대체할 수 있어야 함
- I — 인터페이스 분리 원칙: 클라이언트는 사용하지 않는 인터페이스에 의존하지 않아야 함
- D — 의존성 역전 원칙: 상위 모듈이 하위 모듈에 의존하지 않고 추상화에 의존
- Robert C. Martin이 정립하고 Michael Feathers가 SOLID라는 약어를 명명
42. 디미터 법칙 (Law of Demeter)
객체는 직접적인 친구와만 상호작용해야 하며, 낯선 객체와의 직접 소통은 지양해야 한다
a.getB().getC().doSomething()같은 체인 호출을 피해야 한다는 원칙- 결합도를 낮추고 캡슐화를 강화하여 변경 영향 범위를 줄임
- “최소 지식의 원칙”이라고도 불림
43. 최소 놀라움의 원칙 (Principle of Least Astonishment)
소프트웨어와 인터페이스는 사용자와 다른 개발자를 가장 적게 놀라게 하는 방식으로 동작해야 한다
- 함수, API, UI가 이름과 컨벤션에서 예측 가능한 동작을 해야 함
delete()함수가 실제로는 아카이브만 한다면 놀라움을 유발 → 설계 결함- 직관적이지 않은 동작은 버그와 사용자 실수를 초래
44. YAGNI (You Aren’t Gonna Need It)
필요하기 전까지 기능을 추가하지 말 것
- Extreme Programming(XP)의 핵심 원칙으로 1990년대 후반 Ron Jeffries가 제시
- “미래에 필요할지 모른다”는 이유로 코드를 작성하면 과잉 설계와 유지보수 부담 발생
- 리팩토링에 대한 자신감(좋은 테스트 커버리지, CI)이 있어야 YAGNI를 실천 가능
- 현재 JSON 내보내기만 필요하면 JSON만 구현, XML/YAML 등은 요구될 때 추가
의사결정(Decisions)
45. Dunning-Kruger 효과 (Dunning-Kruger Effect)
어떤 것에 대해 적게 알수록 더 자신감을 갖는 경향이 있다
- 초보 개발자가 복잡한 시스템의 난이도를 과소평가하거나, 전문가가 오히려 자신의 지식에 겸손한 현상
- 코드 리뷰, 멘토링, 지속 학습을 통해 자기 인식의 정확성을 높이는 것이 중요
46. Hanlon의 면도날 (Hanlon’s Razor)
어리석음이나 부주의로 충분히 설명되는 것을 악의로 돌리지 말 것
- 동료의 나쁜 코드나 잘못된 결정을 의도적 방해로 해석하기 전에 무지, 실수, 시간 부족을 먼저 고려
- 팀 내 신뢰와 건설적 커뮤니케이션의 기반
47. Occam의 면도날 (Occam’s Razor)
가장 단순한 설명이 가장 정확한 경우가 많다
- 디버깅 시 복잡한 원인보다 가장 단순한 가능성부터 먼저 확인
- 아키텍처 설계에서도 불필요한 추상화 레이어를 추가하기 전에 단순한 해결책을 우선 탐색
48. 매몰 비용 오류 (Sunk Cost Fallacy)
시간이나 에너지를 투자했다는 이유만으로 손해가 되는 선택을 계속 유지하는 현상
- 6개월 동안 개발한 기능이 잘못된 방향이었더라도 투자한 시간 때문에 버리지 못하는 심리
- 올바른 결정은 과거 투자가 아닌 미래 가치를 기준으로 해야 함
49. 지도는 영토가 아니다 (The Map Is Not the Territory)
현실에 대한 표현(모델)은 현실 자체와 동일하지 않다
- UML 다이어그램, 아키텍처 문서, 데이터 모델 등은 현실의 근사치일 뿐
- 모델을 맹신하지 말고, 실제 시스템의 동작을 관찰하며 모델을 갱신해야 함
50. 확증 편향 (Confirmation Bias)
기존 믿음이나 아이디어를 지지하는 정보를 선호하는 경향
- 자신이 선택한 기술 스택이나 설계 결정에 유리한 정보만 선별적으로 수집하는 함정
- 반대 증거를 적극적으로 탐색하고 다양한 관점을 수용하는 것이 균형 잡힌 의사결정의 핵심
51. Hype Cycle과 Amara의 법칙 (The Hype Cycle & Amara’s Law)
기술의 단기 효과는 과대평가하고, 장기 영향은 과소평가하는 경향이 있다
- Gartner의 Hype Cycle: 기술 촉발 → 과도한 기대의 정점 → 환멸의 골짜기 → 계몽의 경사 → 생산성 안정기
- 새 기술(블록체인, AI 등)을 도입할 때 단기 과열에 휩쓸리지 말고 장기적 실용성을 평가해야 함
52. Lindy 효과 (The Lindy Effect)
오래 사용된 것일수록 앞으로도 계속 사용될 가능성이 높다
- UNIX, SQL, C 언어처럼 수십 년간 사용된 기술은 앞으로도 오래 생존할 가능성이 높음
- 새로운 프레임워크보다 검증된 기술을 선택할 때의 이론적 근거
- Nassim Nicholas Taleb이 Antifragile에서 대중화
53. 제1원리 사고 (First Principles Thinking)
복잡한 문제를 가장 기본적인 구성 요소로 분해한 후 그로부터 재구축하는 사고법
- 기존 관행과 가정을 제거하고 근본적 진실에서 출발하여 해결책을 도출
- Elon Musk가 SpaceX 로켓 비용 절감에 적용한 사례로 유명
- 복잡한 시스템 설계 시 “원래 다 그렇게 하니까”라는 사고를 경계
54. 역전 사고 (Inversion)
반대 결과를 상정하고 거꾸로 추론하여 문제를 해결하는 방법
- “어떻게 성공할까” 대신 “어떻게 하면 실패할까” 를 먼저 생각하여 위험 요소를 식별
- 장애 모드 분석(Failure Mode Analysis)과 프리모템(Pre-mortem)의 이론적 근거
- Charlie Munger가 자주 활용하는 멘탈 모델
55. 파레토 원칙 / 80/20 법칙 (Pareto Principle)
문제의 80%는 원인의 20%에서 발생한다
- 전체 버그의 80%가 코드의 20%에 집중되어 있는 경향
- 가장 영향력이 큰 20%에 리소스를 집중하는 것이 효율적 자원 배분 전략
- Vilfredo Pareto가 이탈리아 토지 소유 분포에서 관찰한 원리에서 유래
56. Cunningham의 법칙 (Cunningham’s Law)
인터넷에서 정확한 답을 얻는 가장 좋은 방법은 질문이 아니라 틀린 답을 게시하는 것이다
- 사람들은 질문에 답하는 것보다 잘못된 정보를 교정하는 데 더 적극적으로 참여
- Ward Cunningham(Wiki 발명자)의 이름을 딴 법칙이지만, 실제로는 Steven McGeady가 이 이름을 붙임
- 오픈소스 커뮤니티에서 문서화나 지식 공유에 활용 가능한 통찰
[출처] https://news.hada.io/topic?id=28760
![]()
[一日30分 인생승리의 학습법] 기술 부채, 인지 부채, 의도 부채
[一日30分 인생승리의 학습법] 기술 부채, 인지 부채, 의도 부채
프로덕션 환경에서 바이브 코딩을 책임감 있게 하는 법 – Vibe coding in prod | Code w/ Claude
(youtube.com)
Anthropic의 코딩 에이전트 연구자 Eric이 바이브 코딩(AI에게 코드 작성을 전적으로 맡기는 방식)을 실제 서비스 환경에서 어떻게 안전하게 활용할 수 있는지를 다룬 발표입니다. 단순히 AI로 코드를 많이 생성하는 것과 바이브 코딩은 다르며, Andrej Karpathy의 정의처럼 “코드가 존재한다는 사실 자체를 잊는 것”이 핵심이라고 설명합니다. AI가 처리할 수 있는 작업 규모가 7개월마다 두 배로 늘고 있는 상황에서, 이 흐름을 활용하지 못하면 경쟁에서 뒤처질 수밖에 없다는 문제의식에서 출발합니다.
핵심 주장
- 바이브 코딩의 원칙은 “코드는 잊되, 제품은 잊지 말 것”입니다. 컴파일러가 생성한 어셈블리를 일일이 읽지 않듯, AI가 작성한 코드 자체보다 결과물의 품질과 정확성을 검증하는 데 집중해야 한다고 봅니다.
- 개발자의 역할이 직접 구현하는 사람에서 Claude의 프로덕트 매니저(PM)로 전환되어야 합니다. 신입 엔지니어에게 업무를 맡길 때처럼, 요구사항과 코드베이스 맥락, 제약조건을 충분히 정리해 AI에 전달하는 과정이 15~20분 이상 소요되더라도 그 투자가 성공률을 크게 높인다고 합니다.
- 바이브 코딩은 코드베이스의 리프 노드(다른 코드가 의존하지 않는 말단 기능)에 집중해야 합니다. 핵심 아키텍처나 다른 모듈이 의존하는 근간 코드는 여전히 사람이 깊이 이해하고 관리해야 합니다.
- 검증 가능성 설계가 필수적입니다. Anthropic 내부에서 22,000줄 규모의 강화학습 코드를 Claude로 작성해 프로덕션에 머지한 사례에서, 스트레스 테스트와 입출력 기반 검증 체크포인트를 설계해 코드를 전부 읽지 않고도 안정성과 정확성을 확인했다고 합니다.
현재의 한계
- 기술 부채(tech debt)는 코드를 직접 읽지 않고는 측정하거나 검증할 좋은 방법이 아직 없습니다. 이 점이 바이브 코딩을 리프 노드에 한정해야 하는 가장 큰 이유입니다.
- 비개발자가 보안이나 결제 같은 민감한 영역까지 바이브 코딩으로 프로덕션 시스템을 구축하는 것은 위험합니다. 올바른 질문을 던질 수 있는 기술적 판단력이 전제되어야 합니다.
차별점
- 바이브 코딩을 단순한 유행이 아닌 소프트웨어 산업의 구조적 전환으로 프레이밍하고, CTO가 전문가를 관리하거나 CEO가 회계사의 업무를 검증하는 것처럼 “구현을 모르면서도 결과를 검증하는 문제”는 문명만큼 오래된 과제라는 점을 짚은 것이 인상적입니다.
시사점
- 소프트웨어 엔지니어에게 요구되는 역량이 코드 한 줄 한 줄을 쓰는 능력에서, 요구사항을 정밀하게 정의하고 결과를 구조적으로 검증하는 능력으로 이동하고 있습니다. AI 도구의 성능 향상 속도를 고려하면, 이 전환에 적응하는 시점이 빠를수록 유리할 것으로 보입니다.
[출처] https://news.hada.io/topic?id=28824
![]()
[인공지능 개발자] 프로덕션 환경에서 바이브 코딩을 책임감 있게 하는 법 – Vibe coding in prod
[인공지능 개발자] 프로덕션 환경에서 바이브 코딩을 책임감 있게 하는 법 – Vibe coding in prod
프로덕션 환경에서 바이브 코딩을 책임감 있게 하는 법 – Vibe coding in prod | Code w/ Claude
(youtube.com)
Anthropic의 코딩 에이전트 연구자 Eric이 바이브 코딩(AI에게 코드 작성을 전적으로 맡기는 방식)을 실제 서비스 환경에서 어떻게 안전하게 활용할 수 있는지를 다룬 발표입니다. 단순히 AI로 코드를 많이 생성하는 것과 바이브 코딩은 다르며, Andrej Karpathy의 정의처럼 “코드가 존재한다는 사실 자체를 잊는 것”이 핵심이라고 설명합니다. AI가 처리할 수 있는 작업 규모가 7개월마다 두 배로 늘고 있는 상황에서, 이 흐름을 활용하지 못하면 경쟁에서 뒤처질 수밖에 없다는 문제의식에서 출발합니다.
핵심 주장
- 바이브 코딩의 원칙은 “코드는 잊되, 제품은 잊지 말 것”입니다. 컴파일러가 생성한 어셈블리를 일일이 읽지 않듯, AI가 작성한 코드 자체보다 결과물의 품질과 정확성을 검증하는 데 집중해야 한다고 봅니다.
- 개발자의 역할이 직접 구현하는 사람에서 Claude의 프로덕트 매니저(PM)로 전환되어야 합니다. 신입 엔지니어에게 업무를 맡길 때처럼, 요구사항과 코드베이스 맥락, 제약조건을 충분히 정리해 AI에 전달하는 과정이 15~20분 이상 소요되더라도 그 투자가 성공률을 크게 높인다고 합니다.
- 바이브 코딩은 코드베이스의 리프 노드(다른 코드가 의존하지 않는 말단 기능)에 집중해야 합니다. 핵심 아키텍처나 다른 모듈이 의존하는 근간 코드는 여전히 사람이 깊이 이해하고 관리해야 합니다.
- 검증 가능성 설계가 필수적입니다. Anthropic 내부에서 22,000줄 규모의 강화학습 코드를 Claude로 작성해 프로덕션에 머지한 사례에서, 스트레스 테스트와 입출력 기반 검증 체크포인트를 설계해 코드를 전부 읽지 않고도 안정성과 정확성을 확인했다고 합니다.
현재의 한계
- 기술 부채(tech debt)는 코드를 직접 읽지 않고는 측정하거나 검증할 좋은 방법이 아직 없습니다. 이 점이 바이브 코딩을 리프 노드에 한정해야 하는 가장 큰 이유입니다.
- 비개발자가 보안이나 결제 같은 민감한 영역까지 바이브 코딩으로 프로덕션 시스템을 구축하는 것은 위험합니다. 올바른 질문을 던질 수 있는 기술적 판단력이 전제되어야 합니다.
차별점
- 바이브 코딩을 단순한 유행이 아닌 소프트웨어 산업의 구조적 전환으로 프레이밍하고, CTO가 전문가를 관리하거나 CEO가 회계사의 업무를 검증하는 것처럼 “구현을 모르면서도 결과를 검증하는 문제”는 문명만큼 오래된 과제라는 점을 짚은 것이 인상적입니다.
시사점
- 소프트웨어 엔지니어에게 요구되는 역량이 코드 한 줄 한 줄을 쓰는 능력에서, 요구사항을 정밀하게 정의하고 결과를 구조적으로 검증하는 능력으로 이동하고 있습니다. AI 도구의 성능 향상 속도를 고려하면, 이 전환에 적응하는 시점이 빠를수록 유리할 것으로 보입니다.
[출처] https://news.hada.io/topic?id=28749
![]()
[인공지능 개발자] AI 코딩 시대, 성장이 멈추는 개발자의 뇌에서 일어나는 일
[인공지능 개발자] AI 코딩 시대, 성장이 멈추는 개발자의 뇌에서 일어나는 일
AI 코딩 시대, 성장이 멈추는 개발자의 뇌에서 일어나는 일
(evan-moon.github.io)
TL;DR;
- AI를 잘 쓰는 핵심 역량은 출력물의 품질을 판단하고 교정하는 능력이며, 이 능력은 AI에 의존할수록 오히려 약화됨
- Bjork의 “바람직한 어려움” 이론에 따르면, 쉽게 처리한 정보는 장기 기억에 남지 않음
- Roediger & Karpicke(2006) 연구에서 인출 연습 그룹의 일주일 후 기억 보존율이 반복 읽기 그룹보다 약 50% 높았음
- AI가 코드를 대신 작성하면 본질적 인지 부하(germane load) 까지 제거되어 스키마 형성 기회 자체가 사라짐
- 숙련된 개발자일수록 신경 효율성으로 인해 AI 출력을 읽는 것만으로는 뇌에 걸리는 부하가 거의 없음
- AI 이전에도 성장이 멈추는 경로는 존재했지만, AI는 그 경로의 마찰을 극적으로 제거함
상세 요약
AI를 잘 쓰려면 코드를 알아야 하는 역설
- “이걸 만들어줘”라고 말할 수 있는 사람은 많지만, AI 결과물을 보고 “이 구조는 변경에 취약하다”, “이 인터페이스는 두 가지 책임을
가지고 있다”고 구체적으로 교정할 수 있는 사람은 훨씬 적음 - 이 능력은 수많은 실패와 디버깅과 리팩토링 경험에서 형성된 직감에 가까움
- AI 사용법 학습과 코드 패턴 학습은 양자택일 관계가 아니라, 후자가 전자의 토대인 관계임
- “AI를 가장 잘 활용할 수 있는 개발자는 AI 없이도 코드를 판단할 수 있는 개발자”
뇌는 편하면 기억하지 않는다
- Bjork의 “바람직한 어려움”: 학습 과정에 적절한 난이도와 저항이 존재할 때 단기 수행은 느려지지만 장기 기억 보존과 전이는 향상됨
- Roediger & Karpicke(2006): 반복 읽기 vs 인출 연습 실험
- 5분 후 테스트: 반복 읽기 그룹 성적이 더 높음
- 일주일 후 재테스트: 인출 연습 그룹의 기억 보존율이 약 50% 더 높음
- 능동적 인출 그룹은 해마–전두엽 피질 연결성이 강화되고 감각운동 네트워크 활성도 증가
- 수동 학습 상태의 뇌는 해마–방추상회 연결만 활성화 — “정보를 보고 있을 뿐 처리하지 않는 것”에 가까움
- 생성 효과 (Slamecka & Graf, 1978): “뜨거운-차___” 처럼 직접 완성한 그룹이 완성된 쌍을 읽은 그룹보다 기억 보존율이 유의미하게 높음
- 유창성의 착각: 정보를 쉽게 처리할 수 있다는 느낌이 잘 기억할 것이라는 착각으로 이어짐
코딩 실력은 절차 기억이다
- 코딩 실력의 상당 부분은 절차 기억 — 자전거 타기처럼 한번 체화되면 의식하지 않아도 자동 실행됨
- Anderson의 적응적 사고 통제(ACT) 모델: 절차 기억 형성 3단계
- 인지 단계: 모든 것을 의식적으로 한 단계씩 실행, 작업 기억 대부분 소모
- 연합 단계: 개별 절차들이 통합되어 하나의 흐름으로 실행 가능
- 자동화 단계: 작업 기억 거의 차지하지 않고 자동 실행 — 남은 여유를 설계 판단에 활용 가능
- 단계 전환은 반복적인 직접 수행을 통해서만 진행됨
- 청킹 (Chase & Simon 체스 연구): 전문가와 초보자의 차이는 작업 기억 슬롯 수가 아니라, 하나의 청크에 담을 수 있는 정보의 양
- 체스 고수는 말의 개별 위치가 아닌 “시실리안 디펜스의 전형적인 중반 배치” 같은 의미 있는 패턴을 하나의 청크로 인식
- 무작위 배치 실험에서 고수와 초보자 차이가 사라짐으로써 입증됨
AI는 이 과정을 방해한다
- AI에게 구현을 맡기면 본질적 인지 부하(germane load) 까지 AI가 대신 처리 — 스키마 구축 기회 자체가 사라짐
- 절차 기억 관점: 인지 단계에서 끙끙대는 시간이 줄어 연합 단계 전환이 지연되고 자동화 단계 도달이 어려워짐
- AI 출력 코드를 읽는 것은 생성 효과 실험의 “완성된 단어 쌍을 읽는 것”에 해당 — 이해한 것 같지만 깊이 각인되지 않음
- 숙련된 개발자일수록 신경 효율성으로 코드를 더 적은 자원으로 처리 → AI 출력 읽기는 생각보다 뇌에 부하를 거의 걸지 않음
- 직접 코드를 짤 때는 예측–피드백 루프로 시냅스가 수정되지만, 완성된 AI 코드 읽기는 예측 과정이 생략된 사후 해석에 불과함
- 주니어에게 특히 심각: 인지 단계에 있는 패턴이 많은 상태에서 AI가 그 단계를 건너뛰게 하면 절차 기억 형성 없이 경력만 쌓임
뇌에 부하를 거는 방법
- AI에게 맡기기 전에 먼저 자신의 설계안 작성: 생성 효과를 의도적으로 활용 — AI 출력과 비교·평가하는 과정에서 뇌의 의미 처리와 실행
제어 영역이 동시 활성화 - 진지한 코드 리뷰: “왜 이 구조인가”, “6개월 뒤에 수정한다면 어디가 문제가 될까”를 의식적으로 묻는 것 — 귀찮음 자체가 바람직한
어려움 - 직접 코드를 짜보는 시간 확보: 절차 기억 형성에 대체 불가능 — 막혔을 때는 전체 답이 아닌 최소한의 힌트만 AI에게 요청
- 생산과 학습의 최적 전략은 다름: AI는 생산 도구로는 탁월하지만, 학습 도구로는 한계가 있음
- 결국 뇌에 남은 것들이 코드 리뷰의 질, 설계 판단의 정확도, 역설적으로 AI 활용 능력을 결정함
[출처] https://news.hada.io/topic?id=28653&utm_source=weekly&utm_medium=email&utm_campaign=202616
![]()
gemma4 e2b 파인튜닝
gemma4 e2b 파인튜닝
Fine-tuning the Gemma 4 E2B (Effective 2B) model is highly accessible, allowing for local training on consumer hardware with as little as 8GB VRAM. Gemma 4 E2B is a multimodal model (text, image, and audio) designed for efficiency using Per-Layer Embeddings (PLE).
The most recommended approach for fine-tuning Gemma 4 E2B is using Unsloth, which offers ~1.5x faster training with ~60% less VRAM compared to traditional methodologies.
Key Information for Gemma 4 E2B Fine-Tuning
-
Model ID: google/gemma-4-E2B-it or unsloth/gemma-4-E2B-it-unsloth-bnb-4bit
-
Requirements: 8GB VRAM (minimum for QLoRA/4-bit).
-
Frameworks: Unsloth, Hugging Face Transformers, TRL (Transformer Reinforcement Learning).
-
Technique: QLoRA (Quantized LoRA) is recommended for efficient local tuning.
-
Context Window: Supports up to 256K tokens.
-
Fine-Tuning Steps (using Unsloth)
Unsloth provides optimized notebooks for training.
-
Environment Setup: Install Unsloth and necessary dependencies.
python
pip install “unsloth[colab-new] @ git+https://github.com”
pip install –no-deps “xformers<0.0.27” “trl<0.9.0” peft accelerate bitsandbytes
-
Load Model and Tokenizer: Use 4-bit quantization to save memory.
python
from unsloth import FastLanguageModel
import torch
model, tokenizer = FastLanguageModel.from_pretrained(
model_name = “unsloth/gemma-4-E2B-it-unsloth-bnb-4bit”,
max_seq_length = 2048,
dtype = None,
load_in_4bit = True,
)
-
Apply LoRA Adapters: Apply Parameter-Efficient Fine-Tuning (PEFT) to adapt only a fraction of the parameters.
python
model = FastLanguageModel.get_peft_model(
model,
r = 16, # Rank
target_modules = [“q_proj”, “k_proj”, “v_proj”, “o_proj”,
“gate_proj”, “up_proj”, “down_proj”,],
lora_alpha = 16,
lora_dropout = 0,
bias = “none”,
use_gradient_checkpointing = “unsloth”,
)
-
Data Preparation: Format your dataset (e.g., chat templates for instruction tuning).
-
Train the Model: Use the SFTTrainer (Supervised Fine-tuning Trainer) from TRL.
-
Save the Model: Save the trained LoRA adapters or merge them into a 16-bit model for inference.
Best Practices and Considerations
-
Unsloth Bug Fixes: Ensure you use the latest Unsloth version, as they fixed issues with gradient accumulation (preventing losses from exploding) and inference bugs in Gemma 4.
-
Multimodal Inputs: To train with image or audio data, use AutoModelForMultimodalLM rather than AutoModelForCausalLM.
-
Memory Management: If you encounter Out of Memory (OOM) errors, reduce per_device_train_batch_size to 1 and increase gradient_accumulation_steps.
-
Data Quality: Use specialized datasets (e.g., function calling/tool use) for specialized tasks.
gemma4 e2b 파인터닝
Gemma 4 E2B(실질적 2B) 모델의 미세 조정은 매우 접근성이 높아, 8GB VRAM만으로도 소비자용 하드웨어에서 로컬 교육을 할 수 있습니다. Gemma 4 E2B는 Per-Layer Embeddings(PLE)를 효율적으로 사용하여 설계된 멀티모달 모델(텍스트, 이미지, 오디오)입니다.
Gemma 4 E2B를 미세 조정하는 데 가장 추천되는 방법은 Unsloth를 사용하는 것으로, 전통적인 방법론에 비해 약 1.5배 빠른 학습과 약 60% 적은 VRAM을 제공합니다.
Gemma 4 E2B 미세 조정에 대한 주요 정보
1. 모델 ID: google/gemma-4-E2B-it 또는 unsloth/gemma-4-E2B-it-unsloth-bnb-4bit
2. 요구 사양: 8GB VRAM(QLoRA/4비트 최소 사양).
3. 프레임워크: 언슬로스, 포옹 페이스 트랜스포머, TRL(트랜스포머 강화 학습).
4. 기법: 효율적인 로컬 튜닝을 위해 QLoRA(양자화 LoRA)를 권장합니다.
5. 컨텍스트 윈도우: 최대 256K 토큰을 지원합니다.
6.
미세 조정 단계 (Unsloth 사용)
Unsloth는 훈련을 위한 최적화된 노트북을 제공합니다.
1. 환경 설정: Unsloth 및 필요한 의존성 설치.
파이썬
PIP install “unsloth[colab-new] @ git+https://github.com”
PIP 설치 –no-deps “xformers<0.0.27” “trl<0.9.0” peft accelerate bitsandbytes
2. 로드 모델 및 토큰라이저: 메모리를 절약하기 위해 4비트 양자화를 사용하세요.
파이썬
unsloth에서 가져오는 FastLanguageModel에서
수입 토치
model, tokenizer = FastLanguageModel.from_pretrained(
model_name = “unsloth/gemma-4-E2B-it-unsloth-bnb-4bit”,
max_seq_length = 2048,
dtype = 없음,
load_in_4bit = 참,
)
3. LoRA 어댑터 적용: 파라미터 효율적 미세 조정(PEFT)을 적용하여 일부 매개변수만 적응시키세요.
파이썬
모델 = FastLanguageModel.get_peft_model(
모델,
r = 16, # 랭크
target_modules = [“q_proj”, “k_proj”, “v_proj”, “o_proj”,
“gate_proj”, “up_proj”, “down_proj”,],
lora_alpha = 16,
lora_dropout = 0,
편향 = “없음”,
use_gradient_checkpointing = “나태 해제”,
)
4. 데이터 준비: 데이터셋을 포맷하세요(예: 명령어 조정용 채팅 템플릿).
5. 모델 훈련: TRL의 SFTTrainer(감독 미세 조정 트레이너)를 사용하세요.
6. 모델 저장: 학습된 LoRA 어댑터를 저장하거나 16비트 모델로 병합하여 추론을 진행합니다.
모범 사례 및 고려사항
1. 언슬로스 버그 수정: 최신 언슬로스 버전을 꼭 사용하세요. 젬마 4에서 그라디언트 누적(손실 폭발 방지)과 추론 버그 문제를 해결했습니다.
2. 멀티모달 입력: 이미지 또는 오디오 데이터로 학습하려면 AutoModelForCausalLM 대신 AutoModelForMultimodalLM을 사용하세요.
3. 메모리 관리: 메모리 외(OOM) 오류가 발생하면 per_device_train_batch_size를 1로 줄이고 gradient_accumulation_steps을 늘려주세요.
4. 데이터 품질: 특수 작업에 특화된 데이터셋(예: 함수 호출/도구 사용)을 활용하세요.
![]()
[인공지능 개발자] LLM을 서빙하는 프레임워크, vLLM 사용법
[인공지능 개발자] LLM을 서빙하는 프레임워크, vLLM 사용법
개요
최근 대형 언어 모델(LLM)을 실제 서비스에 적용하려는 수요가 증가하면서, LLM을 효율적으로 서빙하는 기술의 중요성도 커지고 있습니다. 대표적인 서빙 프레임워크로는 SGLang, TensorRT-LLM, vLLM 등이 있으며, 이들 각각은 성능 특성에 차이를 보입니다.
이 중 vLLM은 초기부터 속도와 메모리 효율성 면에서 안정적인 구조를 갖춘 프레임워크로 주목을 받았고, 현재 가장 널리 활용되고 있는 LLM 서빙 솔루션 중 하나입니다
vLLM의 특징
- PagedAttention: 기존 시퀀스 기반 Attention 방식 대신 페이지 기반의 유연한 메모리 할당 전략을 도입하여 배치 효율 극대화
- 비동기 엔진 구조: 추론 요청을 효율적으로 처리하기 위한 비동기 처리 구조로 높은 처리량 유지
- OpenAI 호환 API 지원: 기존 OpenAI API 방식으로도 쉽게 서빙 가능
속도 비교

vLLM Quick Start
Offline Batched Inference
설치
pip install vllm
모델 로딩 및 추론
from vllm import LLM, SamplingParams
model_name = "kakaocorp/kanana-nano-2.1b-base" # 원하는 모델 이름
llm = LLM(model=model_name)
prompts = [
"한국의 수도는 어디인가요?",
"서울 여행지 3곳을 소개해주세요."
]
sampling_params = SamplingParams(temperature=0.7, top_p=0.9, max_tokens=100)
# 답변 생성
outputs = llm.generate(prompts, sampling_params)
# 답변 출력
for output in outputs:
prompt = output.prompt
generated_text = output.outputs[0].text
print(f"Prompt: {prompt!r}, Generated text: {generated_text!r}")
로컬에서 모델을 직접 로드해 사용할 수 있으며, SamplingParams로 디코딩 전략을 조절할 수 있습니다.
OpenAI Completions API with vLLM
vLLM은 OpenAI API 스타일의 서버도 제공합니다. 이를 통해 기존 코드 변경 없이도 쉽게 서빙 인프라에 연결할 수 있습니다.
서버 실행
vllm serve Qwen/Qwen3-1.7B-Instruct
클라이언트 예제(curl)
curl http://localhost:8000/v1/completions \
-H "Content-Type: application/json" \
-d '{
"model": "Qwen/Qwen3-1.7B-Instruct",
"prompt": "한국의 수도는 어디인가요?",
"max_tokens": 7,
"temperature": 0
}'
클라이언트 예제 (python)
import openai
openai.api_base = "http://localhost:8000/v1"
response = openai.ChatCompletion.create(
model="Qwen/Qwen3-1.7B-Instruct",
messages=[
{"role": "user", "content": "Tell me a joke about AI."}
],
temperature=0.7,
max_tokens=100
)
print(response['choices'][0]['message']['content'])
실제 OpenAI와 거의 동일한 인터페이스를 제공하므로, API 전환이 간편합니다.
vLLM 주요 파라미터
엔진 초기화 파라미터
| 파라미터 | 설명 |
|---|---|
gpu_memory_utilization |
GPU 메모리 사용 비율. 기본값은 0.9로, GPU 메모리 90%까지만 사용하여 안정성 확보 |
max_model_len |
하나의 입력 시퀀스에서 처리할 수 있는 최대 토큰 길이. (ex: 2048, 4096 등) |
tensor_parallel_size |
모델을 여러 GPU에 나눠서 병렬화할 때 사용. ex) 2로 설정하면 2개 GPU 사용 |
추론 파라미터
| 파라미터 | 설명 |
|---|---|
temperature |
샘플링의 무작위성 정도. 낮을수록 일정하고, 높을수록 무작위적(창의력이 높아짐) |
top_p |
상위 p%의 토큰만 고려하여 샘플링 |
top_k |
확률 상위 k개의 후보만 고려하여 샘플링 |
max_tokens |
생성할 최대 토큰 수 |
마무리
vLLM은 간단한 설치와 높은 성능, 그리고 OpenAI API와의 호환성 덕분에 LLM 서빙의 진입 장벽을 크게 낮춰주는 도구입니다. 특히 서빙 효율과 메모리 최적화가 중요한 실시간 애플리케이션에서 큰 강점을 발휘합니다.
Reference
- https://docs.vllm.ai/en/v0.7.1/getting_started/quickstart.html
- https://blog.vllm.ai/2024/09/05/perf-update.html?utm_source=chatgpt.com#appendix
[출처] https://ariz1623.tistory.com/375
![]()
[인공지능 기술] 프롬프트에서 하네스까지 – AI 에이전틱 패턴 4년의 기록
[인공지능 기술] 프롬프트에서 하네스까지 – AI 에이전틱 패턴 4년의 기록
프롬프트에서 하네스까지 – AI 에이전틱 패턴 4년의 기록
(bits-bytes-nn.github.io)
- 2022~2026년, AI 개발 패러다임이 세 번 전환됨: Prompt Engineering → Context Engineering → Harness Engineering
- 각 전환은 이전 패러다임이 약속을 지키지 못한 실패에서 비롯되었으며, 엔지니어링의 엄밀함은 사라진 것이 아니라 프롬프트에서 컨텍스트로, 컨텍스트에서 하네스로 위치를 옮겼을 뿐임
- [1시대] Prompt Engineering (2022~2024)
- “영어가 곧 프로그래밍 언어”, “단계별로 생각하라”
- 아무리 정교한 프롬프트도 컨텍스트 윈도우에 없는 파일은 모름
- [2시대] Context Engineering (2025)
- “어떤 말을 해야 하나”에서 “어떤 정보를 넣어야 하나“로
- 완벽한 컨텍스트를 구성해도, 그것을 소비하는 루프 자체가 잘못 설계되면 여전히 실패
- [2.5시대] 바이브 코딩과 그 숙취
- diff도 안 보고 AI 제안을 전부 수락 – 코드가 읽을 수 있는 수준을 넘어서 자라남
- “LLM이 코드를 썼더라도 당신이 리뷰했다면 그건 vibe coding이 아니다”
- [3시대] Harness Engineering (2026~)
- “에이전트가 실수하면 에이전트가 아니라 하네스를 고쳐라“
- 에이전트 = 모델 + 하네스
- Anthropic 3-에이전트 아키텍처, Ralph 패턴, Lethal Trifecta, Meta AI의 Rule of Two
- 2026년 현재 핵심 메트릭은 프롬프트 품질이 아니라 KV-cache hit rate(모델이 이전 계산을 재활용하는 비율)와 하네스 복잡도로 전환됨
- 바이브 코딩(Vibe Coding)의 숙취, 에이전트의 자기 평가 불능, 보안 취약점 등 실제 프로덕션 장벽들이 각 시대의 한계를 증명했으며, 하네스는 이 모든 문제에 대한 구조적 대응임
- 각 시대는 이전 시대를 대체하지 않고 포함(subsume) 하며, 프롬프트 엔지니어링은 죽은 것이 아니라 하네스 엔지니어링의 서브모듈이 되었음
- 하네스는 뜯어낼 수 있어야(rippable) 함 — 모델이 발전하면 기존 에러 복구 로직의 절반이 불필요해짐
- 엄밀함의 다음 이동 방향: Guardian Agent(실시간 감시 레이어) → 평가 엔지니어링(behavior beats benchmarks) → 지식 엔진(코드 그래프·커밋 히스토리·메모리 결합)
[출처] https://news.hada.io/topic?id=28301&utm_source=weekly&utm_medium=email&utm_campaign=202615
![]()



