[Concepts] 프로그래밍 언어의 실행 과정[Concepts] 프로그래밍 언어의 실행 과정

Posted at 2019. 7. 2. 21:49 | Posted in Computer Concepts




출처 : IT CookBook, 컴퓨터 사이언스






■ 사용자 요구사항 분석과 프로그램 설계




간단한 프로글매이면 분석 없이 바로 코딩을 하기도 하지만, 복잡하거나 규모가 큰 프로그램을 개발할 때는 사용자의 요구사항을 분석한 후 설계한다.




#01. 사용자 요구사항 분석


사용자가 무엇을 원하는지 파악하고 프로그램을 통해 해결할 문제가 무엇인지 확인하는 단계이다. 프로그램의 출력물에 어떤 내용을 포함시켜야 하고, 이를 위해 입력할 내용은 무엇인지, 폼은 어떻게 구성해야 하는지 등을 설계한다. 사용자와 시스템 사이의 인터페이스 방식은 어떻게 할지, 데이터 구조 및 처리 절차에 대한 기본 틀은 어떻게 할지 등을 분석해야 대략적인 설계를 한다. 이 과정이 모두 끝났다면 프로그램 설계를 시작한다.





#02. 프로그램 설계


실제 코딩을 시작할 때 사용할 논리를 프로그래머가 대략 그려내는 단계로 보통 알고리즘 설계라고 한다. 알고리즘(algorithm)의 사전적 의미는 반복 동작을 포함하여 정해진 단계 내에서 형식적이고 수학적으로 표현된 문제를 푸는 절차이다. 즉 어떠한 결과가 나오도록 차례를 설계하는 것을 알고리즘 설계라고 한다.



알고리즘은 다음과 같은 다섯 가지 주요한 특성이 있다.







※ 알고리즘의 5가지 특성



① 알고리즘 명령을 수행하면 유한한 횟수를 거친 후 종료해야 한다.


② 알고리즘의 각 단계와 명령은 명확하게 정의되어야 한다.


③ 알고리즘은 데이터 입력이 0 또는 그 이상이어야 한다.

    여기서 입력은 알고리즘이 시작되기 전에 알고리즘에 주어진 또는 알고리즘 수행 중에 동작으로 주어진 수량을 말한다.


④ 알고리즘은 한가지 이상의 결과를 출력한다.


⑤ 알고리즘은 효과적이어야 한다.
    이는 알고리즘의 모든 연산이 종이와 연필을 이용해 유한한 시간 내에 정확히 수행할 수 있을 정도로 단순해야 함을 의미한다.







이상을 정리하면, 알고리즘은 항상 어떠한 결과(답) 나오도록 만들어진 단계의 모양이다. 여기에서 중요한 것은 인간의 뇌 속에 지식으로 가지고 있는 '문제를 푸는 방법'을 어떻게 문자나 기호 등을 이용해 시각적으로 표현하느냐이다.



문제 푸는 방법을 알고리즘으로 쉽게 표현하기 위해 순서도나 의사 코드 등을 사용한다. 순서도는 제어 흐름을 그림으로 표현한 것이고, 의사 코드는 프로그램과 비슷한 문자로 표현한 것이다. 두 방법 모두 프로그램 실행에 대한 명확한 문법 구조가 아닌 프로그램 전체 구조와 제어 흐름만 나타낸다.


순서도나 의사 코드로 표현되는 프로그램 제어 흐름 유형에는 순차 구조, 선택 구조, 반복 구조가 있다.




※ 프로그램 제어 어 흐름의 유형







:: 순차 구조 ::

:: 선택 구조 ::

:: 반복 구조 ::





◎ 순차 구조 ( Sequence Structure )


순차 구조는 프로그램 코드를 순서대로 실행한다.



◎ 선택 구조 ( Selection Stucture )


선택 구조는 프로그램이 다음에 무엇을 해야 할지 결정하는 분기 구조이다.

조건문(Conditional Stucture)으로 부르기도 한다.

보통 if - then문, case 문, else 또는 else if 문을 포함한 if - then 문을 사용한다.



◎ 반복 구조 ( Repetition Stucture )


반복 구조는 조건이 만족되지 않을 때까지 계속 반복한다.

루프 구조(loop structure)로 부르기도 한다.

프로그래밍 언어마다 반복 구조를 표현하는 방법이 있는데,

for 문, while 문, do - while 문 을 공통으로 사용한다.





① for 문






 어떤 과정을 특정 횟수만큼 반복한다. 조건식이 참이면 문장을 실행한 뒤 증가 연산을 하고 다시 조건식을 검사한다.

 조건식이 거짓이면 문장을 실행하지 않고 for문을 종료한다.



② while 문





 조건식을 만족하는지 여부를 확인한다.

 조건식이 참이면 문장을 실행하고 거짓이면 while 문을 종료한다.

 즉 while 문은 조건식이 거짓이 되지 않는 한 계속 실행된다.





③ do - while 문




 조건식을 먼저 검사하는 while 문과 달리 일단 문장을 한 번 실행 한 후 조건식이 만족하는지 여부를 확인한다.

 조건식이 참이면 문장을 실행하고 거짓이면 do - while 문을 종료한다.











■ 코딩 및 컴파일




프로그래밍 언어로 프로그램을 작성하는 것을 코딩(Coding)이라고 한다. 코딩을 할 때는 개발할 프로그램의 특성에 맞는 프로그래밍 언어를 선택하여 작성해야 한다. 코딩이 끝나면 고급언어로 작성된 명령문을 기계어로 바꾸는 컴파일(Compile) 단계에 들어간다. 컴파일은 프로그래밍 언어의 성격에 따라 컴파일러 compiler를 이용한 방식과 인터프리터(Interpreter)를 이요한 방식이 있고 두 방식을 혼합한 하이브리드 hybrid 방식이 있다.





#01. 컴파일러를 이용한 방식


프로그램 전체를 한 번에 기계어로 번역하는 방식을 C언어를 비롯하여 코볼, 포트란, 파스칼 등에서 사용된다. 다음 그림은 컴파일러를 이용한 방식으로 프로그램을 실행하는 과정이다. 컴파일러는 고급 언어로 작성된 원시 코드를 기계어인 목적 코드로 번역한다. 목적 코드는 로더에 의해 메모리에 옮겨져 실행(Execution)되어 결과 값을 출력한다.


컴파일러는 한번 목적 코드로 번역하고 나면 실행할 때마다 번역할 필요가 없으므로 프로그램 전체의 실행 시간을 줄일 수 있다. 하지만 원시 코드 일부만 수정되어도 프로그램 전체를 다시 번역해야 하므로 번거로울 수 있다.









#02. 인터프리터를 이용한 방식


프로그램을 한 행씩 읽어 번역과 실행을 동시에 하는 방식으로 베이직 등에서 사용된다. 원시 코드가 수정될 때마다 프로그램 전체를 번역할 필요가 없으므로 간단한 구조의 프로그램은 편리하나 반복문이나 계속 호출되는 서브 프로그램처럼 많은 횟수로 처리되는 프로그램은 실행 시간이 길어져 비효율 적이다.











#03. 하이브리드 방식



컴파일러 인터프리터를 함께 이용하는 방식으로 리스프(LISP), 스노볼4(SNOBOL4), API, 프롤로그(Prolog), 자바(JAVA)등에서 사용된다. 이 방식은 컴파일러가 원시 코드를 목적 코드로 번역하는 것이 아니라 적당한 중간 코드로 번역한다. 중간 코드는 인터프리에 의해 입력 자료와 함께 실행된다.
















Name __

Password __

Link (Your Website)

Comment

SECRET | 비밀글로 남기기

[Concepts] 프로그래밍 언어의 개요[Concepts] 프로그래밍 언어의 개요

Posted at 2019. 6. 26. 20:21 | Posted in Computer Concepts




출처 : IT CookBook, 컴퓨터 사이언스






 프로그래밍 언어의 개념



컴퓨터를 움직이게 하려면 명령을 내려야 한다.

프로그래밍 언어는 인간이 컴퓨터와 의사소통할 수 있도록 컴퓨터에 내리는 명령으로 프로그램을 처리하도록 기술한 언어를 말한다.


프로그램은 인스트럭션(Instruction)이라는 명령어로 쓰여 있고, 컴퓨터는 인스트럭션을 논리적 순서(문제를 푸는 방법)에 따라 수행한다. 하지만 2장에서 살펴본 것처럼 컴퓨터는 0이나 1로 된 2진수 형태의 기계어만 처리할 수 있으므로 인스트럭션 역시 기계어로 쓰여 있어 인간이 이해하기 힘들다. 이 문제를 해결하기 위해 인간도 쓰기 쉽고 컴퓨터도 기계어로 해석 할 수 있는 프로그래밍 언어(Programming Language)를 개발하여 사용하게 되었다.








■ 저급 언어와 고급 언어



프로그래밍 언어는 기계어와 유사한 저급 언어와 인간이 쓰는 자연 언어와 유사한 고급 언어로 나뉜다.




#01. 저급 언어


저급언어란 컴퓨터 내부 표현에 가까운 언어로 기계어와 어셈블리어로 나눌 수 있다.

기계어는 0과 1로 작성하고, 어셈블리어는 기계어를 인간이 이해하기 쉽도록 기호홀 표현하여 작성한다.



◎ 기계어 ( Machine Language) 


기계어는 0과 1로 된 2진수 형태의 언어이다.

인간이 이해하기 어려울 뿐만 아니라 하드웨어 주소 체계에 따라 배열이 달라져 컴퓨터 끼리 호환되지 않는 문제가 있어 지금은 거의 사용되지 않는다.



◎ 어셈블리어 ( Assembly Language )


어셈블리어는 기계어 명령을 알기 쉬운 기호로 표시하기 떄문에 기계어는 물론 사용하고자 하는 컴퓨터 내부 구성과도 관계가 깊다.

예를 들어 LDA A라는 어셈블리어 코드는 메모리 A번지에 있는 내용을 누산기 accumulator에 저장하라는 의미로, 기계어 010100000000100에 해당한다.

다음은 A ∨ B 수식을 ( A' ∧ B' )형태로 치환해 계사한 어셈블리어의 예이다.



  LDA A 

 // A번지에 있는 데이터 값을 로드한다.

  CMA

 // 위의 값을 보수( A' )로 바꾼다.

  STA TMP

 // 위의 값을 임시 저장소에 저장한다. 

  LDA B

 // B번지에 있는 데이터 값을 로드한다.

  CMA

 // 위의 값을 보수( B' )로 바꾼다.

  AND TMP

 // AND( A' ∧ B' ) 계산을 수행한다.

  CMA

 // 계산 결과를 보수화하여 ( A ∨ B ) 결과 값을 얻는다.



어셈블리어는 기계어에 비해 간편하게 쓸 수 있지만 기계어인 0과 1의 집합을 문자나 기호로 바꾼 것에 불과하므로 하드웨어 구조에 익수한 사람이 아니면 쓰기 어렵다.

그럼에도 불구하고 주기억 장치, 레지스터, 마으코르포르세서, 입출력 포트 같은 컴퓨터의 하드웨어 장치를 직접 제어할 때는 매우 유용하다.




#02. 고급언어



사용자의 요구 수준이 높아지고 컴퓨터 기술이 발달하면서 다양한 고급 언어가 개발되었다.

고급 언어는 하드웨어의 기술적 요소를 구체적으로 몰라도 쉽게 작성하고 수정할 수 있다.


고급언어의 특징은 다음과 같다.


일상 언어에서 사용하는 표현을 그대로 가져다 쓸 수 있다.

예를 들어 +는 덧셈, -뺄셈으로 상요한느 등 일반적으로 사용하는 단어나 표현을 그대로 쓴다.


기계어나 어셈블리어를 쓰려면 기억장치에 데이터를 읽거나 쓸 때 기억 장소의 주소를 정확히 알아야 한다.

이에 비해 고급 언어는 번지 대신 변수 이름으로 기억 장소에 접근하므로 사용자가 기억 장소의 주소를 일일이 기억할 필요가 없다.


명령어 하나로 다수의 동작을 지시한다.

예를 들어 X = Y + Z × W 명령어는 Z와 W를 먼저 곱하고 그 결과를 Y에 더해 X에 대입하라는 뜻이다.

이처럼 하나의 명령어로 다수의 연산을 실행한다.


다음 그림은 고급 언어로 작성한 프로그램을 실행하는 과정이다. 프로그래머는 먼저 고급 언어와 같은 프로그래밍 언어를 이용해 원시 코드를 작성한다. 그 다음 번역기(컴파일러)가 원시 코드를 목적 코드로 번역한다. 여기서 목적 코드는 긱어로 된 프로그램으로 컴퓨터가 바로 실행할 수 있는 상태의 프로그램 코드이다. 목적 코드는 메모리로 옮겨져 실행되고 결과물을 계산해 낸다.




※ 프로그램 작성과 실행과정





종류에 따라 다르지만 고급 언어는 다음과 같은 형식적인 규칙이 있다. 이를 프로그래밍 언어의 문법 구조(Syntax)라 한다.


어떤 구조와 순서가 있다.

특별한 기호를 사용한다.

언어에 따라서는 마침표( . )나 세미콜론( ; ) 등을 사용한다.


대표적인 고급 언어로는 C언어를 비롯해 포트란(FORTRAN), 코볼(COBOL), 파스칼(PASCAL), C++, 자바(JAVA), 스몰토크(SMALLTALK) 등이 있다.





#03. 프로그래밍 언어의 발전


나라마다 사용하는 언어가 다르듯 프로그래밍 언어도 수백 종 이상이 개발되어 사용되고 있다. 언제 개발되었고 어떻게 발전되어 왔는지 살펴보자.



① 1950년대 언어


이전까지 기계어로 작성하던 프로그램을 1950년대 초에 처음으로 어셈블리어로 작성하였다.

어셈블리어는 기계어인 0과 1을 인간이 이해하기 쉬운 코드로 바꾸어 기계어보다 작성하기 쉬웠지만, 하드웨어 위주의 언어라는 제약이 따랐다.

그러던 중 과학 분야의 복잡한 계산을 수행하기 위해 포트란(FORTRAN, FORmula TRANslator)이 개발되었다.

포트란은 프로그래밍 언어가 발전하는데 새로운 이정표를 세웠다.



② 1960년대 언어


포트란을 발전시킨 과학기술용 고급 언어가 잇따라 개발되었고, 사무 처리용 고급 언어도 개발되었다.

대표적인 사무 처리용 언어가 코볼(COBOL, COmmon Business Oriented Language)이다.

코볼은 미국 국방성이 후원하여 컴퓨터 제품 간의 호환성 문제를 해결하기 위해 개발한 것으로, 수차례의 수정과 보완을 거쳐 사무 처리용 언어로 확고히 자리를 잡았다.

포트란 같은 과학기술용 언어는 프로그램을 수학적 푝법을 사용하여 작성하는데 반해, 코볼은 영어에 가까운 구문을 사용하기 때문에 작성하기도 편하고 이해하기 쉽다는 장점이 있다.

1960년대 포트란과 코볼의 장점을 살린 하이브리드 형태인 PL/I(Programming Language One)이 등장해 관심을 크게 끌었지만, 오늘날에는 코볼에 비해 사용 빈도가 낮은 편이다.



③ 1970년대 언어


하드웨어 가격이 떨어지고 소프트웨어가 복잡해지면서 프로그래밍 언어 역시 소프트웨어 중심으로 비중이 옮겨가기 시작했다.

소프트웨어의 복잡성과 관리가 중요한 쟁점으로 떠오르면서 더 강력하고 새로운 개념의 언어가 필요해졌다.

이렇게 개발된 언어가 C언어와 파스칼(PASCAL)이다.


C언어는 원래 시스템 소프트웨어를 개발하는 언어였지만 다양한 종류의 컴퓨터에 이식할 수 있다는 점 때문에 현재까지도 여러 분야에 두루 사용되고 있다. 실제로 수많은 워드프로세서, 스프레드시트, 그래픽 프로그램, 게임 등이 C언어로 제작되었다.

유닉스 운영체제가 등장하면서 C언어의 인기가 날로 높아졌는데 이것은 비트 연산과 같은 저급 언어 기능을 갖추고 있어 빠르고 효율적이기 때문이다.

물론 이후 등장한 언어에 비해 배우기가 어렵고 보고서 작성이나 데이터 파일 조작이 많은 업무에는 부적합하다는 단점이 있다.


파스칼은 프랑스 수학자인 파스칼(Pascal)의 이름에서 따온 언어로, 1969년에 스위스 취리히 공과대학의 니클라우스 위스(Niklaus Wirth) 교수가 개발했다.

파스칼은 당시 유행한 구조적 프로그래밍에 적합한 언어이기도 했고, 쉽게 배울 수 있는 것은 물론 이공계 및 과학계 종사자가 주로 사용하는 그래픽 처리 기능 또한 뛰어나 많은 사람에게 주목을 받았다.

하지만 대화식 입출력이나 사무 처리 분야에 응용하기엔느 부족했고, C언어에 비해 사용자를 크게 늘리지 못하면서 1990년대 중반 이후에는 인기가 시들해졌다.



④ 1980년대 언어


본격적으로 컴퓨터 하드웨어 가격이 떨어지면서 개인용 컴퓨터와 중앙 컴퓨터가 연결된 단말 시스템을 이용한 분산 처리 개념이 확산되었다.

이러한 이유로 학생들과 컴퓨터 초보자들도 쉽게 배울 수 있는 교육용 언어가 필요해졌고 이때 등장한 언어가 베이직(BASIC)이다.

베이직은 쉽게 배울 수 있고 중앙 컴퓨터와 연결된 단말 시스템에서 처리하는 시분할 시스템(Time Sharing System)운영 에 적합한 기능을 가지고 있어 많은 인기를 끌었다.

다만 비교적인 측면이 있어 소프트웨어 규모가 커질 수록 관리하기 번잡해지고 운영이나 유지가 많이 어렵다는 단점이 있었다.

이후 이러한 단점을 개선한 퀵 베이직(Quick Basic)과 비주얼 베이직(Visual Basic) 등이 등장했고 지금까지도 널리 사용되고 있다.



⑤ 1990년대 언어


객체 지향 언어가 본격적으로 등장했다.

특히 GUI(Graphical User Interface) 환경의 프로그래밍을 위한 여러 클래스의 라이브러리가 등장하면서 객체 지향 언어의 장점이 크게 부각되었다.

이러한 추세에 맞춰 C++, 자바(JAVA), 비주얼 베이직(Visual Basic)등의 객체 지향 언어가 등장했다.

이들 언어은 기존의 객체 개념을 업그레이드하고 GUI 개념을 강화하는 방향으로 더욱 발전해 나갔다.


비주얼 베이직은 베이직과 퀵 베이직을 개선하여 객체 지향 개념을 보강한 언어이다.

GUI 기능을 내세워 사용자가 쉽게 사용할 수 있어 지금까지 많이 활용된다.



⑥ 2000년대 이후 언어


2000년대에 접어들면서 사용자는 더욱 간편하고 쉬운 방법으르 프로그래밍하길 원했고 이미 개발된 프로그램을 쉽게 가져다 쓸 수 있는 소프트웨어가 나오길 기다렸다.

강화된 기능의 웹과 저렴해진 하드웨어는 이러한 사용자 요구를 만족시킬 방법을 찾아냈다.


먼저 파워빌더(PowerBuilder), 델파이(Delphi), 각종 쿼리(Query) 전용 언어 등 소위 4세대라 불리는 언어가 등장했다.

4세대 언언느 특정 상황에 맞춤식으로 사용할 수 있고, 종래의 고급 언어보다 사용하기가 쉽다.

또한 사용자에게 강화된 텍스트 환경이나 시각 환경을 제공한다.


객체 지향 프로그래밍 기법이 발전하면서 소프트웨어 모듈을 컴포넌트화하여 필요할 때마다 사용할 수 있도록 하는 소프트웨어 컴포넌트 기술도 빠르게 발전했다. 이 기술은 소프트웨어를 전자 부품처럼 통일된 인터페이스로 제작함으로써 소프트웨어(Software Factory)을 만들 수 있도록 도왔다.

소프트웨어 컴포너트는 차세대 소프트웨어 기술의 핵심 분야로 인식되면서 소프트웨어 생산성 향상을 위한 필 수 기술로 대두 되었다.


이 시기에는 객체 지향 기술과 웹이 결합하여 다양한 정보를 제공하는 기법이 발전했다.

XML(eXtensible Markup Language)과 VRML(Virutal Realiry Modeling Language) 등 각종 웹 프로그래밍 언어가 등장했다.

XML은 HTML의 한계를 극복할고 만든 언어로 다른 시스템 특히 인터넷에 연결된 시스템끼리 데이터를 쉽게 주고받을 수 있도록 한다.

VRML은 인터넷이나 로컬 시스템에서 3차원 개체나 세계를 표현하기 위한 파일 형식이다.

XML과 VRML은 기존 객체 지향 언어와 결합하여 인터넷에서 텍스트, 이미지, 애니메이션, 사운드 등을 비롯한 가상현실(Virtual Reality) 까지 구현할 수 있는 기술로 발전하고 있다.


최근에는 5세대 언어라 불리는 인공지능 기능을 이요해 자연 언어(Natural Language)로 직접 처리하는 기법에 대한 연구가 활발히 진행되고 있다.

음성인식 시스템이나 자동 번역 시스템 등도 이러한 기법의 일부라 할 수 있다.






※ 프로그램 작성과 실행과정









Name __

Password __

Link (Your Website)

Comment

SECRET | 비밀글로 남기기

[Concept] DNS(Domain Name System) 이란?[Concept] DNS(Domain Name System) 이란?

Posted at 2019. 6. 20. 16:46 | Posted in Computer Concepts




참고 : https://support.google.com/a/answer/48090?hl=ko

참고 : https://aws.amazon.com/ko/route53/what-is-dns/





■ DNS(Domain Name System)의 기본사항




-. DNS는 도메인 이름 시스템을 의미하며, 기본적으로 웹에서 도멘인을 정리하고 확인하는 전화번호부와 같은 역할을 한다.

-. 스마트폰이나 노트북부터 대규모 소매 웹 사이트 콘텐츠를 서비스 하는 서버에 이르기까지 인터넷상의 모든 컴퓨터는

   숫자를 사용하여 서로를 찾고 통시하는데 이러한 숫자를 IP주소라고 한다.

-. 웹 브라우저를 열고 웹 사이트로 이동할 때는 긴 숫자를 기억해 입력할 필요없이 wickedmiso.com 같은 도메인 이름을 입력해 원하는 웹 사이트로 갈 수 있다.

-. "Acme Pizza"와 같은 이름이 전화번호부를 통해 전화번호로 변환되는 것처럼, "www.google.com"과 같은 웹 주소는 웹 주소는

  DNS를 통해 "74.125.19.147"과 같이 사이트(이 경우 Google 홈페이지)를 호스팅하는 컴퓨터의 실제 IP주소로 변환된다.





■ DNS SERVER의 역할









① 사용자가 웹 브라우저를 열어 주소 표시줄에 www.domain.com 을 입려가호 Enter키를 누른다.


② www.domain.com에 대한 요청은 일반적으로 케이블 인터넷 공급업체, DSL 광대역 공급업체 또는 기업 네트워크 같은 인터넷 서비스 제공업체()


③ ISP의 DNS 해석기는 www.domain.com에 대한 요청을 DNS 루트 이름 서버에 전달한다.


④ ISP의 DNS 해석기는 www.domain.com에 대한 요청을 이번에는 .com 도메인의 TLD 이름 서버 중 하나에 다시 전달한다.

 

⑤ ISP의 DNS 해석기는 DNS 네임 서버 하나를 선택해  www.domain.com에 대한 요청을 해당 이름 서버에 전달한다.


⑥ DNS 네임 서버는 domain.com 호스팅 영역에서 www.domain.com 레코드를 찾아 웹 서버의 IP 주소(예 : 120.0.0.1)에 연관된 값을 받고

   이 IP 주소를 DNS 해석기로 변환한다.


⑦ ISP의 DNS 해석기는 마침내 사용자에게 필요한 IP주소를 확보하게 된다. 해석기는 이 값을 웹 브라워로 반환한다.

   또한, DNS 해석기는 다음에 누군가가 example.com을 탐색할 때 좀 더 빠르게 응답할 수 있도록 사용자가 지정하는 일정 기간동안

   domain.com의 IP주소를 캐싱(저장)한다.(자세한 내용은 TTL(Time to Live)을 참조)


⑧ 웹 브라우저는 DNS 해석기로 부터 얻은 IP 주소로 www.domain.com에 대한 요청을 전송한다.

    여기서 콘텐츠가 있는 곳으로, 예를 들어 웹 사이트 엔드포인트로 구성된 웹 서버이다.


⑨ 120.0.0.1에 있는 웹 서버 또는 그 밖의 리소스 www.domain.com의 웹 페이지를 웹 브라우저로 반환하고, 웹 브라워는 이 페이지를 표시한다.










■ DNS의 종류





# MX 레코드(Mail Exchanger Record)


-. 메일 교환(MX) 레코드는 도메인 이메일을 도메인의 사용자 계정을 호스팅하는 서버로 전송한다.




# TXT 레코드(Text Record)


-. TXT 레코드는 도메인 외부 소스에 다양한 목적으로 사용될 수 있는 텍스트 정보를 제공하는 DNS 레코드이다.

-. 레코드 값은 사람이나 컴퓨터가 읽을 수 있는 텍스트가 될 수 있다.




# CNAME 레코드(Canonical Name Record)


-. CNAME 레코드 즉 정규 이름 레코드는 다른 페이지에 정규 도메인 이름앞에 별칭 이름을 지어 연결한다.

-. 예를들어 www.wickedmiso.com을 wickedmiso.com 혹은 blog.wickedmiso.com 으로 연결할 수 있다.




# A 레코드(Address Mapping Records)


-. A 레코드는 주소 레코드 혹은 호스트 레코드라고 한다.

-. 도메인 서비스를 호스팅하는 컴퓨터의 실제 IP주소에 도메인을 연결한다.




# NS 레코드(Name Server Records)


-. 네임 서버 레코드는 도메인에 대해 어떤 서버가 DNS 정보를 전달할지 결정한다.

-. 일반적으로 도메인에 기본 및 보조 네임서버 레코드가 있다.




# TTL(Time To Live)


-. TTL은 다음 레코드 변경사항이 적용될 때까지 걸리는 시간(초)을 결정하는 DNS 레코드 값이다.

-. MX레코드, CNAME 레코드 등 도메인의 각 DNS 레코드에는 TTL 값이 포함된다.

-. 레코드의 현재 TTL은 변경사항이 적용될 때까지 걸리는 시간을 결정한다.

  예를 들어 TTL값이 86,400초인데 레코드는 변경사항은 적용될 때까지 24시간이 소요된다.



※ 레코드 설정을 단축하는 방법

  · 레코드의 TTL을 변경하면 향후 변경사항이 적용되는 시간에 영향을 준다.

  · 인터넷사의 서버가 레코드의 업데이트 사항을 매시간 확인하도록 TTL값을 3600으로 설정하는 것이 좋다.

  · 단축된 TTL은 이전 기간이 만료된 후에만 효력을 발생한다.

  · 이렇게 하면 향후 레코드를 업데이트할  경우 변경사항이 적용될 때까지 한시간이 소요된다.

  · 변경사항을 신속하게 되돌릴 필요에 대비하는 등 다음 변경사항이 더욱 빠르게 적용되도록

    TTL을 300초(5분)와 같이 더 짧게 설정할 수도 있다.

  · MX레코드가 올바르게 구성되면 TTL값을 86400으로 설정하는 것이 좋다. 이렇게 하면 인터넷상의

   서버에서 24시간 마다 확인하여 MX 레코드를 업데이트 하게 된다.





# URL(Uniform Resource Locator)


-. URL은 인터넷 리소스의 웹 주소로, 특정 웹 사이트를 방문하기 위해 브라우저에 입력하는 주소이다.








■ DNS 구성 예시



-. DNS 설정시 실제 도메인 이름이 아닌 @기호를 사용하여 도메인 이름을 표시한다.



※ Google Cloud 서비스와 함께 사용된ㄴ 도메인의 샘플 DNS 설정

이름 / 호스트 / 별칭 

레코드 유형

우선순위

예) 값 / 응답 / 목적지

공백 또는 @

A

NA

 216.239.32.21

공백 또는 @

A

NA

 216.239.32.21

공백 또는 @

A

NA

 216.239.32.21

공백 또는 @

A

NA

 216.239.32.21

공백 또는 @

MX

1

 ASPMX.L.GOOGLE.COM.

공백 또는 @

MX

5

 ALT1.ASPMX.L.GOOGLE.COM.

공백 또는 @

MX

5

 ATL2.ASPMX.L.GOOGLE.COM.

공백 또는 @

MX

10

 ASPMX2.GOOGLEMAIL.COM.

공백 또는 @

MX

10

 ASPMX3.GOOGLEEMAIL.COM.

공백 또는 @

CNAME

NA

 ghs.googlehostedcom.

공백 또는 @

TXT

NA

 google-site

 verification=6tTalLzrBXBO4Gy9700TAbpg2QTKzGYEuZ_Ls69jle8

공백 또는 @

TXT

NA

 v=spf1 include:_spf.google.com ~all

www

CNAME

NA

 ghs.googlehosted.com.









Name __

Password __

Link (Your Website)

Comment

SECRET | 비밀글로 남기기

[Concepts] 컴퓨터의 구성[Concepts] 컴퓨터의 구성

Posted at 2019. 6. 19. 12:31 | Posted in Computer Concepts




출처 : IT CookBook, 컴퓨터 사이언스






■ 컴퓨터의 구성




-. 컴퓨터란 전자회를 이용하여 입력된 데이터를 자동으로 처리한 후 결과를 즉시 출력하거나 이후에 사용할 수 있도록 저장하여 관리하는 기계이다.

-. 컴퓨터는 종류나 크기 또는 성능에 상관없이 하드웨어와 소프트웨어로 구성된다.

-. 하드웨어는 컴퓨터를 구성하는 기계적 장치를 말하고, 소프트웨어는 하드웨어의 동작을 지시하는 명령어 집합인 프로그램을 말한다.







#01. 하드웨어


-. 하드웨어는 모니터, 하드디스크, 프린터 같은 컴퓨터와 관련된 모든 물리적 장치로 입력 기능, 출력기능, 기억 기능, 처리(연산)기능, 저장 기능을 담당한다.

-. 이에 따라 하드웨어는 입력장치, 출력장치, 중앙처리장치, 기억장치로 구분할 수 있다.




① 입력장치


 · 입력장치는 외부로부터 문자, 소리, 그림 영상 등의 데이터를 전달받는 장치이다.

 · 키보드, 마우스, 스캐너등이 대표적이다.



② 출력장치


 · 출력장치는 수행된 결과를 문서나 그림 형태로 사용자에게 전달하는 장치이다.

 · 모니터와 프린터가 대표적이다.



③ 중앙처리장치


 · 중앙처리장치(CPU, Contral Processing Unit)은 프로세서(Processor)라고도 불리는데,

  입력된 데이터를 연산하여 결과를 얻기 위한 장치로 컴퓨터에서 가장 핵심적인 역할을 한다.

 · 중앙처리장치의 내부는 제어장치(Control Unit)와 연산장치(ALU, Arithmetic Logic Unit)로 구성된다.

 · 제어장치는 중앙처리장치와 기억장치 사이에서 프로그램 명령과 데이터 입출력을 제어하고 연산장치는 산술연산과 논리연산을 수행한다.

 · 산술연산 : 수치데이터를 대상으로 하는 덧셈, 뺄셈, 곱셈, 나눗셈을 말한다.

 · 논리연산 : 2진 데이터 0과 1을 대상으로 하는 논리합(OR), 논리곱(AND), 부정(NOT), 배타적 논리합(XOR) 등을 말한다.



④ 기억장치


 · 기억장치는 입출력 데이터와 연산 처리 결과를 저장하는 장치로 주기억장치(Main Memory)와 보조기억장치(Secondary Memory)로 나눌 수 있다.

 · 주기억 장치에는 RAM(Random Access Memory)와 ROM(Read Only Memory)이 있다.

 · 보조기억장치에는 하드디스크, CD-ROM, DVD 플래시 메모리(Flash Memory)등이 있다.











※ 컴퓨터의 5대 장치


위의 설명에서 입력장치, 출력장치, 기억장치, 연산장치, 제어장치를 5개를 말한다.









#02. 소프트웨어


-. 소프트웨어는 하드웨어를 구성하는 각 장치에의 동작을 제어하는 명령어의 집합으로 프로그램이라고도 부른다.

-. 컴퓨터 사용자는 소프트웨어를 통해 하드웨어를 제어하기 때문에 소프트웨어가 없으면 컴퓨터를 사용하기 힘들다.

   물론 하드웨어적으로 컴퓨터를 제어하도록 설계할 수 도 있짐만 그럴 경우 하드웨어가 복잡해지고 개발 비용도 많이든다.

   이에 비해 소프트웨어는 컴퓨터를 매우 정교하게 제어할 수 있고 융통성까지 뛰어나기 때문에 하드웨어로 컴퓨터를 제어한느 것보다 훨씬 편리하다.

-. 소프트웨어는 시스템 소프트웨어와 응용 소프트웨어로 나뉜다.




① 시스템 소프트웨어(System Software)


 · 시스템 소프트웨어는 운영체제, 컴파일러(Compiler), 어셈블러(Assember), 각종 유틸리티(Utility) 등과 같이 컴퓨터 시스템을 운영한느 데 필요한 프로그램을 말한다.

 · 사용자가 하드웨어를 쉽고 편리하게 사용 할 수 있도록 돕는 역할을 한다.



② 응용 소프트웨어(application Software)


 응용 소프트웨어는 문서 작성, 그림 편집, 동영상 제작, 인터넷 검색 같은 특정 업무를 할 때 사용하는 프로그램을 말한다.




※ 시스템 소프트웨어와 응용소프트웨어의 비교

구분

시스템 소프트웨어

응용 소프트웨어

개념

 · 컴퓨터 시스템을 쉽고 편리하게 사용할 수 있도록

  도와주는 소프트웨어

 · 사용자가 특정 업무를 수행하기 위해 사용하는 소프트웨어

종류

 · 운영체제, 컴파일러, 어셈블러, 유틸리티, 장치 드라이버 등

 · 워드프로세서, 스프레드시트, 웹 브라우저, 회계 처리 프로그램

 · 윈도우, 유닉스, 리눅스 등

 · MS Office, 아래한글, 포토샵, Visual C++ 등









Name __

Password __

Link (Your Website)

Comment

SECRET | 비밀글로 남기기