일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- Linux
- cloud
- gradle
- Pipeline
- tomcat
- 액세스회선
- map
- LAN어댑터
- 라우터
- Jenkins
- JPA
- 캐시서버
- ansible
- DevOps
- Java
- Collection
- post
- docker
- STREAM
- 소켓
- IntelliJ
- mybatis
- 허브
- AOP
- Set
- container
- Spring
- 방화벽
- jdk
- sonarQube
- Today
- Total
목록전체 글 (195)
거북이-https://velog.io/@violet_evgadn 이전완료
Application Infrastructure Physical Server, Virtual Server 및 Container는 배포한 파일을 Server에서 어떻게 관리하는지에 대한 방법론이었다. 그렇다면 여기서 Server를 물리적으로 어떻게 형성하여 배포된 Application을 관리하는지도 궁금해진다. Application Infrastructure는 우리가 흔히 말하는 "인프라"와 동일한 의미로써 어떤 방식으로 Server를 구성할 것인지에 대한 방법론, 즉 "Server 그 자체"를 형성하는 방법에 중점을 둔 개념들이라고 말할 수 있겠다. Data Cente ◎ Data Center란? 기업 컴퓨터, Network, Storage나 기타 IT 장비가 위치하는 중앙집중식 물리적 시설이다. 이전에..
Container Container는 응용 프로그램과 프로그램을 실행하는데 필요한 모든 것을 단일 단위로 포장함으로써 Process를 표준화하는 Deplyoment 방식을 의미한다. 기존 VM이나 Physical Server에서 Application을 배포시킬 때는 오로지 Application을 패키징하고 배포시켜야 했기 때문에 Local 컴퓨터와의 환경이 달라 동일한 동작 방식이 보장되지 않는다는 단점이 존재하였는데 Container는 프로그램 실행에 필요한 모든 것을 포함하여 포장하기 때문에 Local 컴퓨터와 동일하게 동작하는 것을 어느 정도 보장할 수 있게 된 것이다. 위 사진에서 볼 수 있듯 Conatiner는 VM과 유사한 형태를 가졌으나 Guest OS가 없다는 특징을 가지고 있다. 따라서 ..
Virtual Server ◎ Virtual Server란? Virtual Server, Virtual Machine(VM)이라고도 불리는 가상 서버를 말한다. 기존 Physcial Server에서는 Resource의 경계를 한정 지을 수 없어 Resource 할당에 대한 단점이 존재하였다. 이런 문제점을 해결하기 위해 "1대의 물리적 서버가 있더라도 마치 여러 개의 물리적 서버가 있는 것처럼 설정하면 되지 않을까?"라는 생각으로 나온 해결책이 바로 Virtual Server이다. VM에서는 1개의 Physical Server 위에 여러 개의 Virtual Layer를 두어 실제로는 1개의 HW만 존재하지만 마치 Virtual Layer 개수만큼의 컴퓨터가 존재하는 것처럼 활용할 수 있게 하는 방식이다...
Deployment Deployment란 Build 된 파일을 WAS 등의 Application을 제공할 Server에 올려 사용자들이 실제로 이용할 수 있도록 하는 것이다. 여기서 Build란 Application의 소스코드를 실제로 활용할 수 있는 실행 파일로 변환하는 과정을 말한다. Packaging Build 과정이 Application의 소스코드를 실제로 활용할 수 있는 실행 파일로 변환하는 과정을 말한다고 위에서 언급했다. 그리고 이 Build 과정에서 Build Tool이라는 것이 활용되는데 이 Build Tool이 하는 역할 중 하나가 패키징이다. Build 과정은 아래와 같은 단계로 이뤄진다. 먼저 설정했던 Dependency들을 다운로드한다. 이후 Source Code를 Binary C..
Microservice Architecture ◎ Microservice Architecture(MSA)란? MSA란 작은 애플리케이션들을 합쳐 큰 애플리케이션을 만드는 Application Architecture를 말한다. MSA는 대형 프로젝트가 힘들다는 Monolithic Architecture 문제점을 해결하기 위해 나온 Architecture로써 SOA(서비스 지향 아키텍처)에서 발전된 형태를 가진다. MSA의 가장 기본적인 철학은 "한 가지만 잘 처리하자"이다. MSA에서는 단일 책임 원칙(SRP)을 중시하여 큰 문제를 최대한 독립성 있는 작은 문제로 분해한다. 이렇게 분해된 문제들을 Component를 통해 해결하고, 개발된 Component 간 REST API를 통해 데이터를 주고받음으로써..
3-tier Architecture, 4-tier Architecture 구조 N-tier Architecture를 이해하기 전 3-tier, 4-tier Architecture에 대해 이해할 필요성이 있다. 3-tier, 4-tier 뿐만이 아닌 2-tier Architecture도 존재하긴 하지만, 2-tier Architecture는 Monolithic Architecture와 차이점이 거의 없기 때문에 이번 Section에서는 3-tier, 4-tier Architecture만 관찰해보자 ◎ Presentation Layer(프리젠테이션 레이어; 표현 계층) 사용자와 직접 상호작용하는 UI(User Interface)를 의미한다. MVC Pattern와 비교해 봤을 떄 View Layer에 해당하..
Application Architeture란? 개발 방법론에 대한 공부가 끝났고 이제는 Application Architecture에 대해 설명할 차례이다. Application Architecture에는 대표적으로 Monolithic, N-Tier Architecture, 그리고 Microservice Architecture(MSA)가 존재한다. 그렇다면 Application Architecture란 무엇인가? Application Architecture란 애플리케이션을 설계하고 구축할 때 활용할 수 있는 패턴이나 기술들을 의미한다. 즉, "어떤 방식으로" Application을 만들 것인가에 정하는 설계도라고 보면 될 것이다. Application Architecture는 개발하는 Software에서..
DevOps ◎ DevOps란? 회사에선 프로젝트를 가지고 온다. 개발자는 코드를 짠다. 그리고 애플리케이션이 생성되어 고객에게 전달된다. ...라는 간단한 흐름으로 개발이 진행되지는 않는다. 개발자는 개발만 진행하는 것이 아닌 외적인 일에도 많은 시간을 할당한다. 기능들에 대해 테스트도 진행해봐야 하고 고객에게 전달할 수 있도록 프로젝트를 Build도 해야 하며 운영 서버에서도 제대로 애플리케이션이 작동하는지 검수해야 하며 이를 위해 Build 한 프로젝트를 서버에 배포도 해야 한다. 운영 서버에서 애플리케이션이 수행될 수 있도록 DB를 세팅하고 Server에 대한 설정도 수행해야 하며 HW에 대한 관리도 필요할 것이다. 또한 운영 과정에서 생기는 문제점이나 생길 수 있는 문제점을 확인하기 위해 모니터..
DevOps를 공부하기 앞서서... DevOps를 공부하기 전 Waterfall과 Agile 방식을 비교하는 시간을 가져보자. DevOps도 SW 개발 방법론 중 하나지만, DevOps는 Agile 방식에서 운영과 개발 과정을 합친 개발 방법론으로써 진화된 Agile 방식이라고 봐도 무관하다. 즉, 현재 자주 활용하는 개발 방법론은 Waterfall과 Agile, 두 방법이라고 이해해도 무방하다. 현재에도 Waterfall Model을 활용하는 기업이 많은 만큼 둘 사이에 차이에 대해 알아보고 어떤 상황에서 무슨 개발 방법론을 활용하는 것이 좋은지 확인하고 가는 것이 좋을 것이다 Waterfall Model과 Agile Model 비교 ◎ 요구사항 Waterfall Model은 Requirements 단..
Agile 방법론 ◎ Agile 방법론이란? 이전 Section에서 우리는 Waterfall 방법론에 대해 배웠다. 그렇다면 Waterfall Model의 가장 큰 단점이 무엇일까? 바로 이전 단계로 돌아갈 수 없다는 Waterfall 모델의 특성상 고객의 요구사항이나 돌발 상황에 대처하기 어렵다는 것이다. Agile 방법론은 Waterfall Model의 단점을 해결하기 위해 나온 개발 방법론으로써 "문서화" 중심의 개발을 버리고 "고객과의 소통"을 중심으로 하는 개발 방식이다. 궁극적으로 Agile은 고객과의 소통을 통해 "고객의 변화에 대응하는 것"을 가장 큰 목표로 두고 있는 개발 방법론인 것이다. 고객과 소통을 하면서 개발을 진행한다면 고객은 SW를 실시간으로 확인 가능하기 때문에 프로젝트의 진..