了解和使用keystone(六)创建service和endpoint

前面的都是用户归属的关系,而service则是用户可以获取什么服务,endpoint则是服务位于那个访问点。一个service可以有多个endpoint,这很好理解,主备,负载均衡。

创建Service

下面的命令使用了环境变量,可以将设定OS_USERNAME以及OS_PASSWORD。

$ openstack service create --name demo-service --description "Demo Services" demo-type
 +-------------+----------------------------------+
 | Field       | Value                            |
 +-------------+----------------------------------+
 | description | Demo Services                    |
 | enabled     | True                             |
 | id          | 654dd649b03e448e9000dc6a8356d9e7 |
 | name        | demo-service                     |
 | type        | demo-type                        |
 +-------------+----------------------------------+

创建service的enpoint

$ openstack endpoint create demo-service internal http://localhost:8080/ep1
 +--------------+----------------------------------+
 | Field        | Value                            |
 +--------------+----------------------------------+
 | enabled      | True                             |
 | id           | 1fe7dd72d4e348b6807ee5dfc40625d6 |
 | interface    | internal                         |
 | region       | None                             |
 | region_id    | None                             |
 | service_id   | 654dd649b03e448e9000dc6a8356d9e7 |
 | service_name | demo-service                     |
 | service_type | demo-type                        |
 | url          | http://localhost:8080/ep1        |
 +--------------+----------------------------------+
$ openstack endpoint create demo-service internal http://localhost:8080/ep2
 +--------------+----------------------------------+
 | Field        | Value                            |
 +--------------+----------------------------------+
 | enabled      | True                             |
 | id           | 13f0ad36b94246e7ad28def1e90f56e5 |
 | interface    | internal                         |
 | region       | None                             |
 | region_id    | None                             |
 | service_id   | 654dd649b03e448e9000dc6a8356d9e7 |
 | service_name | demo-service                     |
 | service_type | demo-type                        |
 | url          | http://localhost:8080/ep2        |
 +--------------+----------------------------------+

在创建endpoint中有参数region,可以提供地域信息,user选择合适地域的服务。

获取service和enpoint信息

在获取token的时候,可以获取相关的信息,service位于catalog。

curl  -d @token-request.json -H "Content-type: application/json" http://localhost:35357/v3/auth/tokens | python -mjson.tool
 或者 curl  -H "X-Auth-Token:$USER_TOKEN" -H "X-Subject-Token:$USER_TOKEN" -H "Content-type: application/json" http://localhost:35357/v3/auth/tokens | python -mjson.tool

  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100  1385  100   939  100   446   1381    656 --:--:-- --:--:-- --:--:--  1380
{
    "token": {
        "audit_ids": [
            "MQP0pIajQdi2L_02ifzeZw"
        ],
        "catalog": [
            {
                "endpoints": [
                    {
                        "id": "13f0ad36b94246e7ad28def1e90f56e5",
                        "interface": "internal",
                        "region": null,
                        "region_id": null,
                        "url": "http://localhost:8080/ep2"
                    },
                    {
                        "id": "1fe7dd72d4e348b6807ee5dfc40625d6",
                        "interface": "internal",
                        "region": null,
                        "region_id": null,
                        "url": "http://localhost:8080/ep1"
                    }
                ],
                "id": "654dd649b03e448e9000dc6a8356d9e7",
                "name": "demo-service",
                "type": "demo-type"
            }
        ],
        "expires_at": "2016-09-06T04:14:13.313439Z",
        "issued_at": "2016-09-06T03:14:13.313439Z",
        "methods": [
            "password"
        ],
        "project": {
            "domain": {
                "id": "32b54ffdebe84eba9cd10a8dbe647b70",
                "name": "demo-domain"
            },
            "id": "b65e9985801f4481bce7ba885b68cac3",
            "name": "project-A"
        },
        "roles": [
            {
                "id": "6abf3532fce440148a7f29abc7685142",
                "name": "demo-role"
            }
        ],
        "user": {
            "domain": {
                "id": "32b54ffdebe84eba9cd10a8dbe647b70",
                "name": "demo-domain"
            },
            "id": "459c2cc894844396bec6c16fbc28da87",
            "name": "userA2"
        }
    }
}
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值