是否存在服务切换的平台/服务不可知定义?

时间:2016-02-01 05:08:45

标签: rest service cloud paas

我很好奇是否有服务切换定义的规范。例如,如果在PaaS / IaaS上配置了服务,则最终用户需要详细了解服务的内容,可以到达端点的位置,发布的端口以及使用的身份验证。 (想想HATEOAS ref_'s)我有一些模型可能看起来像:

对象存储示例

name: myobjstor
family: s3
about: https://aws.amazon.com/documentation/s3
zone: public
protocol:
  spec: http
  host: s3.mysite.com
  port: 443
  tls: true
authentication:
  strategy: oauth2
  username: someuser
  password: somepassword
definition:
  type: swagger
  url: 'https://mysite/swagger.json'

openstack示例

name: myostack
family: openstack-keystone_v2.1
about: http://developer.openstack.org/api-ref.html
zone: public
protocol:
  spec: http
  host: keystone.mysite.com
  port: 443
  tls: true
authentication:
  strategy: oauth2
  username: someuser
  password: somepassword
definition:
  type: swagger
  url: 'https://mysite/swagger.json'

redis示例

name: myredis
family: redis
about: http://redis.io/documentation
zone: public
protocol:
  spec: redis
  host: redis.mysite.com
  port: 6379
options:
  db: 0

nfs示例

name: mynfs
family: nfs
about: http://nfs.sourceforge.net
zone: public
protocol:
  spec: nfsv4
  host: nfs.mysite.com
  ports: 
    - 111
    - 2049

这样的标准是否已经存在?

1 个答案:

答案 0 :(得分:0)

我建议您查看"服务发现" pattern

有几种工具可以很容易地实现,但是大多数工具使用键/值对来描述服务,例如请参阅etcd,但看起来Consul添加了一些可能对您有用的字段here

示例领事定义

{
  "service": {
    "name": "redis",
    "tags": ["master"],
    "address": "127.0.0.1",
    "port": 8000,
    "enableTagOverride": false,
    "checks": [
      {
        "script": "/usr/local/bin/check_redis.py",
        "interval": "10s"
      }
    ]
  }
}