일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- DDD
- 기술공부
- 스프링공부
- 자바공부
- 카프카
- JPA예제
- Kafka
- JPA스터디
- nestjs공부
- 자료구조공부
- JPA공부
- 스프링부트
- nestjs
- K8S
- 스프링부트공부
- 기술면접공부
- JPA 공부
- 스프링 공부
- nestjs스터디
- 스프링
- 플러터 개발
- 코테준비
- Axon framework
- 알고리즘공부
- 프로그래머스
- querydsl
- 플러터 공부
- Flutter
- JPA
- 코테공부
- Today
- Total
목록Infra (68)
DevBoi
1)apply - 원하는 상태를 적용한다. 보통 -f 옵션으로 파일과 함께 사용한다. ex. kubectl apply -f [파일 명 or URL] kubectl apply -f https://subicura.com/k8s/code/guide/index/wordpress-k8s.yml 이렇게 하면 원격 url에서 배포하는 yml 파일을 댕겨와서 적용 시켜준다. 뭔가 pods,deployment,service 들이 생성된 것을 볼 수 있다. 2)get - 리소스 목록을 보여준다. 이제 생성된 것을 봐야겠지? kubectl get pod kubectl get pods kubectl get po kubectl get pod,service kubectl get po,svc kubectl get all 위의 명령..
1. Docker desktop 설치 -> 쿠퍼네티스 enable 실행, window에서는 minikube사용하는데, command에 일일히 치는 ㅈㄴ 귀찮;;; 2. kubectl 설치 -> 가이드 많음, 그냥 curl로 설치 Docker desktop으로, setting에서 k8s enable하면, 요로케 로컬에서 Kubernetes Cluster를 띄워버리고, kubectl을 로컬 터미널에서 치면 정상적으로 확인이 가능하다. kubectl version --output yaml kubectl config get-contexts kubectl get pods -- all-namespaces 우선 위 커맨드 내용이 정상적으로 출력되면 이제 데모를 위한 준비가 완료된 것이다.
pod이라는 오브젝트를 생성한다고 해보자 각각의 yaml 파일을 만들고, create를 하게 되면 이렇게 생성이된다. 나는 생성하다가 오류가 났다...ㅋ 그리고 ArgoCD라는 custom resource기준대로작성된 문서이다. 문서는 어느정도 비슷한 유형을 따른다. 각각 풀스택로 정의되면 k8s는 이런방식으로 동작을 하게 된다. 직접 실습 하면서 확인해보자. 이게 쿠버네티스의 과정을 도식화 한것이다. 이제 실습을 해보자
가장 작은 배포 단위 Pod은 내부적으로 고유한 ip를 가질 수 있다. Pod안에 보통 컨테이너가 하나만 있지만, 두개 이상이 존재할 수도 있다. 하나의 pod에 컨테이너와 캐시, 로그 등으로 묶을 수도있다. ReplicaSet - 총 몇개의 pod으로 관리를 할 지를 결정한다. 만약에 3개의 pod만있는데, 4개를 요구한다면 pod template기준으로, 1개를 추가해준다. 무중단 배포를 위해, 배포버전을 바꾸면, 리플리카가 두개가 뜨게 되고 이를 세팅을 바꾸게되면 pod의 개수를 줄이거나 늘리게 해준다. Deployment 는 즉 ReplicaSet기준으로, 배포버전이 변경되었을때 무중단 배포를 위해서 존재하는 녀석이다. 클러스터 내부에서 사용하는 프록시 Pod들이 모인, 곳에 로드밸런싱을 해준다...
grafana로 admin을 보고 helm으로 업데이트하고 kubectl로 명령어를 치고... 우선 K8S에 대한 구조를 익혀보자 우선 이런 구조이다. 어떤 서버에 용량이 여유가있어서, 새로운 컨테이너를 배포하려고하면 어떤 서버에 넣어야할까? 사람이 직접 골라서 하지않는다. Master서버에서 어떤 서버에 여유가있어서 이 컨테이너가 어떤 서버에 들어갈 수 있는지를 골라서 해준다. 1) etcd 모든 상태와 데이터를 저장하고 분산 시스템으로 구성하여 안전성을 높인다. 가볍고 빠르면서 정확하게 설계가 디고, key-value 형태로 데이터를 저장한다. TTL, watch같은 부가 기능을 제공하기도 한다. 모든 상태를 저장하기 때문에 백업은 필수이다. 대부분 두 대정도 돌아간다. 2) Scheduler 컨테이..
엔진엑스는 동시접속 처리에 특화된 웹 서버 프로그램이다. 아파치 보다 동작이 단순하고, 전달자 역할만 하기 때문에 동시접속 처리에 특화 되어있다. 웹 서버의 역할은? 1) 정적 컨텐츠 전달 웹서버의 역할은 HTML,Css,js이미지 와 같은 정보를 웹 브라우저에 전송하는 역할을 한다. 2)리버스 프록시 nginx.conf파일에서 location지시어를 사용하여 요청을 배분한다. 클라이언트는 가짜 서버에 요청하면, 프록시 서버가 배후 서버로 부터 데이터를 가져온다. 프록시 서버가 Nginx, 리버스 서버가 응용프로그램 서버를 의미한다. nginx.conf -Nginx기본동작이외, 파일 확장자의 MIME type , 가상 호스트, 리버스 프록시를 위한 설정 파일들이 포함 접속자수, 동작 프로세스 수 등 퍼포..
1. aws 인스턴스 생성 -> 8080,9090 등으로 보안그룹 생성하여, 인스턴스 생성 2. aws 접속 ->sudo ssh -i smithkey.pem ec2-user@(서버ip) 3. yum update ->sudo yum update 4. java 설치(open jdk) ->sudo yum install java-1.8.0-openjdk-devel .x86_64 -y 5. jenkins https://www.jenkins.io/ https://get.jenkins.io/war-stable/2.332.2/jenkins.war. /home/ec-user/local 하위 wget https://get.jenkins.io/war-stable/2.332.2/jenkins.war (실행) java -jar..