1. K8SM (Kubernetes Mesos)? K8SM는 Apache Mesos에서 Google의 Kubernetes를 사용 할 수 있도록 개발 된 Mesos Framework 입니다. 초기 K8SM은 Mesosphere 팀에서 Kubernetes v0.14를 기준으로 개발 되었다가, Kubernetes v1.0 버전이 릴리즈 되면서, Kubernetes로 통합이 된 것으로 알고 있습니다. K8SM을 구성하려면 Apache Mesos와 Google Kubernetes에 대한 이해가 있어야 합니다. – Apache Mesos https://www.yongbok.net/blog/apache-mesos-cluster-resource-management/ – Google Kubernetes https://www.yongbok.net/blog/google-kubernetes-container-cluster-manager/ 2. K8SM – Architecture K8SM에 대해 제 나름 대로 그려 봤습니다. (원본은 https://github.com/GoogleCloudPlatform/kubernetes/blob/master/contrib/mesos/docs/architecture.md 에서 확인 가능 합니다.) 원리는 아래와 같습니다. 1. 사용자가 Dockerfile 또는 YAML 파일을 작성하여 적절한 곳에 저장 및 업로드 합니다. 2. 사용자가 kubectl 명령어를 통해 Pods를 구성 하도록 요청
Update: 2015-12-06 Kubernetes? 결론부터 말하자면, Kubernetes는 구글이 자사의 Backend 부분의 Container들을 쉽게 관리하기 위해 고안 된 프로젝트라고 보시면 됩니다. 사실, 구글은 Borg라는 프로젝트를 만들어 Container를 다년간 관리 해왔는데, 이것(Borg)의 경험을 녹여 Kubernetes라는 오픈소스를 2013년에 오픈하게 된 것입니다. 관련 논문은 여기를 참고 하시면 됩니다. 오픈소스로 발표하고 나서, 마이크로소프트(MS), 레드햇, IBM, Docker, CoreOS, Meso Sphere, Salt Stack등등의 회사들이 개발에 참여하여 급속도로 빠르게 성장 하는중 입니다. Kubernetes의 주요 기능은 여러 호스트에서 Container의 응용프로그램 배포와 유지 보수, 확장을 지원 해줍니다. 또한, 현재 포스팅 내용은 Kubernetes v1.1 버전에서 테스트 및 작성 되었습니다. Architecture Kubernetes는 크게 Master 서버와 Minion 서버로 이루어져 있습니다. 1. Master – etcd CoreOS에서 만든 Key/Value
본 글은 Open vSwitch로 여러 호스트에 존재하는 Docker Container들을 연결 할 수 있는 방법에 대해서 작성 하였으며, 테스트 환경은 Ubuntu 14.04 LTS, Docker v1.5, Open vSwitch 2.0.2 버전에서 진행 되었으며, 기타 자세한 설정에 대해서는 생략 하였습니다. 그리고, 공통된 부분에는 root@ruo91:~# 이라는 것으로 표기 될것이며, 개별 설정인 경우에는 다르게 표기 될것 이므로 이점 유의 하시길 바랍니다. Open vSwitch는 무엇인가? 네트워크 표준 관리 인터페이스 및 프로토콜(NetFlow, sFlow, IPFIX, RSPAN, CLI, LACP, 802.1ag)를 지원하면서, 프로그램의 확장을 통해 대규모의 네트워크 자동화를 가능하게 해주는 소프트웨어 입니다. 간단하게 말하자면, 하드웨어가 할일을 소프트웨어를 통해 제어 할 수 있다는 것입니다. Architecture diagram 쉽게 설명 드리고자 간단하게 만들어
nGrinder란? nGrinder는 네이버에서 성능 측정 목적으로 개발 된 오픈소스 프로젝트이며, 2011년에 공개 하였습니다. (The Grinder라는 오픈소스 기반에서 개발 되었습니다.) 성능 측정이란 것은 실제 서비스에 투입 되기 앞서, 실제와 같은 환경을 만들어 놓고, 서버가 사용자를 얼마 만큼 받아 줄 수 있느냐를 실험 할때 사용합니다. 예를들어.. 엔지니어가 동시접속자 100명 정도 쯤 무리 없겠지? 라고 예상하고 그에 맞는 서버를 준비하고 설정 했는데.. 예상치 못한 x1000 명이 더 와버리면.. 서버는 죽고 엔지니어는 야근 하겠죠..? 이런것을 미리 예측 하기 위한 도구라고 이해 하시면 됩니다. ^^; 또한, 엔터프라이즈 환경에서의 상용 성능 측정 도구를 사용 해보질 않아서 잘 모르지만, 대충 들어보니 가격이 억대라고 합니다. 그래서, 네이버가 가격 때문에도
Saltstack은 수백, 수천대의 노드에 특정 명령 및 쿼리를 명령어 한번으로 실행할수 있도록 도와주는 자동화 관리 도구 입니다. SaltStack Architecture SaltStack은 Master, Minion으로 이뤄져 있습니다. – Master Salt 명령어 실행과 상태등을 관리하는 중앙서버 입니다. – Minion Master에 대한 연결을 유지 및 명령을 기다리는 Agent라고 이해 하시면 됩니다. – Halite Saltstack을 쉽게 관리 할수 있는 WEB UI 입니다. Figure 1. Saltstack Architecture Master와 Minion은 ZeroMQ를 통해 AES 암호화 알고리즘으로 통신을 하며, 관리자가 CUI로 salt 명령어를 통해 직접 명령을 내릴수도 있지만, Hailte를 가지고 Web UI에서 간단하게 Minion들을 제어 할수도 있습니다. SaltStack 설치 본 설치는 Ubuntu 14.04 (Trusty) LTS에서 테스트 되었으며,