Inflearn brand logo image
Inflearn brand logo image
Inflearn brand logo image
개발 · 프로그래밍

/

백엔드

확장성 있는 시스템 설계하기

현대의 디지털 제품과 서비스는 작은 아이디어에서 시작해 수백만 사용자에게 사랑받는 모습으로 성장합니다. 이를 가능하게 하는 핵심은 확장성 있는 시스템 설계입니다. 이 강의에서는 소규모에서 대규모 시스템으로 성장할 수 있는 설계 원리와 실천 방안을 배울 수 있습니다.

(4.8) 수강평 13개

수강생 142명

시스템설계
이론 중심
소프트웨어 설계아키텍처

먼저 경험한 수강생들의 후기

이런 걸 배울 수 있어요

  • 소규모에서 대규모 서비스로 성장하기 위한 확장성 있는 시스템 설계의 기본 원리를 배웁니다.

  • 가용성, 성능, 확장성을 고려한 단계별 설계 전략과 실천 방안을 학습합니다.

  • 플랫폼, 서버, 클라이언트 엔지니어링의 역할과 협업 방식을 알아봅니다.

확장성 있는 시스템 설계하기; 작은 아이디어에서 대규모 서비스로-

현대의 디지털 제품과 서비스는 작은 아이디어에서 시작해 수백만 사용자에게 사랑받는 모습으로 성장합니다. 이를 가능하게 하는 핵심은 확장성 있는 시스템 설계입니다. 확장성은 시스템이 사용자의 증가와 데이터의 폭증에 대응할 수 있는 능력입니다.

이 강의는 프로젝트 #POTD(Photo of the Day)를 중심으로 진행됩니다. POTD는 하루 한 장의 사진으로 우리의 이야기를 특별하게 만들어 줄 간단하고 직관적인 앱입니다. 사용자는 사진을 찍고 짧은 글과 함께 업로드한 뒤, 다른 사용자들과 소통하며 좋아요를 누르고, 댓글을 달 수 있습니다. 또한, 해시태그를 이용해 관심사가 비슷한 사람들의 사진을 쉽게 찾아볼 수 있는 아이디어에서 출발했습니다.

하지만 간단해 보이는 이 앱도 사용자가 점진적으로 늘어나는 과정에서 시스템 운영에 많은 도전 과제를 안겨줍니다. 이 강의에서는 POTD 프로젝트를 통해 Outside-In 및 API-First Development Approach를 적용해 MVP(최소 기능 제품)를 설계하고 출시한 뒤, 실제로 사용자 수와 트래픽이 증가할 때 발생하는 다양한 문제를 해결하며 시스템을 확장해 나가는 과정을 배우게 됩니다.

POTD 프로젝트에서 다룰 주요 학습 내용은 다음과 같습니다.

  • 최소 기능 제품으로 출발하며, 초기 사용자 요구사항에 초점을 맞춘 간결하고 효율적인 시스템 설계를 학습합니다.

  • 사용자 증가에 대비해 서버를 수평 확장하고, 로드 밸런서를 통해 트래픽을 효과적으로 분산시키는 방법을 배웁니다.

  • 데이터베이스 클러스터링, 복제, 캐싱 전략을 통해 대규모 데이터를 안정적이고 빠르게 처리하는 방법을 익힙니다.

  • 데이터베이스 검색의 한계를 극복하기 위해 검색 엔진과 메시지 큐를 도입해 효율적인 검색과 비동기 처리를 구현합니다.

  • 머신러닝을 도입해 사용자 데이터를 분석하고 개인화된 추천 시스템을 설계합니다.

  • CDN과 멀티-데이터 센터를 통해 글로벌 사용자들에게 빠르고 안정적인 서비스를 제공하는 방법을 학습합니다.

소프트웨어 개발은 단순히 시스템을 작동하게 하는 것이 아니라, 변화하는 환경에서도 가치를 유지하고 확장할 수 있게 만드는 것입니다. 이 강의를 통해 확장 가능하고 유연한 시스템 설계의 첫걸음을 함께 시작하세요. 🚀

이런 내용을 배워요

확장성 있는 시스템 설계

POTD 프로젝트를 통해 MVP에서 시작해 글로벌 서비스를 설계하는 과정을 단계별로 배웁니다. 로드 밸런싱, 데이터베이스 클러스터링, 검색 엔진, 캐싱, CDN 등 주요 기술을 활용해 성능과 확장성을 갖춘 시스템을 설계해봅니다.

확장성을 고려한 소프트웨어 설계

수평 확장에서 발생하는 세션 관리 문제를 해결하고, 소프트웨어를 유연하게 설계하는 방법을 배웁니다. 또한, 변화하는 환경에서도 시스템의 가치를 유지할 수 있는 적응형 아키텍처에 대해 알아봅니다.

수강 전 참고 사항

유의사항

  • 본 강의는 실습이 포함되지 않은 이론 중심 강의로, 주로 개념과 전략을 소개하고 이해를 돕는 데 초점을 맞추고 있습니다.

  • 본 강의는 확장성 있는 시스템 설계를 처음 접하는 학습자들을 위해 개념을 이해하기 쉽게 설명합니다. 하지만 각 기술의 심화된 내용은 별도의 학습이 필요합니다.

  • 본 강의는 좀 더 정확한 전달을 위해 AI 보이스 기술을 사용하여 제작되었습니다.


이런 분들께
추천드려요

학습 대상은
누구일까요?

  • 프로그래밍에는 익숙하지만, 시스템 아키텍처 설계에 익숙하지 않은 분

  • 실무 경험은 없지만, 소프트웨어 엔지니어링의 전반적인 구조와 시스템 설계의 원리를 이해하고 싶은 분

  • 작은 아이디어에서 출발해 대규모 서비스를 만들고 운영하는 과정에 대해 배우고 싶은 분

선수 지식,
필요할까요?

  • 한 가지 이상의 프로그래밍 언어(Java, Python 등)에 대한 경험이 필요합니다.

  • 컴퓨터 과학(CS)의 기본 개념(데이터베이스, 네트워크, 알고리즘 등)에 대해 이해가 필요합니다.

  • HTTP 와 웹 애플리케이션 동작 원리에 대한 기초가 필요합니다.

안녕하세요
입니다.

1,379

수강생

41

수강평

4.9

강의 평점

3

강의

JYK management

“Jazz Your Knowledge 🆙

“당신의 지식을 더 신나게, 더 매력적으로 만들어라“

——

"당신의 아이디어가 세상을 바꿀 수 있습니다. 우리는 그 과정을 함께합니다."

커리큘럼

전체

16개 ∙ (1시간 19분)

해당 강의에서 제공:

수업자료
강의 게시일: 
마지막 업데이트일: 

수강평

전체

13개

4.8

13개의 수강평

  • pilming님의 프로필 이미지
    pilming

    수강평 2

    평균 평점 5.0

    5

    100% 수강 후 작성

    I applied and watched it all at once! This course is introduced as a course for beginners, but I think it's content that will be helpful to everyone in the IT industry! When you're running towards your goal of studying, getting a job, or changing jobs, you can easily get caught up in the 'trees' and not see the 'forest'. (That's what happened to me...😭^😭) Even before taking the course, I had heard of and knew concepts like 'search engine' and 'scale out'. However, I didn't systematically organize and understand why they were needed and how they developed after implementation. So if I had explained the content covered in this course, I would have ended up focusing on specific concepts (trees) that I knew the best. However, this course allows you to naturally understand how these concepts are connected and expanded into a huge service that handles traffic from all over the world!! Thanks to this, I was able to look at service design from a broader perspective! The course progresses in a way that makes it feel like one thing leads to another, so it was so fun that I watched it all at once, but I think I'll be checking it out often in the future!

    • jacky님의 프로필 이미지
      jacky

      수강평 1

      평균 평점 5.0

      5

      100% 수강 후 작성

      I had the chance to hear this content in another lecture by the instructor, and I enjoyed it so much that I thought I had to listen to it again when it came out as a lecture. I always study the details, so I wanted to know the big picture, and this is a good lecture that helps me understand what part of the project I am involved in and how it is related to other parts. Having a perspective that looks at the whole picture from a distance makes me feel like my vision has become much wider.

      • sebiinim님의 프로필 이미지
        sebiinim

        수강평 1

        평균 평점 5.0

        5

        19% 수강 후 작성

        The diagrams are well-organized and easy to understand!

        • sootudio님의 프로필 이미지
          sootudio

          수강평 1

          평균 평점 5.0

          수정됨

          5

          100% 수강 후 작성

          I was able to improve my 'scalable web application design' skills by taking this course. I highly recommend it to students/job seekers who want to grow as web developers, especially backend developers! One of the most difficult things I faced when I started studying web development was 'knowing why certain technologies are needed'. In particular, I only knew about the structure of the web, such as servers, databases, and clients, but when I entered boot camp and carried out projects, I had many opportunities to encounter unfamiliar technologies such as Redis, Kafka, RabbitMQ, and Elasticsearch. I heard that it would be good to gain experience using these technologies, and I even tried some of them. However, I felt that these were not to solve a 'problem', but rather to leave them as just 'helpful experiences', which was a shame. Then, while listening to this lecture, I was able to resolve many of the things I was curious about. Starting with the most basic functions, the lecture presents problem situations, introduces the technologies that can solve them and how they solve the problems, and finally introduces representative examples of the technologies. As a result, the concept that 'B solution (technology) can be used for problem A' is established when designing a system. In addition, whenever a technology required for system design is added, it is shown as an architecture diagram, and the lecture is provided so that the flow and structure of requests/responses can be easily understood. Ultimately, I believe that you can effectively respond to problems that occur when creating web services, and also develop the technical ability to solve problems. Currently, I am taking the lecture and re-creating the structure of the project I made before based on the lecture content. I can see the parts that I did not understand before or the parts that I designed inefficiently, and I was able to create a more improved structure. I hope that other people who are studying web development will also develop the ability to design scalable and efficient web systems in future projects by taking this course!! :)

          • heechanlog3127님의 프로필 이미지
            heechanlog3127

            수강평 1

            평균 평점 5.0

            5

            81% 수강 후 작성

            I enjoyed it so much. It feels like the fundamentals that I should always be seeing, hearing, and practicing, but I think I become lax because I'm always exposed to them. As a result, I find it difficult when problems arise in projects. This lecture simply shifted the perspective I was missing. It talks about stories that I encounter so often, but it feels new every time I hear them. Thank you for the great lecture.

            ₩11,000

            JYK 매니지먼트님의 다른 강의

            지식공유자님의 다른 강의를 만나보세요!

            비슷한 강의

            같은 분야의 다른 강의를 만나보세요!