Logging 설치 가이드

Table of Contents

1. 문서 개요

2. Logging 서비스 설치

3. Logging 서비스 관리

1. 문서 개요

1.1. 목적

본 문서는 Logging 서비스 Release를 Bosh2.0을 이용하여 설치 하는 방법을 기술하였다.

1.2. 범위

설치 범위는 Logging 서비스 Release를 검증하기 위한 기본 설치를 기준으로 작성하였다.

1.3. 시스템 구성

본 장에서는 Logging 서비스의 시스템 구성에 대해 기술하였다. Logging 서비스 시스템은 Router, Collector, Queue, Parser, Elasticsearch, Visualization의 최소사항을 구성하였다.

VM명

인스턴스 수

vCPU수

메모리(GB)

디스크(GB)

Router

1

1

1

Root 8G

Collector

1

1

2

Root 10G

Queue

1

1

2

Root 10G + Persistent disk 10G

Parser

N

1

2

Root 10G

Elasticsearch Master

1

1

2

Root 10G + Persistent disk 10G

Elasticsearch Data

N

2

4

Root 20G + Persistent disk 30G

Visualization

1

1

2

Root 10G

maintenance

1

1

1

Root 8G

1.4. 참고자료

http://bosh.io/docs http://docs.cloudfoundry.org/

2. Logging 서비스 설치

2.1. 설치 전 준비 사항

본 설치 가이드는 Linux 환경에서 설치하는 것을 기준으로 하였다. Logging 서비스 설치를 위해서는 BOSH 2.0과 PaaS-TA 5.0, PaaS-TA 포털이 설치되어 있어야 한다.

※ 설치 전 확인 사항

uaac client에 "firehose-to-syslog"가 등록되어 있는지 확인 하여, 등록되어 있는 경우에는 "authorities"를 확인하여 "cloud_controller.admin" 권한을 부여한다.

# endpoint 설정
$ uaac target https://uaa.<DOMAIN> --skip-ssl-validation
# target 확인
$ uaac target
Target: https://uaa.<DOMAIN>
Context: uaa_admin, from client uaa_admin
# uaac 로그인
$ uaac token client get <UAA_ADMIN_CLIENT_ID> -s <UAA_ADMIN_CLIENT_SECRET>
# "firehose-to-syslog" uaac client 확인
$ uaac client get firehose-to-syslog
scope: cloud_controller.admin_read_only cloud_controller.global_auditor openid routing.router_groups.write network.write scim.read cloud_controller.admin uaa.user cloud_controller.read
password.write routing.router_groups.read cloud_controller.write network.admin doppler.firehose scim.write
client_id: firehose-to-syslog
resource_ids: none
authorized_grant_types: client_credentials
autoapprove:
authorities: uaa.none doppler.firehose >>>>>>>> cloud_controller.admin 권한 여부 확인
lastmodified: 1552530293656
# "firehose-to-syslog" uaac client 변경
$ uaac client update firehose-to-syslog --authorities "doppler.firehose, uaa.none, cloud_controller.admin"
# "firehose-to-syslog" uaac client 확인
$ uaac client get firehose-to-syslog
scope: cloud_controller.admin_read_only cloud_controller.global_auditor openid routing.router_groups.write network.write scim.read cloud_controller.admin uaa.user cloud_controller.read
password.write routing.router_groups.read cloud_controller.write network.admin doppler.firehose scim.write
client_id: firehose-to-syslog
resource_ids: none
authorized_grant_types: client_credentials
autoapprove:
authorities: uaa.none doppler.firehose cloud_controller.admin
lastmodified: 1552530293656

2.1.1 Logging 서비스 설치 파일 다운로드

Logging 서비스 설치에 필요한 Deployment 및 릴리즈 파일을 다운로드 받아 서비스 설치 작업 경로로 위치시킨다.

  • 설치 파일 다운로드 위치 : https://paas-ta.kr/download/package = Deployment : paasta-logging-service = 릴리즈 파일 : paasta-logging-service-release.tgz

  • 설치 작업 경로 생성 및 파일 다운로드

# Deployment 다운로드 파일 위치 경로 생성
$ mkdir -p ~/workspace/paasta-5.0/deployment/service-deployment
# Deployment 다운로드(paasta-logging-service) 및 파일 경로 확인
$ ls ~/workspace/paasta-5.0/deployment/service-deployment/paasta-logging-service
logging-service-deploy.sh manifests
# 릴리즈 다운로드 파일 위치 경로 생성
$ mkdir -p ~/workspace/paasta-5.0/release/service
# 릴리즈 파일 다운로드(paasta-logging-service-release.tgz) 및 파일 경로 확인
$ ls ~/workspace/paasta-5.0/release/service
paasta-logging-service-release.tgz

2.1.2 Stemcell 다운로드

Logging 서비스 설치에 필요한 Stemcell을 확인하여 존재하지 않을 경우 BOSH 설치 가이드 문서를 참고 하여 Stemcell을 업로드 한다.

  • 설치 파일 다운로드 위치 : https://paas-ta.kr/download/package

    ```

    Stemcell 목록 확인

    $ bosh -e micro-bosh stemcells

    Using environment '10.30.40.111' as client 'admin'

Name Version OS CPI CID bosh-openstack-kvm-ubuntu-xenial-go_agent 315.64* ubuntu-xenial - a2d704b0-2768-4e55-84a6-4f3b1311e6f9

(*) Currently deployed

1 stemcells

Succeeded

### <div id="2.2"/> 2.2. Logging 서비스 릴리즈 업로드
- 릴리즈 목록을 확인하여 Logging 서비스 릴리즈(paasta-logging-service-release)가 업로드 되어 있지 않은 것을 확인한다.

릴리즈 목록 확인

$ bosh -e micro-bosh releases Using environment '10.30.40.111' as client 'admin'

Name Version Commit Hash binary-buildpack 1.0.32 2399a07 ... ((생략)) ... paasta-container-service-projects-release 1.0 ced4610+ php-buildpack 4.3.77 ca96e60 postgres 38 b4926da pxc 0.18.0 acdf39f python-buildpack 1.6.34 e7b7e15 r-buildpack 1.0.10 a9a0a9f routing 0.188.0 db449e4 ruby-buildpack 1.7.40 fa9e7c5 silk 2.23.0 cdb44d5 staticfile-buildpack 1.4.43 aeef141 statsd-injector 1.10.0 b81ab23 uaa 72.0* 804589c

(*) Currently deployed (+) Uncommitted changes

39 releases

Succeeded

- Logging 서비스 릴리즈 파일을 업로드한다.

릴리즈 파일 업로드

$ bosh -e micro-bosh upload-release ~/workspace/paasta-5.0/release/service/paasta-logging-service-release.tgz Using environment '10.30.40.111' as client 'admin'

################################################### 100.00% 91.26 MiB/s 4s

Task 249

Task 249 | 05:16:30 | Extracting release: Extracting release (00:00:02) Task 249 | 05:16:32 | Verifying manifest: Verifying manifest (00:00:00) Task 249 | 05:16:32 | Resolving package dependencies: Resolving package dependencies (00:00:00) Task 249 | 05:16:32 | Creating new packages: cerebro/dd5b9a85982129a7e24fd8679c9a09fdac0857d0a749a4ff20ba3be6a6f585e8 (00:00:01) Task 249 | 05:16:33 | Creating new packages: curator/abf8864d97cc79aba00c6a4c6e51e2b10da2f36219ce358b65840e113e9cd652 (00:00:00) Task 249 | 05:16:33 | Creating new packages: elasticsearch/f3d584d6e084af4d8427795d0df96027cc6da3c4147c62714adcfd08abb33bc3 (00:00:01) Task 249 | 05:16:34 | Creating new packages: firehose-to-syslog/691fe09a5f9f130103b47b7c7a286ca0e53d8264198c7711dc431383ebe6afd7 (00:00:00) Task 249 | 05:16:34 | Creating new packages: golang/f45d2a9623fdac6b1a4a63625ce4a5c435342a5a95920335dd8ce4277be92dc5 (00:00:02) Task 249 | 05:16:36 | Creating new packages: haproxy/b9189484ff6f4d87259e299f9771998abe4d0ffd0a7dd21d941c6c7cc7d8b58a (00:00:00) Task 249 | 05:16:36 | Creating new packages: java8/5074349fa4922efb30893f466c10f7c1e6fcdd8eb66e89f9a8395110dad0ccc1 (00:00:00) Task 249 | 05:16:36 | Creating new packages: kibana/b57105c1860939340eb46391170d1ed59e3af3b6d9aea3e5592c4ead5b9a296d (00:00:01) Task 249 | 05:16:37 | Creating new packages: logsearch-config/aaf9f56bc5044625e7fa3fd790ee8f6ff1ca90cba17561ac0b1f4f7e3488cc1b (00:00:00) Task 249 | 05:16:37 | Creating new packages: logstash/4a3979c58c3a67a79b731de1cf7e4fb27dbcdb27c149d4af3c4d51be11c3aeee (00:00:02) Task 249 | 05:16:39 | Creating new packages: nats_to_syslog/87900e9a2c72f55d7ab346d7819184e21338f2d9b5ff285bcdfb8210b303bbe1 (00:00:00) Task 249 | 05:16:39 | Creating new packages: python3/0543e5945b39f81cfa9f70d70b94fe253321676d029ded40a093addfecbdf18a (00:00:01) Task 249 | 05:16:40 | Creating new packages: redis/a8d2d5161542bd05fcfaffd14f26b221549d75c3ac0f795d3941dd530b27c0a2 (00:00:00) Task 249 | 05:16:40 | Creating new packages: ruby2.3/829cbedc82964dd880f3323d5386680ce0eba6bbd8ab9b84eca2d1902f6d2d7d (00:00:00) Task 249 | 05:16:40 | Creating new jobs: archiver/30264a742c6c457f93804f6466ff1aa0a9b57a0d2b61098e22551ed3e4f22a64 (00:00:00) Task 249 | 05:16:40 | Creating new jobs: cerebro/fd675cbb04d1ada7f530187ea53ec1bd2fa45a542ef983a78164ad58d8263913 (00:00:00) Task 249 | 05:16:40 | Creating new jobs: curator/f551e893b31b1841e7636c95727415d85cf80931179f954231c27fd74abe96f0 (00:00:00) Task 249 | 05:16:40 | Creating new jobs: elasticsearch/cd7b7dfe4d9157e9807c7f5332e880e1d056c18214ea6817db8ca0338eb470bd (00:00:00) Task 249 | 05:16:40 | Creating new jobs: elasticsearch_config/7a9fa8a6bffa7d537918612b814011824200a6b115b2eea84bcadd1cf56ca595 (00:00:01) Task 249 | 05:16:41 | Creating new jobs: enable_shard_allocation/23e6639e8309d510341cadb91829a2ed98d5ccbfc55ef6084fc5d59acb2617e7 (00:00:00) Task 249 | 05:16:41 | Creating new jobs: haproxy/811e63ee59ac888d6da188cc2710ff1e18486310ac9e7f1fef6aef08fc4d3804 (00:00:00) Task 249 | 05:16:41 | Creating new jobs: ingestor_archiver/345644551d21ae3bf8ef86ea33d3ebbf233cad43ee368254dc566295cb2cddcf (00:00:00) Task 249 | 05:16:41 | Creating new jobs: ingestor_cloudfoundry-firehose/eede8116a5acdbf19001401f67af15ed81291ebd5f7896857e85b1492387ce1b (00:00:00) Task 249 | 05:16:41 | Creating new jobs: ingestor_syslog/fc73b8814f4a954be796139a1dc894e0446b0fa1f173e7ab000b886cc3566b49 (00:00:00) Task 249 | 05:16:41 | Creating new jobs: kibana/b45b9667621a32d5d617981dd60b6cb2450b7fca4c3ce5eb214c17ec510b3be8 (00:00:00) Task 249 | 05:16:41 | Creating new jobs: nats_to_syslog/dc68081f021ab82eab2a40a398e1a2f6577f096fd27e451ddeb166a70b391a10 (00:00:00) Task 249 | 05:16:41 | Creating new jobs: parser/3deeea0dc25e6ad0d3f479f69ec8c5b33fe10f720ad54436eb2fd5f98dfda396 (00:00:00) Task 249 | 05:16:41 | Creating new jobs: queue/f201ef1fc4c2a2bd6e463df30c549a276947b47589a48a281ef6ead1c744d494 (00:00:00) Task 249 | 05:16:41 | Creating new jobs: smoke_tests/646ea14c38a12da55a5002b8655645673545afd20f592c7d54032dab2e961e67 (00:00:00) Task 249 | 05:16:41 | Release has been created: paasta-logging-service-release/1.0 (00:00:00)

Task 249 Started Thu Nov 21 05:16:30 UTC 2019 Task 249 Finished Thu Nov 21 05:16:41 UTC 2019 Task 249 Duration 00:00:11 Task 249 done

Succeeded

- 릴리즈 목록을 확인하여 Logging 서비스 릴리즈(paasta-logging-service-release)가 업로드 되어 있는 것을 확인한다.

릴리즈 목록 확인

$ bosh -e micro-bosh releases Using environment '10.30.40.111' as client 'admin'

Name Version Commit Hash binary-buildpack 1.0.32 2399a07 ... ((생략)) ... paasta-logging-service-release 1.0 4e24281+ php-buildpack 4.3.77 ca96e60 postgres 38 b4926da pxc 0.18.0 acdf39f python-buildpack 1.6.34 e7b7e15 r-buildpack 1.0.10 a9a0a9f routing 0.188.0 db449e4 ruby-buildpack 1.7.40 fa9e7c5 silk 2.23.0 cdb44d5 staticfile-buildpack 1.4.43 aeef141 statsd-injector 1.10.0 b81ab23 uaa 72.0 804589c

(*) Currently deployed (+) Uncommitted changes

40 releases

Succeeded

### <div id="2.3"/> 2.3. Logging 서비스 Deployment 파일 수정 및 배포
BOSH Deployment manifest는 Components 요소 및 배포의 속성을 정의한 YAML 파일이다.
Deployment 파일에서 사용하는 network, vm_type, disk_type 등은 Cloud config를 활용하고, 활용 방법은 BOSH 2.0 가이드를 참고한다.
- Cloud config 설정 내용을 확인한다.

Cloud config 조회

$ bosh -e micro-bosh cloud-config Using environment '10.30.40.111' as client 'admin'

azs:

  • cloud_properties:

    datacenters:

    • clusters:

      • BD-HA:

        resource_pool: CF_BOSH2_Pool

        name: BD-HA

        name: z1

        ... ((생략)) ...

        compilation:

        az: z1

        network: default

        reuse_compilation_vms: true

        vm_type: large

        workers: 5

        disk_types:

  • disk_size: 1024

    name: default

  • disk_size: 1024

    name: 1GB

    ... ((생략)) ...

    networks:

  • name: default

    subnets:

    • azs:

      • z1

      • z2

      • z3

      • z4

      • z5

      • z6

        cloud_properties:

        name: Internal

        dns:

      • 8.8.8.8

        gateway: 10.30.20.23

        range: 10.30.0.0/16

        reserved:

      • 10.30.0.0 - 10.30.111.40

        ... ((생략)) ...

        vm_types:

  • cloud_properties:

    cpu: 1

    disk: 8192

    ram: 1024

    name: minimal

    ... ((생략)) ...

Succeeded

- Deployment YAML에서 사용하는 변수들을 서버 환경에 맞게 수정한다.

변수 설정

$ vi ~/workspace/paasta-5.0/deployment/service-deployment/paasta-logging-service/manifests/vars.yml

RELEASE

logging_service_release_name: "paasta-logging-service-release" logging_service_release_version: "1.0"

STEMCELL

stemcell_os: "ubuntu-xenial" stemcell_version: "latest"

VM_TYPE

vm_type_minimal: "minimal" vm_type_default: "default" vm_type_medium: "medium"

NETWORK

private_network_name: "service_private" public_network_name: "service_public" private_nat_network_name: "default" # AWS의 경우 nat network

ELASTICSEARCH_MASTER

es_master_azs: [z5] es_master_instances: 1 es_master_persistent_disk_type: "10GB" es_master_private_ips: ["10.30.107.135"] es_master_private_url: "10.30.107.135"

QUEUE

queue_azs: [z5] queue_instances: 1 queue_persistent_disk_type: "10GB" queue_private_ips: ["10.30.107.139"] queue_private_url: "10.30.107.139"

MAINTENANCE

maintenance_azs: [z5] maintenance_instances: 1 maintenance_private_ips: ["10.30.107.136"]

ELASTICSEARCH_DATA

es_data_azs: [z5] es_data_instances: 2 es_data_persistent_disk_type: "20GB" es_data_private_ips: ["10.30.107.133", "10.30.107.134"]

VISUALIZATION

visualization_azs: [z5] visualization_instances: 1 visualization_private_ips: ["10.30.107.143"] visualization_version: "5.3.0"

COLLECTOR

collector_azs: [z5] collector_instances: 1 collector_private_ips: ["10.30.107.131"]

PARSER

parser_azs: [z5] parser_instances: 2 parser_private_ips: ["10.30.107.137", "10.30.107.138"] parser_es_index: "%{[@metadata][index]}-%{+YYYY.MM.dd.HH}" parser_es_index_type: '%{[@metadata][type]}'

ROUTER

router_azs: [z5] router_instances: 1 router_private_ips: ["10.30.107.140"] router_public_ips: "115.68.47.181" router_private_url: "10.30.107.140"

CF

cf_client_id : "laasclient" cf_client_secret : "clientsecret” system_domain: ""

LOGGING SERVICE

es_config_index_prefix: "laas-" retention_period: 7 laas_logo: ""

- Deploy 스크립트 파일을 서버 환경에 맞게 수정한다.
= vSphere : -o manifests/ops-files/vsphere-network.yml
= AWS : -o manifests/ops-files/aws-network.yml
= OpenStack : -o manifests/ops-files/openstack-network.yml
= Azure : -o manifests/ops-files/azure-network.yml
= GCP : -o manifests/ops-files/gcp-network.yml

Deploy 스크립트 수정

$ vi ~/workspace/paasta-5.0/deployment/service-deployment/paasta-logging-service/logging-service-deploy.sh

!/bin/bash

SET VARIABLES

export LOGGING_SERVICE_DEPLOYMENT_NAME='paasta-logging-service' export BOSH2_NAME='micro-bosh'

bosh -e ${BOSH2_NAME} -d ${LOGGING_SERVICE_DEPLOYMENT_NAME} deploy --no-redact manifests/paasta_logging_service.yml -l manifests/vars.yml -o manifests/ops-files/vsphere-network.yml -v uaa_admin_client_id= -v uaa_admin_client_secret=

- Logging 서비스를 배포한다.

Logging 서비스 Deploy (e.g. vSphere)

$ cd ~/workspace/paasta-5.0/deployment/service-deployment/paasta-logging-service $ sh logging-service-deploy.sh Using environment '10.30.40.111' as client 'admin'

Using deployment 'paasta-logging-service'

  • azs:

    • cloud_properties:

  • datacenters:

    • clusters:

    • BD-HA:

  • resource_pool: CF_BOSH2_Pool

  • name: BD-HA

  • name: z1

    • cloud_properties:

  • datacenters:

    • clusters:

    • BD-HA:

  • resource_pool: CF_BOSH2_Pool

  • name: BD-HA

  • name: z2

... ((생략)) ...

  • compilation:

  • az: z1

  • network: default

  • reuse_compilation_vms: true

  • vm_type: large

  • workers: 5

  • networks:

    • name: default

  • subnets:

    • azs:

    • z1

    • z2

    • z3

    • z4

    • z5

    • z6

  • cloud_properties:

  • name: Internal

  • dns:

    • 8.8.8.8

  • gateway: 10.30.20.23

  • range: 10.30.0.0/16

  • reserved:

    • 10.30.0.0 - 10.30.111.40

... ((생략)) ...

  • disk_types:

    • disk_size: 1024

  • name: default

    • disk_size: 1024

  • name: 1GB

    • disk_size: 2048

  • name: 2GB

    • disk_size: 4096

  • name: 4GB

    • disk_size: 5120

  • name: 5GB

    • disk_size: 8192

  • name: 8GB

    • disk_size: 10240

  • name: 10GB

    • disk_size: 20480

  • name: 20GB

    • disk_size: 30720

  • name: 30GB

    • disk_size: 51200

  • name: 50GB

    • disk_size: 102400

  • name: 100GB

    • disk_size: 1048576

  • name: 1TB

  • stemcells:

    • alias: default

  • os: ubuntu-xenial

  • version: '315.64'

  • releases:

    • name: paasta-logging-service-release

  • version: '1.0'

  • update:

  • canaries: 1

  • canary_watch_time: 30000-600000

  • max_in_flight: 1

  • serial: false

  • update_watch_time: 5000-600000

... ((생략)) ...

  • instance_groups:

    • azs:

    • z5

  • instances: 1

  • jobs:

    • name: elasticsearch

  • properties:

  • elasticsearch:

  • cluster_name: ""

  • exec: ""

  • master_hosts:

    • ""

  • node:

  • allow_data: ""

  • allow_master: ""

  • release: paasta-logging-service-release

    • name: cerebro

  • properties:

  • elasticsearch:

  • cluster_name: ""

  • release: paasta-logging-service-release

  • name: elasticsearch_master

  • networks:

    • name: service_private

  • static_ips:

    • 10.30.107.135

  • persistent_disk_type: 10GB

  • stemcell: default

  • update:

  • max_in_flight: 1

  • vm_type: default

    • azs:

    • z5

  • instances: 1

  • jobs:

    • name: queue

  • properties:

  • redis:

  • host: ""

  • release: paasta-logging-service-release

  • name: queue

  • networks:

    • name: service_private

  • static_ips:

    • 10.30.107.139

  • persistent_disk_type: 10GB

  • stemcell: default

  • vm_type: default

    • azs:

    • z5

  • instances: 1

  • jobs:

    • name: elasticsearch_config

  • properties:

  • elasticsearch_config:

  • elasticsearch:

  • host: ""

  • index_prefix: ""

  • templates:

    • shards-and-replicas: ""

    • index-settings: ""

    • index-mappings: ""

    • index-mappings-laas: ""

    • index-mappings-app: ""

    • index-mappings-platform: ""

  • release: paasta-logging-service-release

    • name: curator

  • properties:

  • curator:

  • elasticsearch:

  • host: ""

  • port: ""

  • purge_logs:

  • retention_period: ""

  • unit: ""

  • elasticsearch_config:

  • index_prefix: ""

  • release: paasta-logging-service-release

  • name: maintenance

  • networks:

    • name: service_private

  • static_ips:

    • 10.30.107.136

  • stemcell: default

  • update:

  • serial: true

  • vm_type: minimal

    • azs:

    • z5

  • instances: 2

  • jobs:

    • name: elasticsearch

  • properties:

  • elasticsearch:

  • cluster_name: ""

  • exec: ""

  • master_hosts:

    • ""

  • node:

  • allow_data: ""

  • allow_master: ""

  • release: paasta-logging-service-release

  • name: elasticsearch_data

  • networks:

    • name: service_private

  • static_ips:

    • 10.30.107.133

    • 10.30.107.134

  • persistent_disk_type: 20GB

  • stemcell: default

  • update:

  • max_in_flight: 1

  • serial: true

  • vm_type: medium

    • azs:

    • z5

  • instances: 1

  • jobs:

    • name: kibana

  • properties:

  • kibana:

  • elasticsearch:

  • host: ""

  • port: ""

  • version: ""

  • laas:

  • cf_api_url: ""

  • cf_client_id: ""

  • cf_client_secret: ""

  • cf_uaa_callback_url: ""

  • cf_uaa_scope: cloud_controller.read&openid

  • cf_uaa_url: ""

  • elasticsearch_index_prefix: ""

  • top_left_logo_image: ""

  • release: paasta-logging-service-release

  • name: visualization

  • networks:

    • name: service_private

  • static_ips:

    • 10.30.107.143

  • stemcell: default

  • vm_type: default

    • azs:

    • z5

  • instances: 1

  • jobs:

    • name: ingestor_syslog

  • properties:

  • logstash_ingestor:

  • debug: ""

  • relp:

  • port: ""

  • redis:

  • host: ""

  • release: paasta-logging-service-release

    • name: ingestor_cloudfoundry-firehose

  • properties:

  • cloudfoundry:

  • api_endpoint: ""

  • firehose_client_id: ""

  • firehose_client_secret: ""

  • firehose_events: ""

  • skip_ssl_validation: ""

  • create-uaa-client:

  • cloudfoundry:

  • system_domain: ""

  • uaa_admin_client_id: ""

  • uaa_admin_client_secret: ""

  • syslog:

  • host: ""

  • port: ""

  • release: paasta-logging-service-release

  • name: collector

  • networks:

    • name: service_private

  • static_ips:

    • 10.30.107.131

  • stemcell: default

  • vm_type: default

    • azs:

    • z5

  • instances: 2

  • jobs:

    • name: parser

  • properties:

  • logstash_parser:

  • debug: ""

  • elasticsearch:

  • index: ""

  • index_type: ""

  • redis:

  • host: ""

  • release: paasta-logging-service-release

    • name: elasticsearch

  • properties:

  • elasticsearch:

  • cluster_name: ""

  • exec: ""

  • master_hosts:

    • ""

  • release: paasta-logging-service-release

  • name: parser

  • networks:

    • name: service_private

  • static_ips:

    • 10.30.107.137

    • 10.30.107.138

  • stemcell: default

  • update:

  • max_in_flight: 4

  • serial: false

  • vm_type: default

    • azs:

    • z5

  • instances: 1

  • jobs:

    • name: haproxy

  • properties:

  • haproxy:

  • cluster_monitor: ""

  • ingestor:

  • backend_servers:

    • ""

  • kibana:

  • backend_servers:

    • ""

  • release: paasta-logging-service-release

  • name: router

  • networks:

    • name: service_private

  • static_ips:

    • 10.30.107.140

    • default:

    • dns

    • gateway

  • name: service_public

  • static_ips: 115.68.47.181

  • stemcell: default

  • vm_type: minimal

  • name: paasta-logging-service

Continue? [yN]: y

Task 68414

Task 68414 | 02:06:49 | Preparing deployment: Preparing deployment (00:00:02) Task 68414 | 02:06:54 | Preparing package compilation: Finding packages to compile (00:00:00) Task 68414 | 02:06:54 | Compiling packages: haproxy/1d59aa8ae61da532ade4e9f5129428bbc101be64 Task 68414 | 02:06:54 | Compiling packages: kibana/4bf52faddc3486d0f81857ddba1d5a617e52cc5b Task 68414 | 02:06:54 | Compiling packages: python3/2a00051b1a0f02d70453c75e9036d41cb960ebfc Task 68414 | 02:06:54 | Compiling packages: golang/fb3379fa5b3afb2e6e515657a33f2145ba4bd076 Task 68414 | 02:06:54 | Compiling packages: ruby2.3/613589acad7ddafc74fd12316e3d9cf5346f612e Task 68414 | 02:09:51 | Compiling packages: kibana/4bf52faddc3486d0f81857ddba1d5a617e52cc5b (00:02:57) Task 68414 | 02:09:51 | Compiling packages: redis/ff3e314387f91116dd8906cd656ecd0476b4c7b5 Task 68414 | 02:10:00 | Compiling packages: golang/fb3379fa5b3afb2e6e515657a33f2145ba4bd076 (00:03:06) Task 68414 | 02:10:00 | Compiling packages: cerebro/278996853981243e3b921d18e255d55d998dcc7f Task 68414 | 02:10:11 | Compiling packages: haproxy/1d59aa8ae61da532ade4e9f5129428bbc101be64 (00:03:17) Task 68414 | 02:10:11 | Compiling packages: java8/ae41eecf1175fb16c678940d4d6e31af10405b6e Task 68414 | 02:10:30 | Compiling packages: cerebro/278996853981243e3b921d18e255d55d998dcc7f (00:00:30) Task 68414 | 02:10:30 | Compiling packages: elasticsearch/cb154811849156850a88023c3dd1fd46698a09da Task 68414 | 02:10:33 | Compiling packages: redis/ff3e314387f91116dd8906cd656ecd0476b4c7b5 (00:00:42) Task 68414 | 02:10:33 | Compiling packages: firehose-to-syslog/57480e93d19cefa2f26dfa787419d378b2104b13 Task 68414 | 02:10:47 | Compiling packages: java8/ae41eecf1175fb16c678940d4d6e31af10405b6e (00:00:36) Task 68414 | 02:10:47 | Compiling packages: logstash/a5bc4ac7fb0f561db9b9e03833510b866236af8e Task 68414 | 02:10:57 | Compiling packages: elasticsearch/cb154811849156850a88023c3dd1fd46698a09da (00:00:27) Task 68414 | 02:11:09 | Compiling packages: firehose-to-syslog/57480e93d19cefa2f26dfa787419d378b2104b13 (00:00:36) Task 68414 | 02:12:09 | Compiling packages: python3/2a00051b1a0f02d70453c75e9036d41cb960ebfc (00:05:15) Task 68414 | 02:12:09 | Compiling packages: curator/27ee549a38ebcef009bb0e63ac716d544dc8caa2 Task 68414 | 02:12:16 | Compiling packages: logstash/a5bc4ac7fb0f561db9b9e03833510b866236af8e (00:01:29) Task 68414 | 02:12:48 | Compiling packages: curator/27ee549a38ebcef009bb0e63ac716d544dc8caa2 (00:00:39) Task 68414 | 02:16:41 | Compiling packages: ruby2.3/613589acad7ddafc74fd12316e3d9cf5346f612e (00:09:47) Task 68414 | 02:16:41 | Compiling packages: logsearch-config/4cd3b3efcb7ea642badd77ff3b5189ae1d324734 (00:00:21) Task 68414 | 02:17:50 | Creating missing vms: elasticsearch_master/4698c36b-413d-4370-b671-44ee075a0cf0 (0) Task 68414 | 02:17:50 | Creating missing vms: elasticsearch_data/d779c528-8f75-4b4c-b2d9-ac367c1e5ece (0) Task 68414 | 02:17:50 | Creating missing vms: maintenance/dba09e1e-06c0-42bf-a30d-d97a62c536bc (0) Task 68414 | 02:17:50 | Creating missing vms: queue/cc986003-b6c1-4570-b2d7-32ecfd40eedf (0) Task 68414 | 02:17:50 | Creating missing vms: visualization/d1ac0c78-aa4c-465d-9193-64f2e2de269a (0) Task 68414 | 02:17:50 | Creating missing vms: elasticsearch_data/fa38698e-913c-4296-aac8-c0b56c84a71e (1) Task 68414 | 02:17:50 | Creating missing vms: collector/d2a1aed9-d10f-42df-91ec-e21f1baecfb8 (0) Task 68414 | 02:17:50 | Creating missing vms: parser/7ef8ffd6-7d8b-4ae0-bd8c-17f5e7092ca2 (0) Task 68414 | 02:17:50 | Creating missing vms: parser/3dfdc7bc-8dde-4ed1-95d0-eb638d4900fa (1) Task 68414 | 02:17:50 | Creating missing vms: router/c64e9519-713c-4f24-9b04-4bbf2d0ac457 (0) Task 68414 | 02:21:00 | Creating missing vms: visualization/d1ac0c78-aa4c-465d-9193-64f2e2de269a (0) (00:03:10) Task 68414 | 02:21:07 | Creating missing vms: elasticsearch_master/4698c36b-413d-4370-b671-44ee075a0cf0 (0) (00:03:17) Task 68414 | 02:21:20 | Creating missing vms: parser/7ef8ffd6-7d8b-4ae0-bd8c-17f5e7092ca2 (0) (00:03:30) Task 68414 | 02:21:20 | Creating missing vms: elasticsearch_data/fa38698e-913c-4296-aac8-c0b56c84a71e (1) (00:03:30) Task 68414 | 02:21:22 | Creating missing vms: queue/cc986003-b6c1-4570-b2d7-32ecfd40eedf (0) (00:03:32) Task 68414 | 02:21:22 | Creating missing vms: elasticsearch_data/d779c528-8f75-4b4c-b2d9-ac367c1e5ece (0) (00:03:32) Task 68414 | 02:21:24 | Creating missing vms: collector/d2a1aed9-d10f-42df-91ec-e21f1baecfb8 (0) (00:03:34) Task 68414 | 02:21:24 | Creating missing vms: maintenance/dba09e1e-06c0-42bf-a30d-d97a62c536bc (0) (00:03:34) Task 68414 | 02:21:24 | Creating missing vms: router/c64e9519-713c-4f24-9b04-4bbf2d0ac457 (0) (00:03:34) Task 68414 | 02:21:25 | Creating missing vms: parser/3dfdc7bc-8dde-4ed1-95d0-eb638d4900fa (1) (00:03:35) Task 68414 | 02:21:28 | Updating instance elasticsearch_master: elasticsearch_master/4698c36b-413d-4370-b671-44ee075a0cf0 (0) (canary) Task 68414 | 02:21:28 | Updating instance queue: queue/cc986003-b6c1-4570-b2d7-32ecfd40eedf (0) (canary) Task 68414 | 02:25:25 | Updating instance elasticsearch_master: elasticsearch_master/4698c36b-413d-4370-b671-44ee075a0cf0 (0) (canary) (00:03:57 Task 68414 | 02:25:43 | Updating instance queue: queue/cc986003-b6c1-4570-b2d7-32ecfd40eedf (0) (canary) (00:04:15) Task 68414 | 02:25:43 | Updating instance maintenance: maintenance/dba09e1e-06c0-42bf-a30d-d97a62c536bc (0) (canary) (00:01:06) Task 68414 | 02:26:49 | Updating instance elasticsearch_data: elasticsearch_data/d779c528-8f75-4b4c-b2d9-ac367c1e5ece (0) (canary) (00:02:10) Task 68414 | 02:28:59 | Updating instance elasticsearch_data: elasticsearch_data/fa38698e-913c-4296-aac8-c0b56c84a71e (1) (00:01:54) Task 68414 | 02:30:53 | Updating instance collector: collector/d2a1aed9-d10f-42df-91ec-e21f1baecfb8 (0) (canary) Task 68414 | 02:30:53 | Updating instance visualization: visualization/d1ac0c78-aa4c-465d-9193-64f2e2de269a (0) (canary) Task 68414 | 02:30:53 | Updating instance router: router/c64e9519-713c-4f24-9b04-4bbf2d0ac457 (0) (canary) Task 68414 | 02:30:53 | Updating instance parser: parser/7ef8ffd6-7d8b-4ae0-bd8c-17f5e7092ca2 (0) (canary) Task 68414 | 02:31:45 | Updating instance router: router/c64e9519-713c-4f24-9b04-4bbf2d0ac457 (0) (canary) (00:00:52) Task 68414 | 02:31:55 | Updating instance visualization: visualization/d1ac0c78-aa4c-465d-9193-64f2e2de269a (0) (canary) (00:01:02) Task 68414 | 02:32:10 | Updating instance parser: parser/7ef8ffd6-7d8b-4ae0-bd8c-17f5e7092ca2 (0) (canary) (00:01:17) Task 68414 | 02:32:10 | Updating instance parser: parser/3dfdc7bc-8dde-4ed1-95d0-eb638d4900fa (1) (00:01:06) Task 68414 | 02:33:54 | Updating instance collector: collector/d2a1aed9-d10f-42df-91ec-e21f1baecfb8 (0) (canary) (00:03:01)

Task 68414 Started Wed Nov 28 02:06:49 UTC 2018 Task 68414 Finished Wed Nov 28 02:33:54 UTC 2018 Task 68414 Duration 00:27:05 Task 68414 done

Succeeded

- 배포된 Logging 서비스를 확인한다.

$ bosh -e micro-bosh -d paasta-logging-service vms Using environment '10.30.40.111' as client 'admin'

Task 68432. Done

Deployment 'paasta-logging-service'

Instance Process State AZ IPs VM CID VM Type Active collector/d2a1aed9-d10f-42df-91ec-e21f1baecfb8 running z5 10.30.107.131 vm-e73085ec-e336-4c54-a842-37989dc4fe1d default true elasticsearch_data/d779c528-8f75-4b4c-b2d9-ac367c1e5ece running z5 10.30.107.133 vm-5b1fed2f-774f-47cf-9a14-edc015e790f1 medium true elasticsearch_data/fa38698e-913c-4296-aac8-c0b56c84a71e running z5 10.30.107.134 vm-36a47dab-8d09-4daa-bb8c-0394f4d83fd7 medium true elasticsearch_master/4698c36b-413d-4370-b671-44ee075a0cf0 running z5 10.30.107.135 vm-46152b8f-d660-413c-9396-8b4068a4a454 default true maintenance/dba09e1e-06c0-42bf-a30d-d97a62c536bc running z5 10.30.107.136 vm-780e1595-9aa9-445c-b056-27ff4e844017 minimal true parser/3dfdc7bc-8dde-4ed1-95d0-eb638d4900fa running z5 10.30.107.138 vm-44210be7-0dab-46db-8cb6-d71a2c29d3c8 default true parser/7ef8ffd6-7d8b-4ae0-bd8c-17f5e7092ca2 running z5 10.30.107.137 vm-1eb78459-3050-4ab2-8f49-78f0ddb795b0 default true queue/cc986003-b6c1-4570-b2d7-32ecfd40eedf running z5 10.30.107.139 vm-f11ec996-5c1e-46a0-972a-8b1415267df0 default true router/c64e9519-713c-4f24-9b04-4bbf2d0ac457 running z5 10.30.107.140 vm-32ebc53c-6bef-48d7-854e-4b09a4dd9d01 minimal true 115.68.47.181 visualization/d1ac0c78-aa4c-465d-9193-64f2e2de269a running z5 10.30.107.143 vm-75fdb6a6-e77f-4adb-8336-ec77254c82fa default true

## <div id="3"/>3. Logging 서비스 관리
Logging 서비스 배포가 완료 되면, PaaS-TA 포탈에서 서비스를 사용하기 위해 Logging 서비스 UAA Client 등록 및 Logging 서비스 활성화 코드 등록을 해 주어야 한다.
### <div id="3.1"/> 3.1. Logging 서비스 UAA Client 등록
- Logging 서비스 접근이 가능한 IP를 확인한다.

$ bosh -e micro-bosh -d paasta-logging-service vms Using environment '10.30.40.111' as client 'admin'

Task 68432. Done

Deployment 'paasta-logging-service'

Instance Process State AZ IPs VM CID VM Type Active collector/d2a1aed9-d10f-42df-91ec-e21f1baecfb8 running z5 10.30.107.131 vm-e73085ec-e336-4c54-a842-37989dc4fe1d default true elasticsearch_data/d779c528-8f75-4b4c-b2d9-ac367c1e5ece running z5 10.30.107.133 vm-5b1fed2f-774f-47cf-9a14-edc015e790f1 medium true elasticsearch_data/fa38698e-913c-4296-aac8-c0b56c84a71e running z5 10.30.107.134 vm-36a47dab-8d09-4daa-bb8c-0394f4d83fd7 medium true elasticsearch_master/4698c36b-413d-4370-b671-44ee075a0cf0 running z5 10.30.107.135 vm-46152b8f-d660-413c-9396-8b4068a4a454 default true maintenance/dba09e1e-06c0-42bf-a30d-d97a62c536bc running z5 10.30.107.136 vm-780e1595-9aa9-445c-b056-27ff4e844017 minimal true parser/3dfdc7bc-8dde-4ed1-95d0-eb638d4900fa running z5 10.30.107.138 vm-44210be7-0dab-46db-8cb6-d71a2c29d3c8 default true parser/7ef8ffd6-7d8b-4ae0-bd8c-17f5e7092ca2 running z5 10.30.107.137 vm-1eb78459-3050-4ab2-8f49-78f0ddb795b0 default true queue/cc986003-b6c1-4570-b2d7-32ecfd40eedf running z5 10.30.107.139 vm-f11ec996-5c1e-46a0-972a-8b1415267df0 default true router/c64e9519-713c-4f24-9b04-4bbf2d0ac457 running z5 10.30.107.140 vm-32ebc53c-6bef-48d7-854e-4b09a4dd9d01 minimal true 115.68.47.181 visualization/d1ac0c78-aa4c-465d-9193-64f2e2de269a running z5 10.30.107.143 vm-75fdb6a6-e77f-4adb-8336-ec77254c82fa default true

- uaac server의 endpoint를 설정한다.

endpoint 설정

$ uaac target https://uaa. --skip-ssl-validation

target 확인

$ uaac target Target: https://uaa. Context: uaa_admin, from client uaa_admin

- uaac 로그인을 한다.

$ uaac token client get -s Successfully fetched token via client credentials grant. Target: https://uaa. Context: admin, from client admin

- Logging 서비스 계정을 생성 한다.
$ uaac client add <CF_UAA_CLIENT_ID> -s <CF_UAA_CLIENT_SECRET> --redirect_uri <Logging 서비스 URI> --scope <퍼미션 범위> --authorized_grant_types <권한 타입> --authorities=<권한 퍼미션> --autoapprove=<자동승인권한>
- <CF_UAA_CLIENT_ID> : uaac 클라이언트 id
- <CF_UAA_CLIENT_SECRET> : uaac 클라이언트 secret
- <Logging 서비스 URI> : 성공적으로 리다이렉션 할 Logging 서비스 접근 URL (router public IP)
- <퍼미션 범위> : 클라이언트가 사용자를 대신하여 얻을 수있는 허용 범위 목록
- <권한 타입> : 서비스가 제공하는 API를 사용할 수 있는 권한 목록
- <권한 퍼미션> : 클라이언트에 부여 된 권한 목록
- <자동승인권한> : 사용자 승인이 필요하지 않은 권한 목록

Logging 서비스 계정 생성

$ uaac client add laasclient -s clientsecret --redirect_uri " http://115.68.47.181" --scope "cloud_controller_service_permissions.read , openid , cloud_controller.read , cloud_controller.write , cloud_controller.admin" --authorized_grant_types "authorization_code , client_credentials , refresh_token" --authorities="uaa.resource" --autoapprove="openid , cloud_controller_service_permissions.read"

Logging 서비스 계정 생성 확인

$ uaac clients laasclient scope: cloud_controller.read cloud_controller.write cloud_controller_service_permissions.read openid cloud_controller.admin resource_ids: none authorized_grant_types: refresh_token client_credentials authorization_code redirect_uri: http://115.68.47.181 autoapprove: cloud_controller_service_permissions.read openid authorities: uaa.resource name: laasclient lastmodified: 1542894096080

```

3.2. Logging 서비스 활성화 코드 등록

  • PaaS-TA 운영자 포탈에 접속한다.

  • 운영관리의 코드관리 메뉴로 이동하여 다음과 같이 코드를 등록한다.

※ Group Table 코드 ID : LAAS 코드 이름 : Logging Service

※ Detail Table Key : laas_base_url Value : http:///app/laas 요약 : Logging Service Base URL 사용 : Y