Summary of installation

Step 0: Prerequisites

Step 1: Create Openstack hostsystem

Step 2: Config
Openstack host
system

: Install Openstackplatform

: Login Openstack

Step 5: Config to access external network

Step 0: Prerequisites

Software

·Red Hat Enterprise Linux (RHEL) 7is preferred. (e.g.CentOS-7-x86_64-Minimal-1611.iso, or the equivalent version of one of the
RHEL-based
Linux distributions such as CentOS, Scientific Linux, and so on. )
·x86_64 is currently the only supported architecture.
·VirtualBox 5.0.30

Hardware

·Machine: PC / Mac
·RAM: 6+GB
·Processors: 2 ~4(with hardware virtualization extensions)
·Network Adapter: 1+ (Cable MUST be connected to yourcomputer if using
Mac system.)

Step 1: Create Openstack host system

Make sure RAM size is bigger than 6GB

VDI is preferred.

Dynamically Allocation ispreferred.

Make sure Disk Size is greater than60GB.

2 ~ 4 processor is preferred.

Make sure following:

  • Only one Adapter is needed.
  • Adapter Type is “Bridge”.
  • Promiscuous Mode is “Allow All”.
  • Cable Connected is checked.

Make sure following:

  • Load CentOS installation image to the driver.

  1. Launch virtual instance we created just now.
  2. Install CentOS to the instance.
  3. Most of configuration could be proceed by clicking “Next” button with one exception that Ethernet Card Connection needs to be turn on in manually.

Step 2: Config OpenStack host system

  1. Reboot virtual instance after installation
  2. Log into instance with the correct credential info, such as root/root
  3. vi /etc/environment
    LANG=en_US.utf-8
    LC_ALL=en_US.utf-8
  4. source /etc/environment
  5. Turn off firewall:
systemctl disable firewalld
systemctl stop firewalld

(Note: Ignore the error message, such as “Failed to execute operation: Access denied”)

Step 3: Install Openstack platform

  1. yum install -y centos-release-openstack-newton

  2. yum update–y

  3. yum install -y openstack-packstack

  4. vi ~/.bash_profile

    export LANG="en_US.UTF-8”
    export LC_COLLATE="en_US.UTF-8”
    export LC_CTYPE="en_US.UTF-8”
    export LC_MESSAGES="en_US.UTF-8”
    export LC_MONETARY="en_US.UTF-8”
    export LC_NUMERIC="en_US.UTF-8”
    export LC_TIME="en_US.UTF-8”
    export LC_ALL="en_US.UTF-8”
  5. packstack --allinone--provision-demo=n --os-neutron-ovs-bridge-mappings=extnet:br-ex
    --os-neutron-ovs-bridge-interfaces=br-ex:eth0--os-neutron-ml2-type-drivers=vxlan,flat,vlan

Note:

  • Ensure “flat” and “vlan” have been added into ml2-type-drivers list.
  • Ensure eth0 is not your current network card which is using for yourssh connection.

Step 4: Login Openstack

  1. cat keystonerc_admin

    unset OS_SERVICE_TOKEN
    export OS_USERNAME=admin
    export OS_PASSWORD=98a76dc776654792
    exportOS_AUTH_URL=http://10.140.253.44:5000/v2.0
    export PS1='[\u@\h \W(keystone_admin)]\$'
    
    exportOS_TENANT_NAME=admin
    exportOS_REGION_NAME=RegionOne
  2. Log into openstack dashboard viahttp://10.140.253.XXX/dashboard (admin/98a76dc776654792)
  3. Start your openstackjourney.

Step 5: Config to access external network

5.1 Create Bridge

  1. vi /etc/sysconfig/network-scripts/ifcfg-br-ex
    DEVICE=br-ex
    DEVICETYPE=ovs
    TYPE=OVSBridge
    BOOTPROTO=static
    IPADDR=10.140.253.XXX# Old eth0 IP since we want the network restart to not
                 # kill the connection, otherwise pick something outside your dhcprange
    NETMASK=255.255.255.0  # your netmask
    GATEWAY=10.140.253.1 #yourgateway
    DNS1=123.123.123.XXX     #yournameserver
    ONBOOT=yes
  2. vi /etc/sysconfig/network-scripts/ifcfg-ethXXX
    DEVICE=ethXXX
    TYPE=OVSPort
    DEVICETYPE=ovs
    OVS_BRIDGE=br-ex
    ONBOOT=yes
  3. service network restart

5.2 Create External Network

  1. Log into dashboard via http://10.140.253.XXX/dashboard with
    your credential.

  2. Go to Admin->System->Networks

  3. Create a network with following info:

  4. Name:external_network

  5. Project:admin

  6. Provider Network Type: Flat

  7. Physical Network: extnet

  8. Segment ID: <any number>

  9. Admin State: UP

  10. Shared:checked

  11. External Network: checked

5.3 Create Subnet of External Network

  1. Subnet Name: <any string>
  2. Network Address: <any available range> e.g.10.140.253.100/28
  3. IP Version: IPv4
  4. Gateway IP: <same with your host gateway> e.g.
    10.140.253.1

  1. Uncheck DHCP
  2. Allocation Pools: <any avaliable range within your Network(10.140.253.100/28>
  3. DNS Name Servers: <your host DNS servers> e.g.123.123.123.123 , 8.8.8.8

5.4 Create Internal Network

  1. Name: private_network
  2. Project: admin
  3. Provider Network Type: VXLAN
  4. Physical Network: extnet
  5. Segment ID: <any number>.
  6. Admin State: UP
  7. Shared: checked
  8. External Network: unchecked

5.5 Create Subnet of Internal Network

  1. Subnet Name: <any string>
  2. Network Address: <any available range> e.g.192.168.100.0/24
  3. IP Version: IPv4

  1. Uncheck DHCP
  2. Allocation Pools: <any available range within your Network(192.168.100.0/24>
  3. DNS Name Servers: <your host DNS servers> e.g.123.123.123.123, 8.8.8.8

5.6 Create Router

  1. Router Name: <Any string>
  2. Admin State: UP
  3. External Network: external_network

5.7 Associate Networks

  1. Go back to Network Topology
  2. Click “Add Interface”

  1. IP Address: <gateway server ip of the internal network> e.g.192.168.100.1

5.8 Config Security Policy

  1. Go to Project -> Compute -> Access & Security
  2. Click“Manage Rules” button on “default” item.

  1. Remove all default rules.
  2. Recreate rules for protocals“ICMP”, “TCP” and “UDP” with both Ingress and Egress directions.

5.9 Create Instance

  1. Go back to Network Topology, you should see the external network and the private network are connected with a router
  2. Click“Launch Instance” button to create an vm

  1. Boot Source: Image
  2. Volume Size: <The min size of your image>
  3. Create New Volume: YES
  4. Delete Volume on Instance Delete:YES
  5. Allocated:<Your image> e.g. cirros

Choose appropriate flavor size.

e.g m1.tiny

Choose the network you want to create an instance on.

e.g. “private_network”

Choose the key pair which you want to used for logging into the instance later on.

Click “Launch Instance” to start instance.

Once the instance is created successfully, you should see the Power State is changed to “Running”.

5.10 Allocate Floating IP

  1. Click the instance drop-down list
  2. Click Associate Floating IP

  1. Click”+” button to creating an floating IP address in a specific Network.
  2. If it’s already done, you can also choose an
    avaliable IP address from the drop-down list.

  1. Choose the network you want to create an IP address on. (e.g. “External_network”)
  2. Click “Allocate IP”

  1. Choose the IP address we created just now.
  2. Click “Associate” button

Now, you should see 2 IP address havebeen associated with the instance.

One is for
private_network;another one (Floating IP) is forexternal_network.

5.11 Instance Login

  1. Click the Instance name and switch to “Console” tab. You could log into the instance.
  2. Type your credential info to login. e.g.cirros/cubswin:)

5.12 IP Binding

If you check the network information, you would find that there is no any IPv4 address bind to the instance.

Neither192.168.100.11, nor 10.140.253.100

Execute following 2 commands:

sudo ifconfig eth0 192.168.100.11 netmask 255.255.255.0
sudo route add default gw 192.168.100.1

Now, the private IP address has been associated with the instance.

        (We do not need to bind the public IP 10.140.253.100 here, because the HTTP requests will be transferred to the outside world by the router which is connected “private_network”
and “external_network”.

        More importantly, that is why10.140.253.100 is an floating IP, and how does it work.)


Ping 8.8.8.8 is OK.

However, Ping by domain name is not working.

e.g. ping www.google.com

sudo vi /etc/resolv.conf

nameserver 123.123.123.123
nameserver 8.8.8.8

Ping www.google.comis OK.

Ping the instance from ”external_network” is pass as well.

6 Useful Tools

# show current network info

ip a

# show current gateway info

route
netstat -rn

# show current network namespace

ipnet ns list

e.g. qrouter-bc826659-8f64-4f82-8f20-8fb76e3c5d9d

#execute command via specific network

ipnet ns exec qrouter-bc826659-8f64-4f82-8f20-8fb76e3c5d9d ping www.google.com

#bind specific ip to network interface

ifconfig eth0 192.168.100.11 netmask 255.255.255.0

#add default gateway route

route add default gw 192.168.100.1

Reference:

http://www.learnlinux.org.za/courses/build/net-admin/ch01s11.html

https://www.rdoproject.org/install/quickstart/

https://www.rdoproject.org/networking/neutron-with-existing-external-networ

Openstack: Single node Installation and External Network Accessing Configuration Guide的更多相关文章

  1. Devstack single node Installation on VM

    Last three days, I want to install devstack on my virtual machine on Vmware Workstation.The VM'syste ...

  2. RDO Stack:VMs cannot access external network.

    Issue: There are many root causes to make your openstack vm instances cannot be reached from externa ...

  3. Hadoop MapReduce Next Generation - Setting up a Single Node Cluster

    Hadoop MapReduce Next Generation - Setting up a Single Node Cluster. Purpose This document describes ...

  4. Hadoop Single Node Setup(hadoop本地模式和伪分布式模式安装-官方文档翻译 2.7.3)

    Purpose(目标) This document describes how to set up and configure a single-node Hadoop installation so ...

  5. Setting up a Single Node Cluster Hadoop on Ubuntu/Debian

    Hadoop: Setting up a Single Node Cluster. Hadoop: Setting up a Single Node Cluster. Purpose Prerequi ...

  6. [原]openstack-kilo--issue(二十)External network cannot is not reachable associate Port

    issue==== INFO neutron.api.v2.resource [req-79a36d02-114b--b9ed-0a10c6d69451 ] update failed (client ...

  7. Installing Apache Hadoop Single Node

    转载请注明出处:http://www.cnblogs.com/wubdut/p/4681286.html platform: Ubuntu 14.04 LTS hadoop 1.2.1 1. inst ...

  8. 4.创建OpenStack的node环境脚本

    创建OpenStack的node环境脚本 使用source admin-openrc.sh来运行脚本 在任意目录下创建admin-openrc.sh文件 vim ~/admin-openrc.sh e ...

  9. all rows from client_id can grow infinitely compared to a single node when hashing by client_id

    all rows from client_id can grow infinitely compared to a single node when hashing by client_id Re: ...

随机推荐

  1. 工作笔记 | Visual Studio 调用 Web Service

    引言 最近笔者负责ERP财务系统跟中粮集团财务公司的财务系统做对接,鉴于ERP系统中应付结算单结算量比较大,而且管理相对集中,ERP系统与中粮财务公司的支付平台系统对接,实现银企直联,将网银录入的环节 ...

  2. PhantomJS命令行选项

    支持命令行选项有: --help或-h列出所有可能的命令行选项.立即停止,不会运行一个脚本作为参数传递. --version或-v打印的版本PhantomJS.立即停止,不会运行一个脚本作为参数传递. ...

  3. MySQL导致错误的语句

    主键不唯一 由于表定义中创建了主键约束,因此MySQL将会确保重复主键不会被插入到数据表中. INSERT INTO person (person_id, fname, lname, gender, ...

  4. [LeetCode] Basic Calculator III 基本计算器之三

    Implement a basic calculator to evaluate a simple expression string. The expression string may conta ...

  5. servlet与ajax数据交换(json格式)

    JSON数据格式: JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成. 它基于的一个子集. JSON采用完全独 ...

  6. Mysql中的常用函数:

    Mysql中的常用函数: 1.字符串函数: (1).合并字符串 concat():// concat('M','y',"SQL",'5.5');== MySQL5.5//当传入的参 ...

  7. POJ 3233 (矩阵)

    题意:对于矩阵A,求A^1 + ...... + A^k 按照矩阵十大经典题的思路大致做了下. 在k为奇数时:  A^( k / 2+1)+ 1) * (A^1 + ....... A^(k/2)) ...

  8. 51Nod 1555 布丁怪

    题目描述: 布丁怪这一款游戏是在一个n×n 的矩形网格中进行的,里面有n个网格有布丁怪,其它的一些格子有一些其它的游戏对象.游戏的过程中是要在网格中移动这些怪物.如果两个怪物碰到了一起,那么他们就会变 ...

  9. VK-Cup2017 Wild Card Round 2

    来自FallDream的博客,未经允许,请勿转载,谢谢. Cf的Vkcup外卡赛2  上次round2和ditoly翻车了 所以只好来打打了  规则是给一道比较特殊的题目,你要找出较优的解 Unive ...

  10. bzoj1132[POI2008]Tro 计算几何

    1132: [POI2008]Tro Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 1722  Solved: 575[Submit][Status] ...