openstack在neutron组网模式下默认采用DHCP-Agent模块给虚拟机自动分配ip
现在想给虚拟机指定固定ip,即创建虚拟机的时候指定固定ip。
现分析如下: 背景 1、我们目前使用openstack+docker来搭建自己的私有云 2、openstack有两种网络环境搭建模式,一种是功能较简单的nova-network,一种是neutron方案 3、neutron方案代表着未来的趋势,提供更多高级的功能(例如路由功能和负载均衡服务等),更加方便用户去自定义自己的虚拟化网络 4、在已有的几个集群中,我们在线下开发测试环境中搭建了neutron方案的openstack集群
目的 neutron的设计理念是ip分配应当资源池化,因此在默认的dashboard操作界面上,只能为每个虚拟机指定特定的子网,虚拟机启动时会自动分配该子网可用的ip资源。但是,在很多开发测试场景下,我们还是需要为指定启动的虚拟机配备一个固定的ip,比如需要反复创建、删除虚拟机,这个时候就会希望虚拟机的ip不变,方便测试用例的编写,固定的ip地址也有利于CMDB的管理。
前置条件 所有的操作都基于openstack项目提供的NeutronClient和NovaClient工具,请确保这两个工具已经安装,可以登录openstack的集群管理节点,在命令行界面执行nova和neutron命令,看是否有帮助提示。执行这两个工具,还需要预先获得权限,例如在管理节点上执行这两个命令的话,首先要执行以下命令,执行后就会在环境变量中保存有admin用户的权限信息
[root@openstack-server src]# source admin-openrc.sh
neutron通过修改dhcp服务器的配置文件实现给指定虚拟机配置固定ip,因此要首先要确保虚拟机准备连接的子网的DHCP功能已开启? 查看子网的详细信息,确认子网的dhcp功能已经开启
[root@openstack-server src]# neutron subnet-list +--------------------------------------+-------------+----------------+----------------------------------------------------+ | id | name | cidr | allocation_pools | +--------------------------------------+-------------+----------------+----------------------------------------------------+ | c53da14a-01fe-4f6c-8485-232489deaa6e | flat-subnet | 192.168.1.0/24 | {"start": "192.168.1.100", "end": "192.168.1.200"} | +--------------------------------------+-------------+----------------+----------------------------------------------------+
[root@openstack-server src]# neutron subnet-show c53da14a-01fe-4f6c-8485-232489deaa6e +-------------------+----------------------------------------------------+ | Field | Value | +-------------------+----------------------------------------------------+ | allocation_pools | {"start": "192.168.1.100", "end": "192.168.1.200"} | | cidr | 192.168.1.0/24 | | dns_nameservers | 192.168.1.17 | | enable_dhcp | True | | gateway_ip | 192.168.1.17 | | host_routes | | | id | c53da14a-01fe-4f6c-8485-232489deaa6e | | ip_version | 4 | | ipv6_address_mode | | | ipv6_ra_mode | | | name | flat-subnet | | network_id | 1d9657f6-de9e-488f-911f-020c8622fe78 | | subnetpool_id | | | tenant_id | 65a0c00638c247a0a274837aa6eb165f | +-------------------+----------------------------------------------------+
如上,“enable_dhcp”是“True”,表明子网的dhcp功能已经开启。 ******************************************************************************************************************** 如果子网的dhcp功能没有开启,可以手动设置进行开启该功能! [root@openstack-server src]# neutron subnet-update --enable-dhcp c53da14a-01fe-4f6c-8485-232489deaa6e ********************************************************************************************************************
下面详细说下,创建虚拟机的时候,指定固定ip的方法:
1)创建一个和指定子网相关联的端口,并为该端口配置一个固定ip,具体命令格式: #neutron port-create --fixed-ip subnet_id=SUBNET_ID,ip_address=IP_FROM_POOL --name PORT_NAME NETWORK_ID 说明: 固定ip由自己决定分配哪一个ip,只要这个ip在子网的可用ip范围内,且该ip还未被使用即可。 PORT_NAME自行命名 NETWORK_ID可在前面的neutron subnet-show命令的执行结果中找到。
[root@openstack-server src]# neutron port-create --fixed-ip subnet_id=c53da14a-01fe-4f6c-8485-232489deaa6e,ip_address=192.168.1.101 --name kvm-server001 1d9657f6-de9e-488f-911f-020c8622fe78 Created a new port: +-----------------------+-----------------------------------------------------------------------------------------------------------------+ | Field | Value | +-----------------------+-----------------------------------------------------------------------------------------------------------------+ | admin_state_up | True | | allowed_address_pairs | | | binding:host_id | | | binding:profile | {} | | binding:vif_details | {} | | binding:vif_type | unbound | | binding:vnic_type | normal | | device_id | | | device_owner | | | dns_assignment | {"hostname": "host-192-168-1-101", "ip_address": "192.168.1.101", "fqdn": "host-192-168-1-101.openstacklocal."} | | dns_name | | | fixed_ips | {"subnet_id": "c53da14a-01fe-4f6c-8485-232489deaa6e", "ip_address": "192.168.1.101"} | | id | 8cc0b915-773d-45b7-9c3a-0e8198818637 | | mac_address | fa:16:3e:ce:bf:a5 | | name | kvm-server001 | | network_id | 1d9657f6-de9e-488f-911f-020c8622fe78 | | port_security_enabled | True | | security_groups | 050a6341-57c5-4b01-bc79-09efd9931d9c | | status | DOWN | | tenant_id | 65a0c00638c247a0a274837aa6eb165f | +-----------------------+-----------------------------------------------------------------------------------------------------------------+
2) 启动虚拟机,并在参数中指定要将虚拟机绑定到刚创建的port上,这样虚拟机就会被自动配置port已设置的ip,具体命令格式: #nova boot --flavor FLAVOR_ID --image IMAGE_ID --nic port-id=PORT_ID INSTANCE_NAME
接着,创建虚拟机,指定固定ip: 【具体参考http://www.cnblogs.com/kevingrace/p/5707003.html 里面创建虚拟机的步骤】
[root@openstack-server src]# nova boot --flavor kvm002 --image CentOS-6.5 --nic port-id=8cc0b915-773d-45b7-9c3a-0e8198818637--security-group default --key-name mykey kvm-server001 +--------------------------------------+---------------------------------------------------+ | Property | Value | +--------------------------------------+---------------------------------------------------+ | OS-DCF:diskConfig | MANUAL | | OS-EXT-AZ:availability_zone | | | OS-EXT-SRV-ATTR:host | - | | OS-EXT-SRV-ATTR:hypervisor_hostname | - | | OS-EXT-SRV-ATTR:instance_name | instance-00000017 | | OS-EXT-STS:power_state | 0 | | OS-EXT-STS:task_state | scheduling | | OS-EXT-STS:vm_state | building | | OS-SRV-USG:launched_at | - | | OS-SRV-USG:terminated_at | - | | accessIPv4 | | | accessIPv6 | | | adminPass | mFAKr7auzXv8 | | config_drive | | | created | 2016-08-30T08:47:06Z | | flavor | kvm002 (938dd195-ad12-4750-836f-bc8a29a3f7ed) | | hostId | | | id | 1a611deb-8560-43fb-a267-cf51c48da709 | | image | CentOS-6.5 (508db9d4-6c9f-459d-8782-065ee8b6f2c2) | | key_name | mykey | | metadata | {} | | name | kvm-server001 | | os-extended-volumes:volumes_attached | [] | | progress | 0 | | security_groups | default | | status | BUILD | | tenant_id | 65a0c00638c247a0a274837aa6eb165f | | updated | 2016-08-30T08:47:06Z | | user_id | b29da729de0b4ac2b3be9b519817a2b9 | +--------------------------------------+---------------------------------------------------+
查看创建的虚拟机,发现ip已经是固定的了! [root@openstack-server src]# nova list +--------------------------------------+---------------+--------+------------+-------------+--------------------+ | ID | Name | Status | Task State | Power State | Networks | +--------------------------------------+---------------+--------+------------+-------------+--------------------+ | 1a611deb-8560-43fb-a267-cf51c48da709 | kvm-server001 | ACTIVE | - | Running | flat=192.168.1.101 | | +--------------------------------------+---------------+--------+------------+-------------+--------------------+
创建好后,使用镜像里的root密码登陆虚拟机,发现ip是上面固定的ip了!
这个时候,也可以手动修改网卡配置:由dhcp修改成static静态方式。
然后重启网卡和虚拟机后,ip不会再变成其他的地址的~~
*********************************************************************************************
openstack私有云环境,在一个计算节点上创建的虚拟机,其实就是一个局域网内的机器群了。
虚拟机和宿主机之间/同一个节点下的虚拟机之间/虚拟机和宿主机同一内网段内的机器之间都是可以相互连接的,即能相互ping通
********************************************************************************************
如果不采用上述方法:即创建虚拟机的时候,不指定固定ip,默认用dhcp自动分配ip方式创建虚拟机。
特别注意: 如果创建虚拟机时不按照上面指定ip操作,那么创建虚拟机后,可登陆机器修改配置网卡文件,将dhcp方式改为static方式! 但是,ip不能修改为其他ip地址,必须修改为dhcp自动为其分配的地址! 要是修改为其他地址,则就和其他虚拟机和同网段内的机器ping不通了! 具体是什么原因导致以及解决方案,有待后续排查~~~
如下,虚拟机kvm-server005创建后,ip是dhcp自动分配的:192.168.1.123
登陆kvm-server005虚拟机本机进行修改:
[root@kvm-server005 ~]# cd /etc/sysconfig/network-scripts/ [root@kvm-server005 network-scripts]# cat ifcfg-eth0 DEVICE="eth0" BOOTPROTO="dhcp" IPV6INIT="yes" NM_CONTROLLED="yes" ONBOOT="yes" TYPE="Ethernet" UUID="db795113-37af-407a-9f78-62f49e26d5c2"
改为static静态ip方式
[root@kvm-server005 network-scripts]# cat ifcfg-eth0 DEVICE="eth0" BOOTPROTO="static" IPADDR=192.168.1.123 NETMASK=255.255.255.0 GATEWAY=192.168.1.17 IPV6INIT="yes" NM_CONTROLLED="yes" ONBOOT="yes" TYPE="Ethernet" UUID="db795113-37af-407a-9f78-62f49e26d5c2"
重启网卡,ip就改为静态ip了