UbuntuOpenStack core componennts
<1,keystone安装配置>
1,yum -y install openstack-keystone python-keystoneclient;
2,配置实用mysql存储keytone componts 配置信息
/etc/keystone/keystone.conf
connection = mysql://ruiy:321@byruiy.cc/keystone
创建数据库用户赋予合适权限;
3,Define an authorization token to use as a shared secret between the identity service and other OpenStack service
ADMIN_TOKEN=$(openssl rand -hex 10)
admin_token = $ADMIN_TOKEN
export OS_SERVICE_TOKEN=14034bb8102de15503dc
export OS_SERVICE_ENDPOINT=http://byruiy.cc:35357/v2.0
4,Keystone usees PKI tokens,Create the signing keys and certificates and restrict access to the generated data:
keystone-manage pki_setup --keystone-user keystone --keystone-group keystone
chown -R keystone:keystone /etc/keystone/ssl
chmod -R o-rwx /etc/keystone/ssl
5,OpenStack清理expired tokens
6,Define users,tenants,roles
创建administrative用户
创建用户,角色,租户
keystone user-create --name=admin --pass=admin --email=rui.qin@egrandis.com
keystone role-create --name=admin
keystone tenant-create --name=admin --description="Admin Tenant"
链接用户角色租户
创建normal普通用户
daily non-administrative interaction with the OpenStack cloud,skip the tenant role creation step when creating there users;
当前角色有admin(super-user)和_member_(normal-user)
7,Create a service tenant:
OpenStack service also require a username,tenant,and role to access other OpenStack services.
Ruiy tips
基于2中环境变量交互访问OpenStack services components
(1,用户,租户,Auth-URL,无此API called)
export OS_USERNAME=admin
export OS_PASSWORD=321
export OS_TENANT_NAME=admin_project
export OS_AUTH_URL=http://5.10.124.181:5000/v2.0
(2,admin_token,OS_SERVICE_ENDPOINT)
export OS_SERVICE_TOKEN=14034bb8102de15503dc
export OS_SERVICE_ENDPOINT=http://byruiy.cc:35357/v2.0
或是指定OpenStack components --options
8,Define services and API endpoints
keystone service-create Describes the service;
keystone endpoint-create Associates API endpoints with the service;
register the identity service itself:
8.1,service-create
8.2,endpoint-create
Specify an OpenStack core components service API endpoint for identity service by using every keystone service-create returned service_ID
8.2.1,截取keystone service-id字段
8.2.2,基于OpenStack service components keystone service-id创建keystone的API endpoint
8.2.3,verify identityService installed and configured correctly
clear unset OS_SERVICE_TOKEN and OS_SERVICE_ENDPOINT environment variables
8.2.4,use regular user name-based authentication(基于此时还没使用tenant)
request a authentication token by using the admin user and the password
in response,you receive a token paired with your user ID
verifyes identity service kis running on the expected endpoint and that your user account is established with the expected credenitals
当你看到上面的截图时,你一定惊呆了!要是惊呆了,那你就傻了,上面仅仅是使用上面创建的用户基于密码,而没使用tenant,看到没
分别总结基于环境变量访问以定义的API endpoint
基于OpenStack core components python-OpenStackcorecomponentsClients --options访问API endpoint
keystone --os-username= --os-password= --os-auth-url= token-get
8.2.5,基于tenant 获取token-get for specify tenant
request authorization on tenant
In response,you receive a token that includes the ID of the tenant that you specified.Verifies that your user account has an explicitly defined role on the specified tenant and the tenant exists expected;
测试不使用--os-username= --os-password= --os-tenant-name= --os-auth-url= 而是使用此命令选项的环境变量
或是--os-service-token= --os-service-endpoint=
<二,安装配置OpenStackClient客户端>
OpenStack Client客户端是干啥的?是用来执行CLI called OpenStack core components Services API;
Ruiy Tips:Internally,each OpenStack core components Service client CLI runs cURL commands that embed API requests;
OpenStack APIs are RESTful APIs that use the HTTP protocol,including methods,URIs,media types,and response codes;
URI,URL区别见
http://baike.baidu.com/view/160675.htm?fr=aladdin
Each Openstack service has its own command-line client;
Openstack services and clients:
Block Storage cinder python-cinderclient create and manage volumes
Compute nova python-novaclient create and manage images,instances,and flavors
Database service trove python-troveclient create and manage databases
image service glance python-glanceclient create and manage images
identity keystone python-keystoneclient create and manage users,tenants,roles,endpoints,and credentials
Networking neutron python-neutronclient configure network for guest servers
Object Storage swift python-swiftclient gather statistics,list items,update metadata,and upload,download,and delete files stored by the object storage service,gain access to an object storage installation for ad hoc processing
orchestration heat python-heatclient launch stacks from templates,view details of running stacks including events and resources,and update and delete stacks
telemetry ceilometer python-ceilometerclient create and collect measurements across openstack
prerequisite softwares for openstack core components services clients
setuptools是 Python Enterprise Application Kit(PEAK)的一个副项目,它 是一组Python的 distutilsde工具的增强工具
pip(python package index) CLC
easy_install pip
from setuptools package
pip install python-PROJECTclient (latest version)
pip enables you to update or remove a packages
upgrade or remove clients
pip install --upgrade python-PROJECTclient
pip uninstall python-PROJECTclient
<三,安装配置image 镜像服务>
OpenStack VMIs image service overview
snapshots for back up and as templates to launch new servers
can store registered
images in Object Storage or in other locations or simple fileSystem
verify image service Succ installed
下载测试镜像
http://cdn.download.cirros-cloud.net/0.3.2/cirros-0.3.2-x86_64-disk.img
upload registry img to image service;
online regtry img resources
Ruiy Tips,OpenStack Services Core components image Service(glance)项目下的组件
glance-api
glance-registry
<四,安装配置compute service Inc Compute control service and compute Nodes>
1,compute control service
Ruiy Rips:
every OpenStack core Componets Service 都需要创建一个keystone user,为其指定service tenant,admin role
注册此组件服务,并关联足迹API endpoints
Ubuntu OpenStack compute control service 服务控制
测试compute controll service -->nova 配置Ok!
基于CLIlaunch virtual machine 前提是获取相关image-id,flavor-id
2,compute Nodes
无网络实例化VMI,always spawning
<五,add a Network services (Nrutron,legacy networking)>
关于云计算安全组(security group)概念:
安全组概念属于云网络范畴,Security groups enable adminstrators to defined firewall rules in groups,a VM can blong to one or more security group,and Networking applies the rules in those security groups to block or unblock,port ranges,or traffic types for that VM
Ruiy Tips:一般命令行的参数Arguments及options选项区别
Arguments(通常no --)
Options(通常加--)
调节内核参数,启用内核网络(kernel networking)功能
dmks(动态内核模块支持(Dynamic Kernel Module Support))
generic routing encapsulation(通用路由封装)
Generic Receive Offload (GRO)
Tunneling protocols such as generic routing encapsulation (GRE) include additional
packet headers that increase overhead and decrease space available for the payload or
user data
many network devices lack support for jumbo frames (Mellanox)
基于单网卡(eg,eth0)配置多ip
ifconfig eth0:1 192.168.1.159 netmask 255.255.255.0;
create a router and attach your tenant and external networks to it;
在配置OpenStack网络后启动虚机必须指定网络
基于nova boot --image --flavor --nic net-id= --security-group --key-name New-Instance-You-want-like-to-name初始化创建OpenStack虚机实例VMI VMs;
获取与本机ESTABLISH的外网ip
OpenStack基于CLI删除VMI,VMs;
UbuntuOpenStack core componennts的更多相关文章
- ASP.NET Core 之 Identity 入门(一)
前言 在 ASP.NET Core 中,仍然沿用了 ASP.NET里面的 Identity 组件库,负责对用户的身份进行认证,总体来说的话,没有MVC 5 里面那么复杂,因为在MVC 5里面引入了OW ...
- .NET Core中的认证管理解析
.NET Core中的认证管理解析 0x00 问题来源 在新建.NET Core的Web项目时选择“使用个人用户账户”就可以创建一个带有用户和权限管理的项目,已经准备好了用户注册.登录等很多页面,也可 ...
- ASP.NET Core 中的那些认证中间件及一些重要知识点
前言 在读这篇文章之间,建议先看一下我的 ASP.NET Core 之 Identity 入门系列(一,二,三)奠定一下基础. 有关于 Authentication 的知识太广,所以本篇介绍几个在 A ...
- .Net Core MVC 网站开发(Ninesky) 2.4、添加栏目与异步方法
在2.3中完成依赖注入后,这次主要实现栏目的添加功能.按照前面思路栏目有三种类型,常规栏目即可以添加子栏目也可以选择是否添加内容,内容又可以分文章或其他类型,所以还要添加一个模块功能.这次主要实现栏目 ...
- ASP.NET Core应用的错误处理[3]:ExceptionHandlerMiddleware中间件如何呈现“定制化错误页面”
DeveloperExceptionPageMiddleware中间件利用呈现出来的错误页面实现抛出异常和当前请求的详细信息以辅助开发人员更好地进行纠错诊断工作,而ExceptionHandlerMi ...
- EntityFramework Core Raw SQL
前言 本节我们来讲讲EF Core中的原始查询,目前在项目中对于简单的查询直接通过EF就可以解决,但是涉及到多表查询时为了一步到位就采用了原始查询的方式进行.下面我们一起来看看. EntityFram ...
- ASP.NET Core MVC/WebAPi 模型绑定探索
前言 相信一直关注我的园友都知道,我写的博文都没有特别枯燥理论性的东西,主要是当每开启一门新的技术之旅时,刚开始就直接去看底层实现原理,第一会感觉索然无味,第二也不明白到底为何要这样做,所以只有当你用 ...
- ASP.NET Core应用的错误处理[2]:DeveloperExceptionPageMiddleware中间件如何呈现“开发者异常页面”
在<ASP.NET Core应用的错误处理[1]:三种呈现错误页面的方式>中,我们通过几个简单的实例演示了如何呈现一个错误页面,这些错误页面的呈现分别由三个对应的中间件来完成,接下来我们将 ...
- Asp.net Core中使用Session
前言 2017年就这么悄无声息的开始了,2017年对我来说又是特别重要的一年. 元旦放假在家写了个Asp.net Core验证码登录, 做demo的过程中遇到两个小问题,第一是在Asp.net Cor ...
随机推荐
- 学DSP(一):开始
DSP有digital signal process 和 digital signal processor 2个意思,数字信号处理和数字信号处理器,我这里就是学数字信号处理器了. 我为什么要学DSP, ...
- 大量客户反映wordpress的网站打开巨慢,经分析发现,这些网站大都使用了google的字体服务,由于最近google的服务已经被大陆屏蔽,所以wordpress的网站打开时,会卡在字体加载上。
一会你安装完wp,发现打开巨卡的话,看看这个帖子:http://bbs.myhostcn.com/thread-1026-1-1.html最近一段时间,大量客户反映wordpress的网站打开巨慢, ...
- LaTex 下编译后不能显示中文,或者中文乱码
在 Sublime Text 中编辑以下文件并保存(第一行的注释很重要),按下 Cammand + B 编译: %!TEX program = xelatex \documentclass[UTF8] ...
- Unity 编辑器扩展自定义窗体
这次看见Unity还可以自定义弹出窗体,让我很好奇.于是就去网上找文章看了看. 如果想自定义窗体需要把类放入Editor文件夹下面. 代码如下: using UnityEngine; using Un ...
- flappy bird游戏源代码揭秘和下载
转:http://blog.csdn.net/touchsnow/article/details/19071961 背景: 最近火爆全球的游戏flappy bird让笔者叹为观止,于是花了一天的时间山 ...
- IOS Custom NavigationItem --写titleView
//先自己写一个titleView UIView *titleView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 200, 20)];//all ...
- 在美国公司架构中,LLC、LLP 和 Corporation 的区别何在?
这个问题,首先需要弄清楚这样一个事实:LLC.LLP.Corporation分别属于三种不同类型的公司实体. 1,LLC (Limited Liability Company)是责任有限公司: 2,L ...
- Jq自定义动画
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- .Net中如何使用MySql连接池
提供一份官方的译文.翻译也挺辛苦的!! 6.4 Using Connector/Net with Connection Pooling 6.4在Connector/Net中使用连接池 The Conn ...
- Eclipse MyEclipse 复制项目 复制现有项目 复制功能相似项目
如果现在已经存在一个Java Web项目 ProjectA,现在想做另外一个项目,里面绝大部分功能和结构都可以复用,如果想通过复制的方法来,那么可以这么做: 1.到资源管理器中,将ProjectA文件 ...