검색

32.2. 사용자 정의 절차에서 3scale 애플리케이션 분석 추출

download PDF

애플리케이션 분석을 추출하려면 ActiveDocs를 사용하여 시작합니다. 3scale ActiveDocs는 계정 설정 > 통합 > 3scale API Docs 아래의 관리 포털에서 사용할 수 있습니다. 3scale에는 ActiveDocs로 사용할 수 있는 모든 API가 있으므로 브라우저에서 사용해 볼 수 있습니다. 이를 통해 요구 사항에 가장 잘 부합하는 요청을 찾고, 요청(curl과 유사)을 가져오고 응답을 빠뜨릴 수 있습니다. 다음 그림은 ActiveDocs 예제를 제공합니다.

DIY 분석

스크립트에서 분석을 추출할 모든 애플리케이션을 가져오는 API 요청에 대한 ActiveDocs입니다.

  • ActiveDocs를 사용하여 조사를 수행한 후 선택한 스크립팅 언어로 요청을 지정합니다. 이 예제에서는 Ruby를 사용합니다.
  • 필요한 작업을 수행하는 스크립트가 있을 때까지 반복합니다. 확장된 분석의 예를 보려면 스크립트를 gist로 사용할 수 있습니다. 계정에서 사용해 볼 수 있습니다.

ActiveDocs를 사용하면 API의 기능을 신속하게 파악할 수 있습니다. 그런 다음 수행할 작업에 필요한 3개 또는 4개의 요청을 찾고 스크립트를 함께 배치하는 것이 중요합니다.

다음 절차에서는 예제에서 고객이 원하는 사용자 지정 분석을 수행하는 단계를 보여줍니다.

절차

  1. 전체 애플리케이션 목록을 검색합니다. 이 작업을 수행하려면 페이지 매김이 필요합니다.

    def api_call_applications_list(domain, provider_key)
      done = false
      res = Array.new
      page = 1
    
          while !done
        url = "https://#{domain}/admin/api/applications.xml?provider_key=#{provider_key}&page=#{page}&per_page=100"
        page += 1
        response = RestClient.get url
        raise Exception.new("Wrong response code (#{response.code}) in request #{url}") if response.code!=200
        document = Nokogiri::XML(response.to_str)    done = document.xpath("applications/@current_page").text == document.xpath("applications/@total_pages").text
        document.xpath("//application").each do |item|
          app = Hash.new
          app["created_at"] = DateTime.parse(item.xpath("created_at").text)
          app["plan_name"] = item.xpath("plan/name").text
          app["service_id"] = item.xpath("plan/service_id").text
          app["account_id"] = item.xpath("user_account_id").text
          app["id"] = item.xpath("id").text
          res << app
        end
      end
      return res
    end
  2. 기준을 충족하지 않는 애플리케이션을 필터링합니다. 즉, 플랜은 "평가"여야 하며, 10일 이상 최신 상태여야 합니다.

    def filter_applications(domain, provider_key, plan_name, num_of_days)
      res = api_call_applications_list(domain, provider_key)
      res.each do |item|
        res.delete(item) if item["plan_name"] != plan_name
        res.delete(item) if item["created_at"] > (DateTime.now - num_of_days)
      end
      return res
    end
  3. 기준을 충족하는 각 애플리케이션에 대해, 지난 10일 동안 애플리케이션에 보유한 적중 횟수인 사용량을 얻습니다.

    def api_call_application_usage(domain, provider_key, application_id, metric, from, to, granularity)
      url = "https://#{domain}/stats/applications/#{application_id}/usage.xml?provider_key=#{provider_key}&metric_name=#{metric}&since=#{from}&until=#{to}&granularity=#{granularity}"
      response = RestClient.get url
      raise Exception.new("Wrong response code (#{response.code}) in request #{url}") if response.code!=200
      document = Nokogiri::XML(response.to_str)
      return document.xpath("//usage/data/values").text.split(",")
    end
  4. 개발자의 정보가 계정 오브젝트에 저장되므로 애플리케이션을 계정으로 상호 참조합니다.

    def api_call_account_read(domain, provider_key, account_id)
      url = "https://#{domain}/admin/api/accounts/#{account_id}.xml?provider_key=#{provider_key}"
      response = RestClient.get url
      raise Exception.new("Wrong response code (#{response.code}) in request #{url}") if response.code!=200
      document = Nokogiri::XML(response.to_str)
      account = Hash.new
      account["email"] = document.xpath("//users/user/email").text
      account["name"] = document.xpath("//users/user/first_name").text + " " + document.xpath("//users/user/last_name").text
      return account
    end
  5. 모든 것을 함께 사용하여 스크립트를 완료합니다. 3scale의 기본 제공 분석에서 아직 사용할 수 없는 정보를 가져오는 스크립트가 있습니다. 전체 스크립트를 gist로 가져올 수도 있습니다.
Red Hat logoGithubRedditYoutubeTwitter

자세한 정보

평가판, 구매 및 판매

커뮤니티

Red Hat 문서 정보

Red Hat을 사용하는 고객은 신뢰할 수 있는 콘텐츠가 포함된 제품과 서비스를 통해 혁신하고 목표를 달성할 수 있습니다.

보다 포괄적 수용을 위한 오픈 소스 용어 교체

Red Hat은 코드, 문서, 웹 속성에서 문제가 있는 언어를 교체하기 위해 최선을 다하고 있습니다. 자세한 내용은 다음을 참조하세요.Red Hat 블로그.

Red Hat 소개

Red Hat은 기업이 핵심 데이터 센터에서 네트워크 에지에 이르기까지 플랫폼과 환경 전반에서 더 쉽게 작업할 수 있도록 강화된 솔루션을 제공합니다.

© 2024 Red Hat, Inc.