我很好奇是否有服务切换定义的规范。例如,如果在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
这样的标准是否已经存在?
答案 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"
}
]
}
}