설명을 이해가 쉽도록 그림과 예제 그리고 코믹한 말투로 설명하시는게 아주 좋습니다. 고인물개발자들은 대충 대략적으로 이해하고 개념은 있지만 설명을 잘 못하는경우가 대부분인데 개념이나 용어, 실제 필요하게 사용할예제를 적절하게 잘 설명해주셔서 도움이 됩니다. 얄코님 엄지척입니다. 감사해요~
프로세스 = 컴퓨터가 실행되는 상태 컴퓨터는 여러개의 프로세스를 소유하고 동시적, 병렬적으로 실행 1. 동시적: 컴퓨터가 프로세스를 차례대로 빠르게 돌아가면서 프로세스들을 마치 동시에 실행되는것처럼 실행 2. 병렬적: 동시적 프로세스가 과부하가 되기 때문에 여러개의 코어로 프로세스 동시 실행 쓰레드 = 프로세스 안에서 실행되는 여러개의 작업들. 프로세스 내에서 같은 메모리를 사용함. 하지만 쓰레드가 같은 메모리를 수정한다면 적용되지않는 에러가 발생. 해결법: 한 쓰레드가 작업을 진행할때 다른 쓰레드에게 대기 명령을 내리는 프로그램 사용 (ex: java => synchronize) 좋은 정보 감사합니다!
이 댓글을 발견하셨다면, 아래에서 이번에 다룬 얄팍사전님의 프로세스와 스레드에 대한 영상내용을 함께 정리해보고 추가적인 내용을 알아봐요! 프로세스와 스레드 - 프로세스와 스레드는 프로그램을 실행하는 데 있어 결코 빠져서는 안되는 필수 요소에요. 이것들은 아래와 같이 짧게 정의할 수 있어요. 짧게 읽어보고 아래에서 좀 더 자세히 살펴보도록 해요. - 프로세스 : 운영체제로부터 시스템 자원을 할당받는 작업의 단위 (메모리에 올라와 실행되고 있는 프로그램의 인스턴스) - 스레드 : 프로세스가 운영체제로부터 할당받은 자원을 이용하는 실행 흐름의 단위 (프로세스 내에서 실행되는 여러 흐름의 단위) === Program : 프로세스 설명을 위해서, 프로그램이 무엇인지 알고 넘어가야 해요. 아래 정리를 보고 프로그램이 뭔지 확인하도록 해요. - 파일이 저장 장치에 저장되어 있지만 메모리에는 올라가 있지 않은 정적인 상태인 어떤 작업을 위해 실행할 수 있는 파일 - 즉, 어떤 작업을 위해 실행할 수 있는 파일이지만 아직 실행되지 않은 파일 그 자체 - 메모리에 올라가있지 않다는 말은, 아직 운영체제가 프로그램에게 독립적인 메모리 공간을 할당해주지 않았다는 뜻이에요. 모든 프로그램은 운영체제가 실행되기 위한 메모리 공간을 할당해 줘야 실행될 수 있어요. - 정적인 상태라는 말은, 단어 그대로 움직이지 않는 상태라는 뜻이에요. 한 마디로 아직 실행되지 않고 가만히 있다는 뜻이에요. === Process : 프로세스는 위에서 운영체제로부터 시스템 자원을 할당받는 작업 단위라고 했어요. 좀 더 알아보도록 해요. - 실행 파일(프로그램)에게 의미를 부여하기 위해서는 프로그램을 실행해야 해요. 프로그램을 실행하는 순간 해당 파일은 컴퓨터 메모리에 올라가게 되는데, 이 상태의 프로그램을 프로세스라고 말해요. - 프로그램을 실행하려고 운영체제로부터 시스템 자원을 할당받기 때문에, 운영체제로부터 할당받는 작업의 단위구나" 라고 이해하면 되요. - 프로그램이 실행되어 파일이 컴퓨터 메모리에 올라간 상태를 동적인 상태라고 말해요. 즉, 프로세스는 실행되고 있는 동적 상태의 프로그램이에요. - 프로세스는 운영체제로부터 여러 시스템 자원을 할당받아요. - 각 프로세스는 최소 하나의 스레드를 가져요. 스레드가 무엇인지는 곧 다룰거에요. - 각 프로세스는 별도 주소공간에서 실행되며, 일반적으로 다른 프로세스의 변수나 자료구조에 접근할 수 없어요. 왜냐하면 각 프로세스는 독립적이기 때문이에요. - 하지만, 커널 영역에서 프로세스들끼리도 서로 데이터를 주고받는 방법이 존재하긴 해요. 그게 바로 IPC(Inter Process Communication)에요. === Thread : 스레드는 위에서, 프로세스 내에서 실행되는 작업의 여러 흐름단위라고 언급했어요. 조금 더 자세히 알아보도록 해요. - 유튜브로 비유해보자면, 우리는 영상을 다운받을 수도 있어야하고 동시에 영상을 볼 수도 있어야 해요. 이렇게 한 프로세스 내에서 여러 갈래의 작업이 동시에 진행될수 있어야 하는데, 이 갈래가 바로 스레드에요. - 스레드는 프로그램을 하나의 프로세스로 실행했을 때, 프로그램 하나가 단순히 한 가지 작업만을 하게 된다는 단점을 해결하기 위해 등장했어요. - 그래서 우리는 스레드가 프로세스의 코드에 정의된 절차에 따라 실행되는 경로이자, 프로세스 내에서 실행되는 여러 흐름의 단위로 생각할 수 있어요 - 스레드는 프로세스 내에서 각각 별도의 Stack를 갖고있지만, Code, Data, Heap형식의 영역은 공유해요. 즉, 프로세스 내의 할당된 메모리공간을 스레드끼리 공유하면서 실행할 수 있다는 말이에요. 프로세스와 다르게 말이죠. - 스레드는 프로세스와 다르게 프로세스의 자원을 공유하면서 작동하기 때문에, 스레드들은 프로세스 실행 흐름의 일부가 되는 것으로 이해할 수 있어요. - 만약, 한 스레드가 프로세스 자원을 변경하면 다른 이웃 스레드(sibling thread)도 그 변경 결과를 즉시 볼 수 있어요. 서로가 같은 프로세스의 자원에 접근할 수 있으니까요. [댓글 길이가 길어서 남은부분은 해당 댓글의 답글로 달았어요!]
=== 차이 구분 | Process | Thread 영역 | 운영체제에 의해 각각 독립된 메모리 영역 | 할당 프로세스가 할당 받은 메모리 영역에서 Stack영역은 따로 할당받고, Code/Data/Heap 메모리 영역은 공유 공유 | 각각 독립된 메모리 영역을 할당받으므로 다른 프로세스의 변수나 자료에 접근 불가 | 별도의 Stack영역을 가지고 있지만 Heap 메모리와 같은 영역은 서로 읽고 쓸 수 있음 오류 전파 | 각 프로세스의 메모리 영역은 서로 독립적이므로, 오류 전파의 걱정이 적음 | Code/Data/Heap 메모리 영역의 내용을 공유하므로 특정 스레드에서 오류 발생 시, 같은 프로세스 내의 다른 스레드에 영향을 미침 단위 | 운영체제로부터 시스템 자원을 할당받는 작업 단위 (운영체제 입장에서 최소 작업 단위) | 프로세스 내에서 실행되는 흐름의 단위 (CPU 입장에서의 최소 작업 단위) === Multi Process - 멀티프로세스는 하나의 응용프로그램을 여러 개의 프로세스로 구성하여 각 프로세스가 하나의 작업(태스크)을 처리하도록 하는 것이에요. - 멀티프로세스는 각 프로세스의 메모리 구분이 필요하거나, 독립된 주소공간을 가져야 할 경우 사용할 수 있어요. - 먼저, 멀티 프로세스의 장점에 대해 언급해볼게요. 1. 멀티 프로세스는 독립된 메모리 구조를 가지기 때문에, 프로세스 중 하나에 문제가 발생해도 다른 프로세스에게 치명적 영향이 확산되지 않는다는 안전성이 있어요. 2. 독립된 메모리 구조를 가짐으로 서로의 변수와 자료구조에 접근하지 못하기 때문에 동기화 작업이 별도로 요구되지는 않으나, 만약 프로세스 간 통신이 필요하면 IPC라는 복잡한 기법을 사용해야 해요. - 다음으로, 멀티 프로세스의 단점에 대해 언급해볼게요. 1. 멀티 프로세스는 멀티 스레드보다 더 많은 메모리 공간과 CPU 자원을 차지해요. 운영체제로부터 시스템 자원을 할당받는 작업 단위가 여러 개니까 더 많은 CPU 자원을 할당한다고 생각하면 되요. 2. Context Switching발생 시, 캐시 메모리 초기화 등의 무거운 작업들을 동반하여 비용과 시간이 많이 소모되는 오버헤드가 발생할 수 있어요. Context Switching은 CPU가 한 번에 하나의 프로세스만 실행 가능하기 때문에 등장한 개념이에요. 좀 더 자세히 설명하자면, CPU에서는 여러 프로세스를 돌아가면서 한 번에 하나씩 작업을 실행해요. 만약 어떠한 이유로 동작 중인 프로세스가 대기 상태로 이동해야 한다면, 다음에 이 프로세스가 다시 CPU 자원을 받아 올라왔을 때 작업을 이어서 진행해야 할 거에요.
즉, 프로세스는 대기 상태로 넘어가면서 해당 프로세스의 상태(Context)를 보관해야 해요. 같은 맥락으로, 대기하고 있던 다음 순서의 프로세스는 CPU 자원을 할당받아 동작하면서 이전에 보관했던 프로세스의 상태를 복구하는 작업이 동반되어야 하겠죠? 이런 일련의 과정이 Context Switching이에요. === Multi Thread - 멀티스레드는 하나의 응용프로그램을 여러 개의 스레드로 구성하고, 각 스레드로 하여금 하나의 작업을 처리하도록 하는 것이에요. 대표적으로 웹 서버가 있어요. - 프로그램이 시작할 때 메인 스레드가 실행되고, 메인 스레드는 작업을 처리하기 위해 새로운 스레드를 생성해요. 이들은 병렬로 실행되며, 실행이 완료되면 메인 스레드와 결과를 동기화하는 방식으로 진행되요. - 먼저, 멀티 스레드의 장점에 대해 언급해볼게요. 1. 프로세스를 생성해 자원을 할당하는 system call이 줄어들어 자원을 효율적으로 관리할 수 있어요. 즉, 시스템 자원의 소모를 줄임으로써 자원의 효율성을 증대시키고 시스템 처리량이 증가하게 되요. 2. 또, 프로세스에 비해 스레드 간 데이터를 주고 받는 것이 간단하기 때문에 통신 부담이 적고, 마찬가지로 시스템 자원 소모가 줄어들게 되요. 덕분에 스레드 사이의 작업량이 적어 Context Switching이 빨라요. 3. 프로세스에서의 Context Switching은 서로 공유하는 데이터가 없으므로 캐시가 쌓아놓은 데이터들이 무너지고, 새로 캐시 정보를 쌓아야 해요. 하지만, 스레드에서의 캐시 데이터는 스레드가 바뀌어도 공유하는 데이터가 있으므로 의미가 있어요. 그래서 Context Switching이 빠른 거에요. - 다음으로, 멀티 스레드의 단점에 대해 언급해볼게요. 1. 멀티 스레드의 경우 자원을 공유하기 때문에, 각 스레드가 같은 공유 자원의 내용에 접근하고, 수정을 가할 경우 동기화 문제가 발생할 우려가 있어요. 2. 그래서, 스레드의 공유 자원 접근에 대해 주의 깊은 설계가 필요하며, 디버깅이 까다로운 점이 있어요. 3. 다른 프로세스(프로세스 밖)에서 스레드 각각을 제어할 수 없으며, 하나의 스레드만 오류로 종료되어도 전체 스레드가 종료될 수 있어요. 4. 마지막으로 하나의 스레드만 실행중일 때에는 실행시간이 되려 지연될 수 있어요. 여러 작업을 할 목적으로 멀티 스레드를 설계했을텐데, 하나의 스레드만 동작한다면 문제가 되겠죠?
그리고 영상 주제 신청하고 싶은게 있는데 젠킨스 같은 CI 서버를 사용하면 좋은점 (?) , 필요성을 알고싶어요. 혼자 프로젝트 할때는 필요성을 느끼지 못해서 안했었는데 회사에선 사용하더라구요. 좀 알아봐도 제가 직접 배포 환경을 셋팅하지 않다보니까 잘 와닿지 않더라구요. 해당 주제에 해서 영상 찍어주시면 감사하겠습니다 !!
🎫 얄코 강의 선착순 반값쿠폰 (매주 갱신)
bit.ly/yalco-fcfs-coupon
얄코 강좌들 보기:
www.yalco.kr/#lectures
얄코 책 보기:
www.yalco.kr/#books
학원에서 하루종일 설명해주는거 6분이면 끝
학원다니지말아야겠어요
정보는 여러곳에서 얻어서 그걸 자기가 정리하는과정이 필요하죠.
여러번 볼수록 진짜 대단한분이란걸 느낌
이렇게 쉽게 설명하기위해서 명확하게이해했을거고
재밌게설명하기위해서 많이고민했을텐데
영상엔없지만 나는 그 과정이 보인다......
ㅠㅠ 감사합니다!!
현실세계에선 로맨스물이 되지만,
컴퓨터 세계에선 *에로*물이 돼요 ~
설명을 이해가 쉽도록 그림과 예제 그리고 코믹한 말투로 설명하시는게 아주 좋습니다.
고인물개발자들은 대충 대략적으로 이해하고 개념은 있지만 설명을 잘 못하는경우가 대부분인데
개념이나 용어, 실제 필요하게 사용할예제를 적절하게 잘 설명해주셔서 도움이 됩니다.
얄코님 엄지척입니다. 감사해요~
도움되어드려 기쁩니다 ㅠㅜ 감사합니다!!
설명 진짜 잘하시네요 . 다른데 보면 지저분하고 복잡해서 이해하기 힘든데 보기도 좋고 비유 진짜 잘하심
감사합니다!!
이런 무료강의 정말 알차고 좋은 강의ㅠㅠㅠㅜ정말 감사합니다 이렇게 준비하시는 것도 엄청 공들이실텐데! 앞으로 더욱 더 발전해나가주세요!!! 구독하겠습니다 ㅎㅎ
ㅠ 감사합니다!!!
제가 배운게 이런거였다는걸 드디어 깨달았네요ㅋㅋㅋㅋㅋㅋ 깔끔한 설명 감사드립니다! 앞으로도 좋은 영상 부탁드려요~~
감사합니다!!
아 진짜 공감입니다 ㅠㅠㅠ 얄코님 정말 감사합니다!!!!!!!
git똥차게ㅋㅋㅋ 너무 재미있고 설명도 쏙쏙들어와요!! 잘보고갑니다ㅎㅎ
와우 얄코 채널 영상들 정주행 중이에요.
귀에 쏙쏙 박히는 설명, 적절하고 친절한 비유, 꽉찬 이미지 자료들, 모두 최고네요!!
앞으로도 잘 볼께요!
좋게 보아주셔서 감사해요~!!
와 아무것도 모르는 상태에서
6분만에 이해가 프로세스와 쓰레드가 이해가 됐습니다
감사합니다
학원다니면서 이해를 못해서 버벅이고 번아웃 상태인데 재미있는 비유와 설명으로 이해도 가고 + 흥미까지 생겼어요! 너무 감사하고 쭉 업로드 부탁드려요 😆
큰 보람 주는 댓글 감사합니다!!
유튜브 순기능에 눈물한방울흘리고갑니다 ㅠㅠ 스레드 이해잘안되서 답답해미칠지경이었는데 이영상하나만으로도 구독을 안할아유가없네요 진짜 최고예요
감사합니다~!!
우리 교수님보다 더 이해하기 쉽게 설명해주신듯한... 덕분에 개념정리 잘하고 갑니다!
감사합니다!!
와 미쳤다.......이해 너무 잘된다.....감사해요 영상 맨날 하나씩 올라왔으면 좋겠어요.
ㅠㅜ 본업이 있어서 어렵지만 더 많이 할 수 있도록 노력할게요!!
와..절로 고개가 끄덕여지네요 ❤
잘 보고 갑니다. 영상 볼수록 존경심이 늘어나네요.
감사합니다! 😄
와... 영상 진짜 많이 찾아봤는데
지금처럼 이해가 잘 된 건 없었던 것 같아요!!
좋은 비유와 알찬 내용 정말 감사합니다😆
정말 얄코님 강의는 최고예요~ 너무 재밌고 쉽게 잘 알려주셔서 감사합니다
와 딱 어렸을때 잘가르치고 재밌는 선생님 같으시네요. 표정 목소리톤도 부담스럽지도 않고 좋음
감사합니다!!
Concurrency와 parallelism의 차이에 대해 굉장히 쉽게 설명해주셨네요 ㅎㅎ
다른 비유들도 굉장히 명쾌합니다!
감사합니다!!
설명이 드릅게 찰집니다 ㅋㅋㅋ 귀에 착착 박힘
감사합니다!!
3:05~3:09 ㅋㅋㅋㅋ엄청난 말씀이십니다
프로세스 = 컴퓨터가 실행되는 상태
컴퓨터는 여러개의 프로세스를 소유하고 동시적, 병렬적으로 실행
1. 동시적: 컴퓨터가 프로세스를 차례대로 빠르게 돌아가면서 프로세스들을 마치 동시에 실행되는것처럼 실행
2. 병렬적: 동시적 프로세스가 과부하가 되기 때문에 여러개의 코어로 프로세스 동시 실행
쓰레드 = 프로세스 안에서 실행되는 여러개의 작업들. 프로세스 내에서 같은 메모리를 사용함.
하지만 쓰레드가 같은 메모리를 수정한다면 적용되지않는 에러가 발생.
해결법: 한 쓰레드가 작업을 진행할때 다른 쓰레드에게 대기 명령을 내리는 프로그램 사용 (ex: java => synchronize)
좋은 정보 감사합니다!
비유를 통한 설명이 참 좋아요
감사합니다!
와... 진짜 너무 이해가 잘되네요. 어떻게 미국 교수님보다 간단하게 이렇게 설명히 되네요. 정말 감사합니다!
it용어를 이 정도로 쉽고 정확하고 와닿게 설명할 수 있는 사람이 몇분이나 있을까. 감탄하고 갑니다.
네트워크 공부 시작한지 얼마 안되어서 스레드 활용한 멀티 프로세스 프로그래밍이 정말 헷갈렸는데 이 영상 하나도 바로 이해됐네요..
감사합니다!!
다른거 보다 잠오다가 이거보닌깐 잠이 확 깨네요ㅋㅋㅋ 감사합니다 귀에 쏙쏙이에요
정말 좋아할 수 밖에 없는 채널인 것 같아요!!
예시를 너무 잘 인용해주셔서 이해가 쉽네요!!
감사합니다!!
ㄹㅇ국비학원 강사없이 얄코 정주행 쫙 틀어주면 그게 더 유익한 시간일듯 개발입문자들 시청각자료로 0티어
이 댓글을 발견하셨다면, 아래에서 이번에 다룬 얄팍사전님의 프로세스와 스레드에 대한 영상내용을 함께 정리해보고 추가적인 내용을 알아봐요!
프로세스와 스레드
- 프로세스와 스레드는 프로그램을 실행하는 데 있어 결코 빠져서는 안되는 필수 요소에요. 이것들은 아래와 같이 짧게 정의할 수 있어요. 짧게 읽어보고 아래에서 좀 더 자세히 살펴보도록 해요.
- 프로세스 : 운영체제로부터 시스템 자원을 할당받는 작업의 단위 (메모리에 올라와 실행되고 있는 프로그램의 인스턴스)
- 스레드 : 프로세스가 운영체제로부터 할당받은 자원을 이용하는 실행 흐름의 단위 (프로세스 내에서 실행되는 여러 흐름의 단위)
===
Program : 프로세스 설명을 위해서, 프로그램이 무엇인지 알고 넘어가야 해요. 아래 정리를 보고 프로그램이 뭔지 확인하도록 해요.
- 파일이 저장 장치에 저장되어 있지만 메모리에는 올라가 있지 않은 정적인 상태인 어떤 작업을 위해 실행할 수 있는 파일
- 즉, 어떤 작업을 위해 실행할 수 있는 파일이지만 아직 실행되지 않은 파일 그 자체
- 메모리에 올라가있지 않다는 말은, 아직 운영체제가 프로그램에게 독립적인 메모리 공간을 할당해주지 않았다는 뜻이에요. 모든 프로그램은 운영체제가 실행되기 위한 메모리 공간을 할당해 줘야 실행될 수 있어요.
- 정적인 상태라는 말은, 단어 그대로 움직이지 않는 상태라는 뜻이에요. 한 마디로 아직 실행되지 않고 가만히 있다는 뜻이에요.
===
Process : 프로세스는 위에서 운영체제로부터 시스템 자원을 할당받는 작업 단위라고 했어요. 좀 더 알아보도록 해요.
- 실행 파일(프로그램)에게 의미를 부여하기 위해서는 프로그램을 실행해야 해요. 프로그램을 실행하는 순간 해당 파일은 컴퓨터 메모리에 올라가게 되는데, 이 상태의 프로그램을 프로세스라고 말해요.
- 프로그램을 실행하려고 운영체제로부터 시스템 자원을 할당받기 때문에, 운영체제로부터 할당받는 작업의 단위구나" 라고 이해하면 되요.
- 프로그램이 실행되어 파일이 컴퓨터 메모리에 올라간 상태를 동적인 상태라고 말해요. 즉, 프로세스는 실행되고 있는 동적 상태의 프로그램이에요.
- 프로세스는 운영체제로부터 여러 시스템 자원을 할당받아요.
- 각 프로세스는 최소 하나의 스레드를 가져요. 스레드가 무엇인지는 곧 다룰거에요.
- 각 프로세스는 별도 주소공간에서 실행되며, 일반적으로 다른 프로세스의 변수나 자료구조에 접근할 수 없어요. 왜냐하면 각 프로세스는 독립적이기 때문이에요.
- 하지만, 커널 영역에서 프로세스들끼리도 서로 데이터를 주고받는 방법이 존재하긴 해요. 그게 바로 IPC(Inter Process Communication)에요.
===
Thread : 스레드는 위에서, 프로세스 내에서 실행되는 작업의 여러 흐름단위라고 언급했어요. 조금 더 자세히 알아보도록 해요.
- 유튜브로 비유해보자면, 우리는 영상을 다운받을 수도 있어야하고 동시에 영상을 볼 수도 있어야 해요. 이렇게 한 프로세스 내에서 여러 갈래의 작업이 동시에 진행될수 있어야 하는데, 이 갈래가 바로 스레드에요.
- 스레드는 프로그램을 하나의 프로세스로 실행했을 때, 프로그램 하나가 단순히 한 가지 작업만을 하게 된다는 단점을 해결하기 위해 등장했어요.
- 그래서 우리는 스레드가 프로세스의 코드에 정의된 절차에 따라 실행되는 경로이자, 프로세스 내에서 실행되는 여러 흐름의 단위로 생각할 수 있어요
- 스레드는 프로세스 내에서 각각 별도의 Stack를 갖고있지만, Code, Data, Heap형식의 영역은 공유해요. 즉, 프로세스 내의 할당된 메모리공간을 스레드끼리 공유하면서 실행할 수 있다는 말이에요. 프로세스와 다르게 말이죠.
- 스레드는 프로세스와 다르게 프로세스의 자원을 공유하면서 작동하기 때문에, 스레드들은 프로세스 실행 흐름의 일부가 되는 것으로 이해할 수 있어요.
- 만약, 한 스레드가 프로세스 자원을 변경하면 다른 이웃 스레드(sibling thread)도 그 변경 결과를 즉시 볼 수 있어요. 서로가 같은 프로세스의 자원에 접근할 수 있으니까요.
[댓글 길이가 길어서 남은부분은 해당 댓글의 답글로 달았어요!]
===
차이
구분 | Process | Thread
영역 | 운영체제에 의해 각각 독립된 메모리 영역 | 할당 프로세스가 할당 받은 메모리 영역에서 Stack영역은 따로 할당받고, Code/Data/Heap 메모리 영역은 공유
공유 | 각각 독립된 메모리 영역을 할당받으므로 다른 프로세스의 변수나 자료에 접근 불가 | 별도의 Stack영역을 가지고 있지만 Heap 메모리와 같은 영역은 서로 읽고 쓸 수 있음
오류 전파 | 각 프로세스의 메모리 영역은 서로 독립적이므로, 오류 전파의 걱정이 적음 | Code/Data/Heap 메모리 영역의 내용을 공유하므로 특정 스레드에서 오류 발생 시, 같은 프로세스 내의 다른 스레드에 영향을 미침
단위 | 운영체제로부터 시스템 자원을 할당받는 작업 단위 (운영체제 입장에서 최소 작업 단위) | 프로세스 내에서 실행되는 흐름의 단위 (CPU 입장에서의 최소 작업 단위)
===
Multi Process
- 멀티프로세스는 하나의 응용프로그램을 여러 개의 프로세스로 구성하여 각 프로세스가 하나의 작업(태스크)을 처리하도록 하는 것이에요.
- 멀티프로세스는 각 프로세스의 메모리 구분이 필요하거나, 독립된 주소공간을 가져야 할 경우 사용할 수 있어요.
- 먼저, 멀티 프로세스의 장점에 대해 언급해볼게요.
1. 멀티 프로세스는 독립된 메모리 구조를 가지기 때문에, 프로세스 중 하나에 문제가 발생해도 다른 프로세스에게 치명적 영향이 확산되지 않는다는 안전성이 있어요.
2. 독립된 메모리 구조를 가짐으로 서로의 변수와 자료구조에 접근하지 못하기 때문에 동기화 작업이 별도로 요구되지는 않으나, 만약 프로세스 간 통신이 필요하면 IPC라는 복잡한 기법을 사용해야 해요.
- 다음으로, 멀티 프로세스의 단점에 대해 언급해볼게요.
1. 멀티 프로세스는 멀티 스레드보다 더 많은 메모리 공간과 CPU 자원을 차지해요. 운영체제로부터 시스템 자원을 할당받는 작업 단위가 여러 개니까 더 많은 CPU 자원을 할당한다고 생각하면 되요.
2. Context Switching발생 시, 캐시 메모리 초기화 등의 무거운 작업들을 동반하여 비용과 시간이 많이 소모되는 오버헤드가 발생할 수 있어요. Context Switching은 CPU가 한 번에 하나의 프로세스만 실행 가능하기 때문에 등장한 개념이에요.
좀 더 자세히 설명하자면, CPU에서는 여러 프로세스를 돌아가면서 한 번에 하나씩 작업을 실행해요. 만약 어떠한 이유로 동작 중인 프로세스가 대기 상태로 이동해야 한다면, 다음에 이 프로세스가 다시 CPU 자원을 받아 올라왔을 때 작업을 이어서 진행해야 할 거에요.
즉, 프로세스는 대기 상태로 넘어가면서 해당 프로세스의 상태(Context)를 보관해야 해요. 같은 맥락으로, 대기하고 있던 다음 순서의 프로세스는 CPU 자원을 할당받아 동작하면서 이전에 보관했던 프로세스의 상태를 복구하는 작업이 동반되어야 하겠죠? 이런 일련의 과정이 Context Switching이에요.
===
Multi Thread
- 멀티스레드는 하나의 응용프로그램을 여러 개의 스레드로 구성하고, 각 스레드로 하여금 하나의 작업을 처리하도록 하는 것이에요. 대표적으로 웹 서버가 있어요.
- 프로그램이 시작할 때 메인 스레드가 실행되고, 메인 스레드는 작업을 처리하기 위해 새로운 스레드를 생성해요. 이들은 병렬로 실행되며, 실행이 완료되면 메인 스레드와 결과를 동기화하는 방식으로 진행되요.
- 먼저, 멀티 스레드의 장점에 대해 언급해볼게요.
1. 프로세스를 생성해 자원을 할당하는 system call이 줄어들어 자원을 효율적으로 관리할 수 있어요. 즉, 시스템 자원의 소모를 줄임으로써 자원의 효율성을 증대시키고 시스템 처리량이 증가하게 되요.
2. 또, 프로세스에 비해 스레드 간 데이터를 주고 받는 것이 간단하기 때문에 통신 부담이 적고, 마찬가지로 시스템 자원 소모가 줄어들게 되요. 덕분에 스레드 사이의 작업량이 적어 Context Switching이 빨라요.
3. 프로세스에서의 Context Switching은 서로 공유하는 데이터가 없으므로 캐시가 쌓아놓은 데이터들이 무너지고, 새로 캐시 정보를 쌓아야 해요. 하지만, 스레드에서의 캐시 데이터는 스레드가 바뀌어도 공유하는 데이터가 있으므로 의미가 있어요. 그래서 Context Switching이 빠른 거에요.
- 다음으로, 멀티 스레드의 단점에 대해 언급해볼게요.
1. 멀티 스레드의 경우 자원을 공유하기 때문에, 각 스레드가 같은 공유 자원의 내용에 접근하고, 수정을 가할 경우 동기화 문제가 발생할 우려가 있어요.
2. 그래서, 스레드의 공유 자원 접근에 대해 주의 깊은 설계가 필요하며, 디버깅이 까다로운 점이 있어요.
3. 다른 프로세스(프로세스 밖)에서 스레드 각각을 제어할 수 없으며, 하나의 스레드만 오류로 종료되어도 전체 스레드가 종료될 수 있어요.
4. 마지막으로 하나의 스레드만 실행중일 때에는 실행시간이 되려 지연될 수 있어요. 여러 작업을 할 목적으로 멀티 스레드를 설계했을텐데, 하나의 스레드만 동작한다면 문제가 되겠죠?
해당 댓글의 답글이 어딧어요? 아까는 본거 같은데 다시 보려니 찾을수가 없네요
비유가 진짜 장난아니시네요 ㄷㄷㄷ... 좋은 영상 감사합니다!
감사합니다!!
이게 3년전 영상이라니.. 시간이 지나도 명강의네요
감사합니다!
찾았다 1타강사 ㅋㅋ 2배속으로 돌려봐도 이해가 잘가는 영상이었습니다.
12년차 IT쪽에서 일하는사람입니다만..참 설명 잘하시네요 목소리 딕션도 좋으시고^^ 항상 잘 보고있습니다. 프로세스와 쓰레드..대충 뭔진알지만 이렇게 잘 설명할수있는사람은 마니없죠 ㅎ
와...자바코딩까지 예술 ....바로구독 눌렀어요 미쳣어요 ㅠㅠ컨텐츠 계속기대할게요👏👏👏
감사합니다!!
최고의 설명인것같네요 ㅎㅎ 바로 이해했습니다 감사합니다 ㅎㅎ
감사합니다!!
우연히 찾게돼서 영상 5개째 내리 보고 있는데 처음보다 무척 잘생겨보이셔요 감사합니다 슨생님
앗 ㅎㅎㅎ 감사합니다!
4:59 스낵면이에요ㅋㅋㅋㅋㅋ
대애애애애애애박!!!!! 자막 덕분에 머리 쏙쏙들어와요 그대로 처럼 똑같이 진행해줘요!!!!
감사합니다!
라면끓이는 쓰레드 실제로 코딩햐서 눈으로 보여주는 그는 도덕책
자바라서 코드는 못알아 봐도 재미있게 봤습니다! 항상 재미있는 강의 감사해요~~>
재밌게 보아주셔서 감사합니다~!!
최근에 학교 과제를 하려고 자바를 개인적으로 공부하고 있는데 본 영상이 너무 큰 도움이 된 것 같아요! 항상 좋은 영상 너무 감사합니다~
제가 본 설명 중에 제일 깔끔한 프로세스 vs스레드입니다.. 👍
스레드에 관해서 쉽게 이해할 수 있었습니다! 앞으로도 잘 볼게요!
너무 쉽고 재밌는 설명 감사합니다 운영체제 공부중인데 도움이 많이많이 된거같아요 감사합니다!
와 설명의 킹이십니다. 구독하고 구독하기 잘했다는 생각이 들게 만드네요.
감사합니다!!
와 이런 설명을 소름 ㄷㄷ; 감사합니다.
감사합니다!!
프로세스랑 쓰레드의 개념이 공룡책같은 운영체제 서적에선 너무 어렵게 설명되어있던데
얄코님의 영상을 보니 머릿속에 쏙쏙 들어옵니다.
구독하겠습니다. 좋은 영상 많이 만들어주세요!
애매하게 알던 것을 좀 더 명확하게 알게되었어요. 감사합니다.
감사합니다!!
헝 면접때문에 부랴부랴 보고있습니다
좋은 영상 감사해요 😊
라면 예제 너무 재밌고 이해 쏙쏙입니다 ㅠㅠ👍
적게 일하고 많이 버세요
감사합니다 ㅠㅠ
얄코형 이런 cs지식 많이 많이 올려주세용❤️
감사합니다!
설명 잘 듣고 있습니다. 정말 많은 도움 받았습니다. 좋아요 꾹 누르고 갑니다. 스넥면이에욬ㅋㅋㅋㅋ 재밌었습니당
최고의 스레드 강의에요^^~!
매 영상 다 너무 유용하고 재밌어요 크항!!! 감사해요! DB 관련해서도 한번 다뤄주실 수 있나요? ㅠ.ㅠ 개념 이해하기 넘 좋을 것 같습니다!
감사합니다! 데이터베이스도 머지않아 다룰 계획이에요 ^^ 잘 준비해서 만들도록 할게요!
얄팍한 코딩사전 기대할게요😊😊
너무 몰입도 있게, 정확한 설명 감사드립니다! 이해가 잘되요
감사합니다!!
영상 뒷부분으로 갈수록 점점 th레드보단 쓰레드로 발음하시는데 더 듣기 편하네요 쓰레드가... ^^
예시들 덕분에 개념들이 쏙쏙 들어옵니다. 좋은 영상 만들어주셔서 감사합니다!
영상 하나 보고 바로 구독과 좋아요 눌렀습니다. 유용하고 친절한 컨텐츠와 설명 감사드립니다.
운영체제 공부중인데 대박 유용한것 같습니다. 감사합니다.
감사합니다!!!
Good! 좋은 코딩독학영상 감사합니다!
감사합니다!!
run부분 코드 쭉 쓰고 synchronized 블록 처리는 나중에 임계영역 접근하는 곳에 해주면 되는 듯
설명 너무 감사합니다... 스레드 개념이 이렇게 입체적으로 들어오네요
이 채널을 이제 알았다니..
와 설명 듣고 바로 구독 박았습니다...
감사합니다! 앞으로도 좋은 영상 많이 만들도록 하겠습니다.
예를 들어서 설명해주시니 이해하기 쉽네요. 영상 만들어주셔서 감사합니다. 오늘부터 구독 신청했어요 ~ ㅎ
감사합니다!! 더 좋은 영상들 만들게요~!!
속속들어오는 설명으로 3분 50초 까지는 행복했다 -,.-
ㅎㅎ 더 오래 행복하실 수 있도록 분발할게요!!
와 정말 최고의 설명 이 개념을 이렇게 쉽게 설명해주다니! 감사합니다
매일 아침 한개씩 꼭꼭 챙겨봅니다!
비유가 너무 재미있네요ㅋㅋ 구독 누르고 갑니다.
감사합니다!!
쉽고 재미있는 설명이 넘 좋네요
감사합니다!
아놔 이채널 대박이네
너무 유익하고 재미있습니다. !!
감사합니다!!
1:20 깨알 git ㅋㅋㅋㅋㅋ
뒷부분에 코드로 예시 설명 해주신게 혹시 멀티 스레드와도 관련된 것 일까요?
설명 너무 좋아요 진짜진짜로요 감사합니다!!
크 오늘도 깃똥찬설명감사합니다 설명을위해 예제코드까지 다 만드시는건가요? ㅜㅜ붙일곳도없지만 스티커라도 사야겠어요
우왕 ㅠㅜ 감사합니다!!!
깔끔한 설명이네요. 요즘 운체 공부 중인데 많은 도움이 되었습니다!
영상 질이 차원이 다릅니다. 천천히라도 좋으니 계속 만들어주세요.. ㅠ
한방에 이해됐어요. 정말 감사합니다! 다른 영상들도 감사히 잘 보겠습니다 ㅎㅎ
로멘스물이 에로물이 된다라.. 정말 조심해야겠네요!!
님 좀 짱인듯!!!
감사합니다!
객체지향에 개념에 대한 동영상도 만들어 주세요.
네, 조만간 다룰 예정이에요! 감사합니다~
와 ㅠ 코드랑 설명이랑 같이 들으니까 너무 이해가 잘되요 영상 찍어주셔서 감사합니다!
그리고 영상 주제 신청하고 싶은게 있는데 젠킨스 같은 CI 서버를 사용하면 좋은점 (?) , 필요성을 알고싶어요. 혼자 프로젝트 할때는 필요성을 느끼지 못해서 안했었는데 회사에선 사용하더라구요. 좀 알아봐도 제가 직접 배포 환경을 셋팅하지 않다보니까 잘 와닿지 않더라구요. 해당 주제에 해서 영상 찍어주시면 감사하겠습니다 !!
감사합니다! CI서버 내용도, 더 전에 배워야 할 내용들 이후로 기획중이에요. 얼른 좋은 컨텐츠로 만들도록 할게요~
정말 대단한 설명 감사합니다!!
감사합니다!!
참고로
작업관리자 단축키 : Ctrl + Shift + Esc
입니다.
키 위치 처럼 좌측으로 프로그램을 쭉 정렬해놓고 본다 라고 외우면 됩니다. 나중에 Ctrl이였는지 Alt였는지 헷갈리지 않아요.
수십개의 프로세스들이 여러개의 프로세서에 각각 할당되서 착착 돌아가는데 그 프로세스 안에 또 스레드가 존재해서 프로세스를 처리하는 그런 느낌인가봐요
OS 설계한 사람들은 신인가.. 어떻게 이런걸 구현했을까
아놔 에러물 심쿵했어요
와 정말 설명 잘해주셨네요! 감사해요!
감사합니다!
항상 감사합니다
스낵면 ㅋㅋㅋ 킬링파트네요
개그맨이신가요?? 지식+ 재미까지
설명 최고에여
감사합니다!!
감사합니다! 멋져요ㅋㅋ자바로 당장 해봐야겠어요
교수님수업듣다가 도무지 이해가안되서 따로검색하던중에 보게됬는데 정말 이해가 잘되네요 감사합니다. 왜 학교에서는 어렵게 가르치는걸까요?
어렵게 배워서일거에요 ㅎㅎ 감사합니다!!
항상 감사드립니다! 오늘도 개념 잡고 가요!!
코드 예제 따라해봤는데요 37번줄 조건문이 synchronized 블럭 안에 들어가야되지 않나요? 밖에 있으니까 동시에 조건문에 통과되는 경우에는 동시에 같은 버너를 사용하는 경우가 있는 것 같아요~
조회하는 코드라 넣지 않았었는데 말씀주신 상황을 고려 못했군요. 지적 감사합니다!!
@@yalco-coding 아 넵 ㅎㅎ 코드도 따라해보니까 이해가 더 잘되는 것 같아요! 항상 좋은 강의 감사합니다 :)
두 스레드가 동시에 손댄 것 같은 로그가 발생해서 의문이 생겨 댓글을 탐색하고 있는데 이미 여기 있었군요!
프로세스 fork하는 코드도 보여주세요~!!