还有一种创建方式 是使用py开发工具,调用openstackclient的方法进行创建实例 ,好处就是可随意指定我们要的虚拟机IP地址,需求的场景就是,某天我们需要主动分配一个比较熟知的IP用作某个服务组件
或者某天,你需要打包一个实例的快照,终止实例后,你想通过快照的方式将它恢复为原来的IP,可以使用以下方法。
以win7客户端为例。
先下载安装eclipse 安装
安装 eclipse 的python插件,插件安装方法可自行百度
本机,安装python2.7环境
安装完后,添加python到系统环境变量。因为我们后面要用它的cmd命令行进行下载安装openstackclient,环境变量方法可自行百度
下载python-pip工具插件,
解压到python安装目录下。
随后进入该pip目录,在空白处,按住Shift+鼠标右键,选“在此处打开命令窗口”
pip安装openstackclient
pip install openstackclient
安装完后基础的openstackclient端就完成了,直接可关闭窗口了,后续我们在eclipse上调试调用即可。
运行eclipse,新建一个python工程,创建一个pyDev项目
可以写调用api的工程模板了。
比如我在我的工作空间目录openstackdashboad下,创建了一个test.py模块。
手工创建双网卡IP实例脚本如下,也是参考官网提供,稍做了修改,如下我有些浅蓝注释,复制时记得把 <粉色注释> 可删除。
# coding:utf-8
import time
import sys
from novaclient.client import Client
reload(sys)
sys.setdefaultencoding (" utf-8")
def print_values_ip(ip_list):
ip_dict_lisl = []
for ip in ip_list:
print( "-"*35 )
print( "fixed_ip : %s" % ip.fixed_ip)
print( "id : %s" % ip.id)
print( "instance_id : %s" % ip.instance_id)
print( "ip : %s" % ip.ip)
print( "pool : %s" % ip.pool)
def get_nova_credentials_v2():
d = {}
d['version'] = '2'
d['username'] = "demo"
#像我们登录dashboard一样,要用户名
d['api_key'] = "你的租户密码"
#像我们登录dashboard一样,要密码认证
d['auth_url'] = "http://controller:5000/v2.0"
#像我们平时登录dashboard一样,填写登录地址
d['project_id'] = "demo"
#项目名称
d['region_name'] = "RegionOne"
#区域名称
return d
def print_hosts(host_list):
for host in host_list:
print( "-"*35 )
print( "host_name : %s" % host.host_name)
print( "service : %s" % host.service)
print( "zone : %s" % host.zone)
print( "-"*35 )
if __name__ == '__main__':
credentials = get_nova_credentials_v2()
nova_client = Client(**credentials)
serviers = nova_client.servers.list()
# print(serviers)
image = nova_client.images.find(name= "20G_CentOS7_noLvm")
#这个是我们做好上传的centos7镜像名称,比如官网上的cirros,可以是镜像名称,也可以是快照名称
flavor = nova_client.flavors.find(name= "C2-M4G-D20G")
#这个是我们要的创建的主机类型和大小名称,比如官网上的tiny\small\large等等
net = nova_client.networks.find(label= "1040100")
#这个是我们定义好的,公网网段名称,比如官方的public,这主声明方法是为了解析到public得到它的net-id,并附给net
net2 = nova_client.networks.find(label= "17216100")
#这个是我们定义好的,私有网段名称,比如官方的private,这主声明方法是为了解析到private 得到它的net-id,并附给net2
nics = [{'net-id': net.id, 'v4-fixed-ip': '10.40.100.27'},{'net-id' : net2.id,'v4-fixed-ip': '172.16.100.27'}]
#这个是我们要为net和net2手工指定的双网卡IP地址
instance = nova_client.servers.create(name= "vm27", image=image,flavor=flavor, availability_zone="stg_zone" , nics=nics)
#vm27这个是为虚拟机指定一个主机名称,"stg_zone"是我们分配主机到指定的zone区域中去。
print("Sleeping for 5s after create command")
time.sleep(5)
print("List of VMs")
print(nova_client.servers.list())
配置完,保存,运行,注意你的这个IP是之前没有分配出云的,查看可通过dashboard界面查看虚拟状态。
手工创建单网卡IP实例脚本如下
# coding:utf-8
import time
import sys
from novaclient.client import Client
reload(sys)
sys.setdefaultencoding("utf-8")
def print_values_ip(ip_list):
ip_dict_lisl = []
for ip in ip_list:
print("-"*35)
print("fixed_ip : %s" % ip.fixed_ip)
print("id : %s" % ip.id)
print("instance_id : %s" % ip.instance_id)
print("ip : %s" % ip.ip)
print("pool : %s" % ip.pool)
def get_nova_credentials_v2():
d = {}
d['version'] = '2'
d['username'] = "demo"
d['api_key'] = "你的租户密码"
d['auth_url'] = "http://controller:5000/v2.0"
d['project_id'] = "demo"
d['region_name'] = "RegionOne"
return d
def print_hosts(host_list):
for host in host_list:
print("-"*35)
print("host_name : %s" % host.host_name)
print("service : %s" % host.service)
print("zone : %s" % host.zone)
print("-"*35)
if __name__ == '__main__':
credentials = get_nova_credentials_v2()
nova_client = Client(**credentials)
serviers = nova_client.servers.list()
# print(serviers)
image = nova_client.images.find(name="20G_CentOS7.1_noLVM")
flavor = nova_client.flavors.find(name="C2-M4G-D20G")
net = nova_client.networks.find(label="10120100")
nics = [{'net-id': net.id,'v4-fixed-ip':'10.40.150.150'}]
instance = nova_client.servers.create(name="zabbixserver", image=image,flavor=flavor, availability_zone="stg_zone", nics=nics)
print("Sleeping for 5s after create command")
time.sleep(5)
print("List of VMs")
print(nova_client.servers.list())
- openstack私有云布署实践【12.2 网络Neutron-controller节点配置(办公网环境)】
网络这一块推荐使用的是 Neutron--LinuxBirdge的Ha高可用,此高可用方案对Public作用不是很大,Public只用到DHCP,而Private则会用到L3 Agent,则此方案是有 ...
- openstack私有云布署实践【12.1 网络Neutron-controller节点配置(科兴环境)】
网络这一块推荐使用的是 Neutron--LinuxBirdge的Ha高可用,此高可用方案对Public作用不是很大,Public只用到DHCP,而Private则会用到L3 Agent,则此方案是有 ...
- openstack私有云布署实践【0 前言】
管理控制层面示图: 其实在修改这个布署文档是,我发现当时生产中的布署已经严重偏离了openstack高可用的指导思想.我们自己实践的高可用其实是适应自己的架构而做的调整,因为我们现实手头上中没有比较符 ...
- openstack私有云布署实践【15 创建租户网络+实例】
这里以办公网测试环境为例, (一)创建租户demo的网络 使用admin用户 source admin-openrc.sh 创建public公网 neutron net-create 1040 ...
- openstack私有云布署实践【9.3 主从controller单向同步glance-image目录】
采用Rysnc单向同步,而不用双方实时同步,原因是在历史的运行过程中,我们发现,有些镜像包太大,当在主用的glance将镜像保存时,并不是一时半会就把镜像保存好,当主用在保存时,备用节点又在实时同步那 ...
- openstack私有云布署实践【16.1 CentOS7.1 只有根分区镜像制作】
之所以要只有根分区镜像,是因为在创建VM或者调整云主机的硬盘大小时,它能自动扩容.无需人工介入 在原来的物理机10.40.41.1的CentOS 6.7上制作镜像.(当然如果你的制作镜像的宿主机是 ...
- openstack私有云布署实践【2 安装前的服务器基本环境准备】
服务器物理机都安装centos7.2 1511版本 , 此次采用的分区方式全是自动XFS格式LVM,在装系统时就将所有本地raid5硬盘都加入LVM全用了.默认/home目录有着最大的硬盘空间 并且我 ...
- openstack私有云布署实践【11.2 计算nova - compute节点配置(办公网环境)】
这里我只使用compute1节点配置为示例,其它节点的配置基本是一样的,只是声明的管理IP不同而已 计算节点 # yum install openstack-nova-compute sysfsu ...
- openstack私有云布署实践【11.1 计算nova - compute节点配置(科兴环境)】
这里我只使用kxcompute1节点配置为示例,其它节点的配置基本是一样的,只是声明的管理IP不同而已 计算节点 # yum install openstack-nova-compute sysf ...
随机推荐
- Windows窗口的创建
Windows窗口创建的基本代码: #include <Windows.h> LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM); i ...
- Windows 7/8 64位下安装64位Apache 2.4.7
准备软件: VC11 运行库 64位的apache版本 传送门:http://www.apachelounge.com/download/ 安装步骤: 修改httpd.conf配置文件 37行: Se ...
- 分析Sizzle引擎
jQuery 2.0.3 源码分析Sizzle引擎 - 打造高效查询 为什么Sizzle很高效? 首先,从处理流程上理解,它总是先使用最高效的原生方法来做处理 HTML文档一共有这么四个API: ge ...
- java 的sigola orm 的开发,第一次学写java,可以用在play上面
当然还是开源:https://github.com/xiaose1205/sigola 初学者有用,高手可以给点建议,勿喷啊.net转java,有些思想还没有那么快转.希望得到大家的支持啊 使 ...
- 2013 多校联合 2 A Balls Rearrangement (hdu 4611)
Balls Rearrangement Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Othe ...
- 限制某个进程只能在某个CPU上运行
首先可以调用GetSystemInfo查看有多少个CPU,再通过调用: BOOL WINAPI SetProcessAffinityMask( __in HANDLE hProcess, __in D ...
- 典型的团队VS优秀团队
如果做不了优秀的团队,那么就做一个典型的团队,公司需要这么一个神话,需要这么一个领头羊. 我在进入某公司后,第一个项目用的是"敏捷开发方法".而公司的理念恰恰是:开发.协作性强.扁 ...
- TaintDroid:智能手机监控实时隐私信息流跟踪系统(三)
4.3 原生代码标记传播 Native 代码是不受TaintDroid监控的.理想情况下,我们获得了相同的传播语义当使用相同的解释副本时.因此,为了精确的在Java层进行污点监控,我们定义了两个必 ...
- 图的匹配问题与最大流问题(三)——最大流问题Ford-Fulkerson方法Java实现
上篇文章主要介绍了Ford-Fulkerson方法的理论基础,本篇给出一种Java的实现. 先借助伪代码熟悉下流程 FORD-FULKERSON(G,t,s) 1 for each edge(u,v) ...
- Tomcat 配置成https协议
Tomcat 配置成https协议 在命令提示符窗口,进入Tomcat目录,执行以下命令: keytool -genkey -alias tomcat -keyalg RSA -keypass ch ...