본문 바로가기

CS

(27)
[Lecture] DHCP IPv4의 기본적인 문제점 address space 부족 security 대안 IPv6사용 - 96년도에 디자인했고, 앞으로 나오는 요구사항을 맞출 수 있다는 보장이 없음 (부정적 의견) 새로운 프로토콜 - 동적으로 변화가 가능한(요구사항 반영 가능한) 유연한 IP를 만들자는 아이디어가 있다 IPv4 를 사용하면서 얻은 가장 큰 교훈 미래를 예측할 수 없다 아키텍쳐(생태계)가 하나 들어오면 바꾸기가 어렵다 IPv6로 바꾸기 어려운 이유 전세계 존재하는 모든 라우터가 IPv6으로 바뀌어야하는데, 각 라우터의 소유자가 다 다르다(KT,SKT등 통신 사업자) 생태계적인 문제로 타협이 어렵다 라우터는 포워딩만 해야한다.. 근데 여러가지가 곁들여진 .. DNS가 라우터로 가져오고, naver computer IP..
[Lecture] Network layer : IP(Internet Protocol) Nework layer 이제 어떻게 보낼 것인지에 대해 다룰 것이다. 인터넷 프로토콜인 IP에서 볼 것이다 라우터는 이 배송에 참여하기 때문에 전에 얘기했듯이 stack(networt layer, link layer, phy- layer)를 가지고 있다 transport segment를 송신측에서 수신측으로 보낸다 송신측은 segments를 datagrams로 캡슐화한다 수신측은 segments를 transport 계층에 전달한다 라우터는 그것을 통과하는 IP 데이터그램의 헤더 필드를 검사한다 각 패킷은 라우터의 네트워크 계층까지 올라갔다가 다시 전송된다 (형광펜 표시) Two key network-layer function forwarding : move packets from router's inpu..
[Lecture] TCP : Congestion control 네트워크가 막히면 상황이 더 악화되기 때문에 (TCP가 재전송하기 때문에 더 막힌다) 따라서 속도조절이 필요하다 수로와 같다고 생각하면 편하다. 너무 많이 보내면 얇은 부분의 파이프가 터진다. 따라서 이 얇은 부분의 파이프가 감당할 수 있을만큼의 물을 흘려줘야한다 네트워크는 이 얇은 부분을 리포트해주지 않기 때문에 속도를 조금씩 늘리며(물을 조금씩 부어서)속도를 맞춰가야한다 TCP Congestion Control 3 main phases Slow start Additive increase (조심히 늘리는) : increase CongWin by 1MSS every RTT until loss detected Multiplicative decrease : cut CongWin in half after lo..
[Lecture] TCP : Flow Control Flow Control A B send buffer(나의 seq#) ===> recv buffer(상대방의 seq#) recv buffer(상대방의 seq#)
[점프 투 스프링] 질문 및 요약정리 (1) Spring boot : 자바의 웹 프레임 워크 spring 프레임 워크 + 톰캣(내장 서버) ㄴ 톰캣 : 클라이언트가 요청을 하면 맞는 자바 프로그램을 실행시킨다, 배포되는 jar파일에도 적용된다 대표적인 웹 브라우저 보안공격 SQL 인젝션 SQL 주입공격 XSS js 삽입공격 CSRF 위조된 요청으로 공격 클릭재킹 의도하지 않는 클릭을 유도해서 공격 웹어플리케이션 -- WAS(software 플랫폼) -- 서버환경 Q. WAS가 필요한 이유? 웹 서버 : 정적콘텐츠(즉시 응답이 가능한 것들 : html 문서 등)를 제공한다 WAS : 데이터베이스 조회나 다양한 로직 처리가 필요한 동적 컨텐츠를 제공한다 기능을 나눠 서버부화를 방지한다 https://codechasseur.tistory.com/25
[Lecture] Connection-oriented transport: TCP TCP : Overview point-to-point one sender, one receiver 하나의 sender와 receiver(딱 한쌍)의 통신을 권장한다 (단일 소켓 통신 패턴) 엄격히 말하자면, process사이 소켓 한쌍 사이의 통신을 말한다 reliable, in-order byte stream no message boundaries TCP는 스트림 지향 프로토콜로, TCP는 데이터를 메시지로 나누어 주지 않고, 연속된 스트림으로 전송한다. TCP는 데이터를 세그먼트로 나누어 전송하며, 수신측에서는 이 세그먼트를 재조립하여 완전한 데이터를 얻게 된다. 이 과정에서 데이터의 경계를 명확히 지정하지 않는다. 유실되지 않고, 순서대로 간다 pipelined TCP congestion and f..
[Lecture] Pipelined protocol (Go-Back-N과 Selective Repeat) 지난시간 packet error : error detection, feedback, retransmission, sequence# (4가지 매커니즘으로 해결) packet loss : timer의 timeout (로 해결) => reliable data transfer protocol이지만, 현실세계에선 사용하지 않는다 (transmition(패킷하나를 link에다 올려 보내는 시간) 공식 : 이전글 참조) Usender의 분자는 sender가 보내는 시간, 분모는 sender가 보내는 시간 + 그 다음 보내기 전까지의 시간 결과를 보면 sender가 보내는 시간의 비율이 0.00027이기 때문에 효율적이지 않다는 것을 알 수 있다 전체시간에서 sender가 네트워크를 사용하는 비율이 클수록 좋다 (효율..
[Lecture] Principles of Reliable Data Transfer 목표 : reliable data transfer이 가능한 통신의 원리를 이해한다 Principles of Reliable Data Transfer 앞서 수업을 통해서 알 수 있는건, transport 아래는 unreliable한 부분이라는 것이다 unreliable하면 두가지 문제점이 발생한다 packet error packet loss RDT protocol (reliable data transfer) : sender가 packet을 하나씩 보내고, receiver가 받으면 또 하나 보낸 방식 : stop-wait-protocol 만약에 unreliable한 채널이 완벽하면 RDT 동작은 딱히 할 것이 없다 (비현실적인 상황) packet errors message error Error detecti..