본문 바로가기

전체 글135

오드로이드 홈서버 구축기 - 하드웨어 구성 매달 구글 클라우드 플랫폼에 5~10만원씩 내다보니까 좀 빡세서 휴가 나온 김에 홈서버를 구축해봤다. 서버로 쓸 보드는 하드커널의 오드로이드 시리즈이다. 오드로이드 HC4, XU4, N2+를 샀다. 싱글보드 컴퓨터 종류 중에 성능이 제일 괜찮은게 오드로이드라고 생각한다. (홍보글 아님) 서버 구성 ODROID HC4 CPU는 Cortex-A55 1.8GHz 쿼드코어에 메모리는 DDR4 4GB 정도이다. 원래 N2+를 2개 사려다가 SATA 커넥터가 있어서 이것도 하나 샀다. SSD나 HDD를 직접 연결할 수 있다. USB 처럼 혹시 툭 쳐서 뽑히는 일은 없겠지 (?) 여기에 장착할 500GB짜리 SSD랑 2TB짜리 HDD도 사서 꽂아봤다. ODROID N2+ 얘는 big.Little CPU를 사용한다. .. 2021. 11. 16.
[Lecture Note] Learn how to learn - 1주차 Focused Thinking vs Diffuse Thinking Focused thinking은 한 가지 주제를 가지고 골똘히 생각하는 것이다. 이미 익숙한 주제에 대해서 생각할 때 Focused thinking을 한다. 이때는 하나의 좁은 주제에 대해서 집중적으로 생각한다. 반면 Diffuse thinking은 더 폭 넓게 창의적인 생각을 할 때 사용한다. 처음 배우는, 익숙하지 않은 주제에 대해서는 Diffuse thinking을 하는 게 학습에 더 도움이 된다. 그리고 Diffuse thinking은 창의적인 생각을 할 때도 자주 사용된다. 걷거나, 잠이 들기 전이나, 샤워할 때처럼 자연스럽고 차분하게 생각을 하면 창의적이고 더 넓은 시야로 문제를 바라볼 수가 있다. Procrastination .. 2021. 11. 7.
메모리 계층별 대략적인 성능 비교 컴퓨터에는 CPU 레지스터, CPU 캐시, RAM, SSD, HDD 등 다양한 장치에서 데이터를 읽고 쓸 수 있다. 일반적으로 이러한 계층구조는 피라미드 형태를 띄며, 피라미드에서 위로 갈수록 빠르고, 작고 비싸다. 아래로 갈수록 느리고, 크고, 싸다. 아래 그림은 컴퓨터에서 메모리가 어떻게 계층구조를 이루는지 그림으로 보여준다. 이 글에서는 실제 하드웨어에서 계층별로 어느 정도의 성능이 나오는지를 알아본다. 물론 하드웨어에 따라서 성능이 다르기 때문에 대략적인 성능만 알아본다. 다시 강조하지만 구체적인 수치는 다를 수 있다. 특히 예전 하드웨어랑 비교할수록 훨씬 느려보일 것이다. CPU Register 레지스터는 컴퓨터에서 가장 빠른 메모리로 CPU 내부에 존재한다. 레지스터에 데이터를 읽고 쓰는 것은.. 2021. 11. 7.
[Paper] When Poll is Better than Interrupt 운영체제를 처음 공부할 때는 폴링은 디바이스가 작업을 완료하기까지 대기하는 게 시간낭비이므로, IO가 무조건 인터럽트 방식으로 이루어질 거라고 생각했다. 하지만 하드웨어 성능이 미친듯이 좋아지면서 오히려 인터럽트의 오버헤드가 성능에 큰 영향을 미치기도 한다. When Poll is Better than Interrupt는 2012년에 USENIX에서 발표된 논문으로 고성능 디바이스에서 폴링이 인터럽트 방식보다 나을 수 있음을 보여준다. 실제로 블록 레이어에서는 2015년에 폴링 방식이 구현되었다. 네트워크 레이어는 훨씬 더 전인 2000년대 초반부터 NAPI를 통해 폴링을 지원했다. When Poll Is Better than Interrupt | USENIX www.usenix.org Abstract .. 2021. 11. 6.
[LWN.net] Shrinking the kernel with link-time optimization Shrinking the kernel with link-time optimization [LWN.net] Shrinking the kernel with link-time optimization This article brought to you by LWN subscribersSubscribers to LWN.net made this article — and everything that surrounds it — possible. If you appreciate our content, please buy a subscription and make the lwn.net Link Time Optimization 바로 앞 글에서는 가비지 컬렉션으로 코드를 줄이는 법을 알아봤다. 하지만 이 방법은 코드의 수정도 .. 2021. 11. 5.
[LWN.net] Shrinking the kernel with link-time garbage collection Shrinking the kernel with link-time garbage collection [LWN.net] Shrinking the kernel with link-time garbage collection Benefits for LWN subscribersThe primary benefit from subscribing to LWN is helping to keep us publishing, but, beyond that, subscribers get immediate access to all site content and access to a number o lwn.net Linker Section Garbage Collection C언어로 작성된 프로그램은 전처리기 -> 컴파일러 -> 링커의.. 2021. 11. 5.
[Linux Kernel] RCU (Read-Copy-Update) 공부하다보니 여기저기서 RCU가 나와서 이것도 정리를 해야겠다. RCU는 읽기가 대부분인 상황에서 사용하는 동기화 매커니즘이다. 다른 동기화 매커니즘은 읽기와 쓰기에 대한 오버헤드가 발생하지만, RCU는 읽기에 대한 오버헤드가 존재하지 않는다는 특징이 있다. 커널 문서를 보면 사람들이 RCU를 가지고 오해를 많이 한 것 같다. 이렇게 쓰여있다. 그만큼 RCU가 헷갈리는 주제가 아닌가 싶다. 기존에는 RCU가 RCU를 한 가지 진실된 방법으로 설명할 수 있을거라는 잘못된 가정하에 설명되었다. 사람들은 RCU를 서로 다른 과정으로 이해한다. 따라서 이 문서는 여러가지 방법으로 RCU를 설명한다. Notes 이 글은 비실시간 커널(non real-time kernel)에서의 RCU를 설명한다. 실시간 커널에서.. 2021. 11. 5.
[Linux Kernel] kprobe와 kretprobe BPF를 공부하다보니 실행될 함수를 등록할 때 kprobe, kretprobe, uprobe, tracepoint, UDST 등의 다양한 도구를 사용한다고 해서 이러한 도구들을 먼저 정리해보려고 한다. 우선 이 글에선 kprobe와 kretprobe를 정리해본다. kprobe, kretprobe란 kprobe와 kretprobe는 드커널 코드에 동적으로 중단점을 삽입하여 사용자가 정의하는 핸들러 함수가 실행되도록 하는 강력한 도구이다. kprobe는 함수 또는 함수에서 특정 오프셋만큼 떨어진 곳에서 핸들러 함수를 실행하게 해주는 도구이다. kretprobe는 함수가 끝난 후에 핸들러 함수를 실행하게 해주는 도구이다. struct kprobe kprobe의 구조체를 간단하게 살펴보자. 꽤나 직관적이기 때문.. 2021. 11. 2.
[Linux Kernel] BPF/eBPF란 무엇인가 BPF와 관측가능성 BPF 책을 보면 볼수록 흥미로워서 내용을 정리해본다. BPF는 패킷 필터로 시작해서 현재는 리눅스 시스템에 관측가능성을 부여하는 도구이다. 만들어진지는 거의 리눅스 급으로 오래됐는데 최근 5년간 새로운 용도(?)를 발견하면서 많이 핫해진것 같다. 이 글에서는 BPF가 어떤 구조로 되어있는지를 간단하게 설명한다. 더 공부하면서 bcc나 bpftrace에서 어떻게 프로그램을 실행하는지, BPF 관련 프로젝트에 무엇이 있는지 등등을 정리하려고 한다. 예전에도 BPF라는게 있구나 정도는 알았는데 관측가능성이라는 말의 의미가 잘 와닿지 않아서 그냥 스쳐 지나갔었다. BPF는 사용자 공간에서 명령어 몇개만으로 커널을 새로 빌드하지 않고도 커널 코드를 안전하게 수행할 수 있다. 심지어 커널 코드.. 2021. 10. 31.