Openstack平臺搭建之次日node
Author by xxbAndy.python
If you have any question ,please contact me by weichuangxxb@sina.cn or 371990778(qq).
mysql
環境準備:
RHEL6.5 內存4G 硬盤70G
yum源的制定(分別制定三個yum源,其中前面三個是本身本地定製的yum源)
baseurl=ftp://instructor.example.com/pub/rhel6.5/Server
baseurl=ftp://instructor.example.com/pub/errata
baseurl=http://instructor.example.com/pub/OpenStack/
baseurl=ftp://ftp.redhat.com/pub/redhat/linux/enterprise/$releasever/en/os/SRPMS/
baseurl=ftp://ftp.redhat.com/pub/redhat/linux/beta/$releasever/en/os/SRPMS/
#yum update -y ; reboot
第一節:qpid通訊節點安裝
2.安裝qpid
[root@server10 ~]# yum install -y qpid-cpp-server qpid-cpp-server-ssl cyrus-sasl-md5
3.建立用戶 -f制定密碼文件 -u 制定用戶信息 以及db信息
[root@server10 ~]# saslpasswd2 -f /var/lib/qpidd/qpidd.sasldb -u QPID qpidauth
[root@server10 ~]# sasldblistusers2 -f /var/lib/qpidd/qpidd.sasldb
qpidauth@QPID: userPassword
4.建立認證文件 acl(默認不存在)
[root@server10 ~]# echo 'acl allow qpidauth@QPID all all' > /etc/qpid/qpidauth.acl
5.讀取acl文件 後臺進程qpidd
[root@server10 ~]# echo "QPIDD_OPTIONS='--acl-file /etc/qpid/qpidauth.acl'" >> /etc/sysconfig/qpidd
6.修改權限
root@server10 ~]# chown qpidd /etc/qpid/qpidauth.acl
[root@server10 ~]# chmod 600 /etc/qpid/qpidauth.acl
7.修改/etc/qpidd.conf
cluster-mechanism=DIGEST-MD5
auth=yes
8.建立獨立的pki(目錄權限)
[root@server10 ~]# mkdir /etc/pki/tls/qpid
[root@server10 ~]# chmod 700 /etc/pki/tls/qpid/
[root@server10 ~]# chown qpidd /etc/pki/tls/qpid/
查看qpidd用戶(在安裝軟件的時候已經建立了)
9.增長密碼和權限
[root@server10 ~]# echo westos > /etc/qpid/qpid.pass
[root@server10 ~]# chmod 600 /etc/qpid/qpid.pass
[root@server10 ~]# chown qpidd /etc/qpid/qpid.pass
10.生成認證證書(certutil)
[root@server10 ~]# echo $HOSTNAME
server10.example.com
[root@server10 ~]# certutil -N -d /etc/pki/tls/qpid/ -f /etc/qpid/qpid.pass
注意查看/etc/pki/tls/qpid/目錄下生成的文件(權限沒有哦)
11制定加密序列 -n制定全主機名 (注意生成文件的權限)
[root@server10 ~]# certutil -S -d /etc/pki/tls/qpid/ -n server10.example.com -s "CN=server10.example.com" -t "CT,," -x -f /etc/qpid/qpid.pass -z /usr/bin/certutil
[root@server10 tls]# chown -R qpidd qpid/
12.在主配置文件中制定相關的db,name以及pd
(啓動qpidd後進行查看日誌)
[root@server10 ~]#vim /etc/qpidd.conf
ssl-cert-db=/etc/pki/tls/qpid
ssl-cert-name=server10.example.com
ssl-cert-password-file=/etc/qpid/qpid.pass
require-encryption=yes
[root@server10 ~]# /etc/init.d/qpidd restart
[root@server10 ~]# tail -f /var/log/messages 顯示正在running(h好像有個密碼錯誤啊)
[root@server10 ~]# chkconfig qpidd on
################
第二節:身份識別系統:identity(全局使用)
1.安裝keystone以及相關
[root@server10 ~]# yum install openstack-keystone openstack-selinux openstack-utils -y
2.初始話服務,向數據庫中導入db文件(默認不會安裝mysql'服務)
[root@server10 ~]# openstack-db --init --service keystone 須要安裝mysql服務並進行配置
3.建立keystone用戶和密碼(其實就是向數據庫導入文件,也能夠本身使用openssl導入)
[root@server10 ~]# keystone-manage pki_setup --keystone-user keystone --keystone-group keystone
4.修改相應ssl的權限(/etc/keystone/ssl)
[root@server10 ~]# chown -R keystone:keystone /etc/keystone/ssl/
5.生成認證文件而且額導入:
[root@server10 ~]# openssl rand -hex 10 使用openssl加密前10
a030068247b339b52f37
[root@server10 ~]# echo a030068247b339b52f37 > /root/ks_admin_token
[root@server10 ~]# cat ks_admin_token
a030068247b339b52f37
[root@server10 ~]# export SERVICE_TOKEN=a030068247b339b52f37
6.導入到文件
[root@server10 ~]# export SERVICE_ENDPOINT=http://server10.example.com:35357/v2.0
7.配置keystone文件
[root@server10 ~]# openstack-config --set /etc/keystone/keystone.conf DEFAULT admin_token $SERVICE_TOKEN
[root@server10 ~]# vim /etc/keystone/keystone.conf (刪除一個default)
8.啓動keystone(開機啓動)
[root@server10 ~]# /etc/init.d/openstack-keystone restart
[root@server10 ~]# chkconfig openstack-keystone on
注意:啓動後注意查看有沒有報錯啊,查看啓動端口
[root@server10 ~]# grep ERROR /var/log/keystone/keystone.log
9.建立keystone服務(id)
[root@server10 ~]# keystone service-create --name=keystone --type=identity --description="keystone identity service"
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| description | keystone identity service |
| id | 5a1d8b6901f6450fa5b063e6a002601c |
| name | keystone |
| type | identity |
+-------------+----------------------------------+
注意:ID惟一哦
10.建立接口(外部 內部 管理接口)
[root@server10 ~]# keystone endpoint-create --service-id 5a1d8b6901f6450fa5b063e6a002601c \
> --publicurl 'http://server10.example.com:5000/v2.0' \
> --adminurl 'http://server10.example.com:35357/v2.0' \
> --internalurl 'http://server10.example.com:5000/v2.0'
+-------------+----------------------------------------+
| Property | Value |
+-------------+----------------------------------------+
| adminurl | http://server10.example.com:35357/v2.0 |
| id | 714dbd31a3bd45feafa7ca3539525fb2 |
| internalurl | http://server10.example.com:5000/v2.0 |
| publicurl | http://server10.example.com:5000/v2.0 |
| region | regionOne |
| service_id | 5a1d8b6901f6450fa5b063e6a002601c |
+-------------+----------------------------------------+
11.建立用戶,角色,tenant(租戶)
[root@server10 ~]# keystone user-create --name admin --pass westos
+----------+----------------------------------+
| Property | Value |
+----------+----------------------------------+
| email | |
| enabled | True |
| id | f90b1ed5677a42b0b70544367d804222 |
| name | admin |
+----------+----------------------------------+
[root@server10 ~]# keystone role-create --name admin
+----------+----------------------------------+
| Property | Value |
+----------+----------------------------------+
| id | ab686060308d470887911c19a8c011b4 |
| name | admin |
+----------+----------------------------------+
[root@server10 ~]# keystone tenant-create --name admin
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| description | |
| enabled | True |
| id | b4aa48fd47724a19a9e09eeb1d8199df |
| name | admin |
+-------------+----------------------------------+
12.用戶角色添加(關聯上述的用戶)
[root@server10 ~]# keystone user-role-add --user admin --role admin --tenant admin
13.編輯kestone管理文件(本身建立)
[root@server10 ~]# vim /root/keystonerc_admin
export OS_USERNAME=admin
export OS_TENANT_NAME=admin
export OS_PASSWORD=westos
export OS_AUTH_URL=http://server10.example.com:35357/v2.0/
export PS1='[\u@\h \W(keystone_admin)]\$ '
14.清除配置,同時加載keystone加載到裏面;顯示keystone用戶
[root@server10 ~]# unset SERVICE_TOKEN
[root@server10 ~]# unset SERVICE_ENDPOINT
[root@server10 ~]# source /root/keystonerc_admin
[root@server10 ~(keystone_admin)]# keystone user-list
+----------------------------------+-------+---------+-------+
| id | name | enabled | email |
+----------------------------------+-------+---------+-------+
| f90b1ed5677a42b0b70544367d804222 | admin | True | |
+----------------------------------+-------+---------+-------+
第三節 swift 存儲(在主機上添加兩塊盤)
1.安裝swift存儲代理,賬號以及容器
[root@server10 ~(keystone_admin)]# yum install -y openstack-swift-proxy openstack-swift-object openstack-swift-container openstack-swift-account memcached -y
2.建立用戶以及tenant(記住全部名字同樣service)
[root@server10 ~(keystone_admin)]# keystone user-create --name swift --pass westos
+----------+----------------------------------+
| Property | Value |
+----------+----------------------------------+
| email | |
| enabled | True |
| id | 2e86f4f604cd4edaa535caf8f19af9db |
| name | swift |
+----------+----------------------------------+
[root@server10 ~(keystone_admin)]# keystone tenant-create --name services
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| description | |
| enabled | True |
| id | 4dd069c858834df99733119353d1c822 |
| name | services |
+-------------+----------------------------------+
3.關聯用戶之間關係
[root@server10 ~(keystone_admin)]# keystone user-role-add --role admin --tenant services --user swift
4.服務建立
[root@server10 ~(keystone_admin)]# keystone service-create --name swift --type object-store --description "swift storage service"
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| description | swift storage service |
| id | 970407c1c93248a3abe25e59e3da9108 |
| name | swift |
| type | object-store |
+-------------+----------------------------------+
5.定義認證的URL:
[root@server10 ~(keystone_admin)]# keystone endpoint-create --service-id 970407c1c93248a3abe25e59e3da9108 \
> --publicurl "http://server10.example.com:8080/v1/AUTH_%(tenant_id)s" \
> --adminurl "http://server10.example.com:8080/v1/AUTH_%(tenant_id)s" \
> --internalurl "http://server10.example.com:8080/v1/AUTH_%(tenant_id)s"
+-------------+--------------------------------------------------------+
| Property | Value |
+-------------+--------------------------------------------------------+
| adminurl | http://server10.example.com:8080/v1/AUTH_%(tenant_id)s |
| id | 2f5a84921b3f4d2ba067f5dec2d9b529 |
| internalurl | http://server10.example.com:8080/v1/AUTH_%(tenant_id)s |
| publicurl | http://server10.example.com:8080/v1/AUTH_%(tenant_id)s |
| region | regionOne |
| service_id | 970407c1c93248a3abe25e59e3da9108 |
+-------------+--------------------------------------------------------+
6.查找盤符,而且建立主分區
[root@server10 ~(keystone_admin)]# fdisk -cu /dev/vdb
[root@server10 ~(keystone_admin)]# fdisk -cu /dev/vdc
7.格式化分區 而且開機自動掛在(記得操做以前對文件進行備份)
[root@server10 ~(keystone_admin)]# mkfs.ext4 /dev/vdb1
[root@server10 ~(keystone_admin)]# mkfs.ext4 /dev/vdc1
[root@server10 ~(keystone_admin)]# mkdir -p /srv/node/z{1,2}d1
[root@server10 etc(keystone_admin)]# cat /etc/fstab
/dev/vdb1 /srv/node/z1d1 ext4 acl,user_xattr 0 0
/dev/vdc1 /srv/node/z2d1 ext4 acl,user_xattr 0 0
[root@server10 etc(keystone_admin)]# mount -a
8.編輯目錄權限
[root@server10 node(keystone_admin)]# chown -R swift:swift /srv/node/
9.編輯安全上下文
[root@server10 node(keystone_admin)]# restorecon -Rv /srv/
將安全上下文轉換成的類型修改成swift類型格式(能夠實時查看)
10.編輯配置文件(能夠將裏面的文件都備份下/etc/swift/swift.conf(account/container/object))
[root@server10 node(keystone_admin)]# openssl rand -hex 10
ed7addafe2a3477d5e92
[root@server10 node(keystone_admin)]# cat /etc/swift/swift.conf
[swift-hash]
swift_hash_path_prefix = ed7addafe2a3477d5e92
swift_hash_path_suffix = ed7addafe2a3477d5e92
將三個文件的bind-ip改成本身的ip(192.168.0.110)
#vim /etc/swift/container-server.conf
#vim /etc/swift/account-server.conf
#vim /etc/swift/object-server.conf
11.啓動三個服務(開機自動啓動)
[root@server10 node(keystone_admin)]# chkconfig openstack-swift-container on
[root@server10 node(keystone_admin)]# chkconfig openstack-swift-object on
[root@server10 node(keystone_admin)]# chkconfig openstack-swift-account on
12.測試
Configure Swift Object Storage Service Rings
使用三個命令建立三個builder
[root@server10 node(keystone_admin)]# swift-ring-builder /etc/swift/account.builder create 12 2 1
[root@server10 node(keystone_admin)]# swift-ring-builder /etc/swift/container.builder create 12 2 1
[root@server10 node(keystone_admin)]# swift-ring-builder /etc/swift/object.builder create 12 2 1
執行下面命令:(有警告啊)
#for i in 1 2 ; do swift-ring-builder /etc/swift/account.builder add z${i}-192.168.0.110:6002/z${i}d1 100; done
#for i in 1 2 ; do swift-ring-builder /etc/swift/object.builder add z${i}-192.168.0.110:6000/z${i}d1 100; done
#for i in 1 2 ; do swift-ring-builder /etc/swift/container.builder add z${i}-192.168.0.110:6001/z${i}d1 100; done
12.1使用swift-ring-builder建立負載
[root@server10 node(keystone_admin)]# swift-ring-builder /etc/swift/object.builder rebalance
[root@server10 node(keystone_admin)]# swift-ring-builder /etc/swift/container.builder rebalance
[root@server10 node(keystone_admin)]# swift-ring-builder /etc/swift/account.builder rebalance
[root@server10 node(keystone_admin)]# chown -R root:swift /etc/swift/
13.啓動代理服務
Deploy the Swift Object Storage Proxy Service
13.1編輯代理文件(procy-server.conf備份哦本身編寫)
[root@server10 node(keystone_admin)]# vim /etc/swift/proxy-server.conf
[filter:authtoken]
admin_tenant_name = services 注意名字的編寫哦
admin_user = swift
admin_password = westos
auth_host = 192.168.0.110
#############
13.2啓動memcached和openstack-swift-proxy(記住開機自動啓動)
[root@server10 ~(keystone_admin)]# /etc/init.d/memcached start;/etc/init.d/openstack-swift-proxy start
[root@server10 ~(keystone_admin)]#chkconfig memcached on;chkconfig openstack-swift-proxy on
14.建立容器:
Validate the Swift Object Storage
Configuration
14.1 截取1024的文件,並放置到對象存儲區域(容器裏面)
注意:必須得在/etc/swift目錄嗎 (必須的,由於是在上傳目錄啊發佈目錄)
問題:在第一次作的時候不當心把filter_authtoken
一個一個建立文件哦
[root@server10 swift(keystone_admin)]# head -c 1024 /dev/urandom > data(1,2,3).file (爲了測試分別建立多個data文件實際分別建立)
#swift upload c1 data1.file 直接建立容器CX並上傳文件
#swift upload c1 data2.file
#swift upload c1 data3.file
#swift upload c2 data3.file
#swift upload c3 data3.file
# swift list 能夠查看生成的三個容器(c1 c2 c3)
# swift list c1 查看c1容器存放的數據
# swift delete c3 刪除容器
# swift delete c1 data3.file 刪除容器裏面的對象
詳情能夠查看swift --help
建立區域:swift upload c1 data1.file
c指的是容器
接着在/srv/node下查看,其實兩塊存儲存放的東西是同樣的(z1d1和z2d2)
/srv/node/z2d1/objects
第四節 :配置Glance Image服務
1.安裝openstack-glance軟件
[root@server10 ~(keystone_admin)]# yum install -y openstack-glance
2.編輯配置文件
[root@server10 ~(keystone_admin)]#cp /etc/glance/glance-registry.conf /etc/glance/glance-registry.conf.orig
[root@server10 ~(keystone_admin)]# cp /etc/glance/glance-api.conf /etc/glance/glance-api.conf.orig
拷貝新的配置文件
# cp /usr/share/glance/glance-registry-dist.conf /etc/glance/glance-registry.conf
3.初始化glance服務,建立密碼(經過mysql使用上面的追加)
[root@server10 ~(keystone_admin)]# openstack-db --init --service glance --password westos --rootpw westos
能夠登陸mysql進行查看相關的數據庫
4.建立用戶以及關聯用戶關係
[root@server10 ~(keystone_admin)]# keystone user-create --name glance --pass westos
+----------+----------------------------------+
| Property | Value |
+----------+----------------------------------+
| email | |
| enabled | True |
| id | 41be9c4c80b74ec4bc9df05636859985 |
| name | glance |
+----------+----------------------------------+
[root@server10 ~(keystone_admin)]# keystone user-role-add --user glance --role admin --tenant services
5.編輯glance相關配置文件glance-api.conf
[root@server10 ~(keystone_admin)]# vim /etc/glance/glance-api.conf
[paste_deploy]
flavor = keystone 認證方式
[keystone_authtoken] 配置認證方式
admin_tenant_name=services
admin_user=glance
admin_password=westos
[DEFAULT]
qpid_hostname = localhost 若是apid在遠端能夠增長IP
qpid_username = qpidauth
qpid_password = westos
qpid_port = 5671
qpid_protocol = ssl (5671是通常的加密接口)
6.編輯配置文件/etc/glance/glance-registry.conf
[paste_deploy]
flavor = keystone (沒空格不影響吧)
[keystone_authtoken]
admin_tenant_name = services
admin_user = glance
admin_password = westos
7.啓動兩個服務glance-api glance-registry
#chkconfig openstack-glance-api on
#chkconfig openstack-glance-registry on
查看日誌,但願不要有錯誤 啊
# egrep 'ERROR|CRITICAL' /var/log/glance/*
/var/log/glance/api.log:2014-07-30 14:09:13.298 21918 ERROR glance.store.sheepdog [-] Error in store configuration: Unexpected error while running command.
查看有一個牧羊犬錯誤,能夠先不要管他
8.新建一個glance服務
[root@server10 ~(keystone_admin)]# keystone service-create --name glance --type image --description "glance image service"
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| description | glance image service |
| id | a5806eaa7c4f4b0bac077d344b3e8c3f |
| name | glance |
| type | image |
+-------------+----------------------------------+
9.建立一個endpoint的URL
[root@server10 ~(keystone_admin)]# keystone endpoint-create --service-id a5806eaa7c4f4b0bac077d344b3e8c3f \
> --publicurl http://server10.example.com:9292 \
> --adminurl http://server10.example.com:9292 \
> --internalurl http://server10.example.com:9292
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| adminurl | http://server10.example.com:9292 |
| id | 53bdf3b884724675bf9da11791bc1fbe |
| internalurl | http://server10.example.com:9292 |
| publicurl | http://server10.example.com:9292 |
| region | regionOne |
| service_id | a5806eaa7c4f4b0bac077d344b3e8c3f |
+-------------+----------------------------------+
10.上傳鏡像:Use glance to Upload a System Image
[root@server10 ~(keystone_admin)]# glance image-create --name xxb --is-public True --disk-format qcow2 --container-format bare --copy-from http://192.168.0.254/pub/materials/small.img
+------------------+--------------------------------------+
| Property | Value |
+------------------+--------------------------------------+
| checksum | None |
| container_format | bare |
| created_at | 2014-07-30T06:33:15 |
| deleted | False |
| deleted_at | None |
| disk_format | qcow2 |
| id | dd5135b4-c2ce-4c66-8b73-454705b2a310 |
| is_public | True |
| min_disk | 0 |
| min_ram | 0 |
| name | xxb |
| owner | b4aa48fd47724a19a9e09eeb1d8199df |
| protected | False |
| size | 92908032 |
| status | queued |
| updated_at | 2014-07-30T06:33:15 |
+------------------+--------------------------------------+
10.1查看鏡像信息
[root@server10 ~(keystone_admin)]# glance image-list
+--------------------------------------+---------+-------------+------------------+-----------+--------+
| ID | Name | Disk Format | Container Format | Size | Status |
+--------------------------------------+---------+-------------+------------------+-----------+--------+
| dd5135b4-c2ce-4c66-8b73-454705b2a310 | xxb | qcow2 | bare | 92908032 | active |
| 1e08ab41-58ed-457d-994e-5f8607f5bb67 | xxbandy | qcow2 | bare | 258146304 | active |
+--------------------------------------+---------+-------------+------------------+-----------+--------+
10.2刪除鏡像
[root@server10 ~(keystone_admin)]#glance delete ID
[root@server10 ~(keystone_admin)]# glance image-show xxb 查看xxb鏡像詳細信息
第五節:建立塊存儲,用來給雲主機掛在使用的a
1.安裝塊存儲軟件:
[root@server10 ~(keystone_admin)]# yum install -y openstack-cinder
[root@server10 ~(keystone_admin)]#cp /etc/cinder/cinder.conf /etc/cinder/cinder.conf.bak
[root@server10 ~(keystone_admin)]#cp /usr/share/cinder/cinder-dist.conf /etc/cinder/cinder.conf
2.初始化
[root@server10 ~(keystone_admin)]# openstack-db --init --service cinder --password westos --rootpw westos
# openstack-db --drop --service cinder 若是初始化錯誤可使用這個刪除cinder(從新執行)
3.建立相應的用戶以及關聯用戶
[root@server10 ~(keystone_admin)]# keystone user-create --name cinder --pass westos
+----------+----------------------------------+
| Property | Value |
+----------+----------------------------------+
| email | |
| enabled | True |
| id | 912094d6e8c54864aa2606a13daae1c9 |
| name | cinder |
+----------+----------------------------------+
[root@server10 ~(keystone_admin)]# keystone user-role-add --user cinder --role admin --tenant services
4.建立卷組
[root@server10 ~(keystone_admin)]# keystone service-create --name=cinder --type=volume --description="openstack block storage service"
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| description | openstack block storage service |
| id | f8fbbcec6c864ac588f70ee396bb55da |
| name | cinder |
| type | volume |
+-------------+----------------------------------+
5.建立cinder的URL
[root@server10 ~(keystone_admin)]# keystone endpoint-create --service-id f8fbbcec6c864ac588f70ee396bb55da --publicurl 'http://server10.example.com:8776/v1/%(tenant_id)s' --adminurl 'http://server10.example.com:8776/v1/%(tenant_id)s' --internalurl 'http://server10.example.com:8776/v1/%(tenant_id)s'
+-------------+---------------------------------------------------+
| Property | Value |
+-------------+---------------------------------------------------+
| adminurl | http://server10.example.com:8776/v1/%(tenant_id)s |
| id | 3116d4a05f2a4dac8dd712b10aaf4d09 |
| internalurl | http://server10.example.com:8776/v1/%(tenant_id)s |
| publicurl | http://server10.example.com:8776/v1/%(tenant_id)s |
| region | regionOne |
| service_id | f8fbbcec6c864ac588f70ee396bb55da |
+-------------+---------------------------------------------------+
6..備份配置文件,而且進行修改內存
[root@server10 ~(keystone_admin)]# cp /etc/cinder/cinder.conf /etc/cinder/cinder.conf.orig
[root@server10 ~(keystone_admin)]# cp /usr/share/cinder/cinder-dist.conf /etc/cinder/cinder.conf
[root@server10 ~(keystone_admin)]#vim /etc/cinder/cinder.conf
[keystone_authtoken]
admin_tenant_name = services
admin_user = cinder
admin_password = westos
[DEFAULT]
qpid_username = qpidauth
qpid_password = westos
qpid_protocol = ssl
qpid_port = 5671
7.啓動服務並開機子啓動
[root@server10 ~(keystone_admin)]# /etc/init.d/openstack-cinder-scheduler start
[root@server10 ~(keystone_admin)]#/etc/init.d/openstack-cinder-api start
[root@server10 ~(keystone_admin)]# /etc/init.d/openstack-cinder-volume start
8.配置共享存儲iscsi
echo 'include /etc/include/volumes/*' >> /etc/tgt/targets.conf
[root@server10 ~(keystone_admin)]## /etc/init.d/tgtd start
[root@server10 ~(keystone_admin)]##chkconfig tgtd on
9.查看openstack的總體狀態
[root@server10 ~(keystone_admin)]## openstack-status
== Glance services ==
openstack-glance-api: active
openstack-glance-registry: active
== Keystone service ==
== Keystone users ==
Authorization Failed: Unable to establish connection to http://server10.example.com:35357/v2.0/tokens
== Glance images ==
Authorization Failed: Unable to establish connection to http://server10.example.com:35357/v2.0/tokens
若是正常應該沒有問題的(其實在配置過程當中常常也會出現不能tokens這個問題,持續等待也許會好的。本身在作的時候也常常出現這個問題,也許就是靠人品咯)
10.建立一個卷組vol1 2G(測試邏輯卷的應用)
使用cinder工具建立一個名爲vol1的邏輯卷大小2G
[root@server10 ~(keystone_admin)]# cinder create --display-name vol1 2
+---------------------+--------------------------------------+
| Property | Value |
+---------------------+--------------------------------------+
| attachments | [] |
| availability_zone | nova |
| bootable | false |
| created_at | 2014-07-30T08:03:05.551543 |
| display_description | None |
| display_name | vol1 |
| id | 7d8bde6b-4d83-439d-839a-1f9d5974d94c |
| metadata | {} |
| size | 2 |
| snapshot_id | None |
| source_volid | None |
| status | creating |
| volume_type | None |
+---------------------+--------------------------------------+
11.查看當前的邏輯卷大小
[root@server10 ~(keystone_admin)]#vgs
[root@server10 ~(keystone_admin)]# vgs
VG #PV #LV #SN Attr VSize VFree
cinder-volumes 1 1 0 wz--n- 4.97g 2.97g
vol0 1 2 0 wz--n- 29.97g 0
只要卷組是cinder的話就能夠識別。在部署應答文件時裏面就有一個塊存儲的卷20G
#cinder list
#################
第六節 網絡配置
1.建立網絡
[root@server10 ~(keystone_admin)]# keystone service-create --name neutron --type network --description 'networking service'
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| description | networking service |
| id | ffc971e1288e48df85a56291ddd9c621 |
| name | neutron |
| type | network |
+-------------+----------------------------------+
2.指定相應的URL
[root@server10 ~(keystone_admin)]# keystone endpoint-create --service-id ffc971e1288e48df85a56291ddd9c621 \
> --publicurl http://server10.example.com:9696 \
> --adminurl http://server10.example.com:9696 \
> --internalurl http://server10.example.com:9696
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| adminurl | http://server10.example.com:9696 |
| id | 2af628a5043a4bb1ab7e5990305c7a84 |
| internalurl | http://server10.example.com:9696 |
| publicurl | http://server10.example.com:9696 |
| region | regionOne |
| service_id | ffc971e1288e48df85a56291ddd9c621 |
+-------------+----------------------------------+
3.建立用戶以及關聯相關
[root@server10 ~(keystone_admin)]# keystone user-create --name neutron --pass westos
+----------+----------------------------------+
| Property | Value |
+----------+----------------------------------+
| email | |
| enabled | True |
| id | e8a059a320ef4ed5973bb245e56ceb67 |
| name | neutron |
+----------+----------------------------------+
[root@server10 ~(keystone_admin)]# keystone user-role-add --user neutron --role admin --tenant services
4.查看用戶
[root@server10 ~(keystone_admin)]# keystone user-role-list
+----------------------------------+-------+----------------------------------+----------------------------------+
| id | name | user_id | tenant_id |
+----------------------------------+-------+----------------------------------+----------------------------------+
| ab686060308d470887911c19a8c011b4 | admin | f90b1ed5677a42b0b70544367d804222 | b4aa48fd47724a19a9e09eeb1d8199df |
+----------------------------------+-------+----------------------------------+----------------------------------+
[root@server10 ~(keystone_admin)]# keystone --os-username neutron --os-password westos --os-tenant-name services user-role-list
+----------------------------------+-------+----------------------------------+----------------------------------+
| id | name | user_id | tenant_id |
+----------------------------------+-------+----------------------------------+----------------------------------+
| 59d0d13373894bcdb8ad06852a620117 | admin | e8a059a320ef4ed5973bb245e56ceb67 | 3a4b064f7782481fbde472d25d3e496f |
+----------------------------------+-------+----------------------------------+----------------------------------+
5.安裝networking軟件包
[root@server10 neutron(keystone_admin)]# yum install -y openstack-neutron openstack-neutron-openvswitch
查看下qpidd的狀態
6.配置主要文件:
[root@server10 neutron(keystone_admin)]# vim /etc/neutron/neutron.conf
[DEFAULT]
rpc_backend=neutron.openstack.common.rpc.impl_qpid
qpid_hostname = 192.168.0.110
qpid_port = 5671
qpid_username = qpidauth
qpid_password = westos
qpid_protocol = ssl
[keystone_authtoken]
admin_tenant_name = services
admin_user = neutron
admin_password = westos
[agent]
root_helper = sudo neutron-rootwrap /etc/neutron/rootwrap.conf
7.編輯配置文件(用戶admin文件cp後修改)
[root@server10 ~(keystone_admin)]# cat /root/keystonerc_neutron
export OS_USERNAME=neutron 修改
export OS_TENANT_NAME=services 修改
export OS_PASSWORD=westos
export OS_AUTH_URL=http://server10.example.com:35357/v2.0/
export PS1='[\u@\h \W(keystone_neutron)]\$ '
8.切換到網絡用戶neutron
[root@server10 ~(keystone_neutron)]# yum install openstack-nova-common -y
[root@server10 ~(keystone_neutron)]# neutron-server-setup --yes --rootpw westos --plugin openvswitch
[root@server10 ~(keystone_neutron)]# neutron-db-manage --config-file /usr/share/neutron/neutron-dist.conf --config-file /etc/neutron/neutron.conf --config-file /etc/neutron/plugin.ini stamp head
No handlers could be found for logger "neutron.common.legacy" 好像有錯啊(不過沒有直接報錯能夠不用管)
9.開啓服務
[root@server10 ~(keystone_neutron)]# /etc/init.d/neutron-server start
[root@server10 ~(keystone_neutron)]# chkconfig neutron-server on
[root@server10 ~(keystone_neutron)]# openstack-status 發現nova沒有啓動,networking沒有啓動。繼續下面的配置吧
10.配置網絡
[root@server10 ~(keystone_neutron)]# neutron-node-setup --plugin openvswitch -qhost 192.168.0.110
[root@server10 ~(keystone_neutron)]# /etc/init.d/openvswitch start(chkconfig openvswitch on)
11.配置接口(br-ex br-int)
[root@server10 ~(keystone_neutron)]# ovs-vsctl add-br br-int
(ovs-vsctl show 查看網絡接口)
[root@server10 ~(keystone_neutron)]# vim /etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini
integration_bridge = br-int
[root@server10 ~(keystone_neutron)]# /etc/init.d/neutron-openvswitch-agent start
Starting neutron-openvswitch-agent: [ OK ]
[root@server10 ~(keystone_neutron)]# chkconfig neutron-openvswitch-agent on
[root@server10 ~(keystone_neutron)]# chkconfig neutron-ovs-cleanup on
[root@server10 ~(keystone_neutron)]# neutron-dhcp-setup --plugin openvswitch --qhost 192.168.0.110
[root@server10 ~(keystone_neutron)]# /etc/init.d/neutron-dhcp-agent start
Starting neutron-dhcp-agent: [ OK ]
[root@server10 ~(keystone_neutron)]# chkconfig neutron-dhcp-agent on
注意在查看dhcp時有錯誤:
[root@server10 ~(keystone_admin)]# egrep 'ERROR|CRITICAL' /var/log/neutron/dhcp-agent.log
2014-08-02 13:36:31.633 25212 ERROR neutron.common.legacy [-] Skipping unknown group key: firewall_driver
顯示的是firewall的錯誤,並非咱們的服務問題哦
11.1配置對外接口
#ovs-vsctl add-br br-ex
#cp /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/sysconfig/network-scripts/ifcfg-br-ex
#vim /etc/sysconfig/network-scripts/ifcfg-eth0 (3條:設備名;開機自啓動;MAC)
#vim /etc/sysconfig/network-scripts/ifcfg-br-ex (設備名;MAC取消)
#ovs-vsctl add-port br-ex eth0;service network restart
[root@server10 ~(keystone_neutron)]# rpm -q iproute
iproute-2.6.32-130.el6ost.netns.2.x86_64
11.2配置neutron網絡
[root@server10 ~(keystone_neutron)]# neutron-l3-setup --plugin openvswitch --qhost 192.168.0.110
[root@server10 ~(keystone_neutron)]# /etc/init.d/neutron-l3-agent start
[root@server10 ~(keystone_neutron)]# chkconfig neutron-l3-agent on
仍然有報錯啊
[root@server10 network-scripts(keystone_admin)]# egrep 'ERROR|CRITICAL' /var/log/neutron/l3-agent.log
2014-08-02 13:45:27.151 27518 ERROR neutron.common.legacy [-] Skipping unknown group key: firewall_driver
[root@server10 ~(keystone_neutron)]# openstack-status 查看網絡,網絡那塊有兩個沒有啓動
== Nova services ==
openstack-nova-api: dead (disabled on boot) 沒有開機啓動
openstack-nova-compute: dead (disabled on boot)
openstack-nova-network: dead (disabled on boot)
openstack-nova-scheduler: dead (disabled on boot)
== Glance services ==
其實到這裏nova的相關仍是有些問題的,繼續配置nova節點
############################################################################
第七節 nova安裝
切回admin用戶執行
[root@server10 ~(keystone_admin)]# yum install -y openstack-nova openstack-nova-novncproxy
[root@server10 ~(keystone_admin)]# source /root/keystonerc_admin
[root@server10 ~(keystone_admin)]# chown nova:nova /var/log/nova/
初始化db數據庫
[root@server10 ~(keystone_admin)]# openstack-db --init --service nova --password westos --rootpw westos
建立用戶
root@server10 ~(keystone_admin)]# keystone user-create --name nova --pass westos
+----------+----------------------------------+
| Property | Value |
+----------+----------------------------------+
| email | |
| enabled | True |
| id | fd4f1d6540464a32b79c8e3a41ba7e70 |
| name | nova |
+----------+----------------------------------+
綁定角色而且建立服務
[root@server10 ~(keystone_admin)]# keystone user-role-add --user nova --role admin --tenant services
[root@server10 ~(keystone_admin)]# keystone service-create --name nova --type compute --description "openstack compute service "
+-------------+----------------------------------+
| Property | Value |
+-------------+----------------------------------+
| description | openstack compute service |
| id | 7dd84b0c66ea4cd891b11b66a1dab754 |
| name | nova |
| type | compute |
+-------------+----------------------------------+
建立endpoint:URL
[root@server10 ~(keystone_admin)]# keystone endpoint-create --service-id 7dd84b0c66ea4cd891b11b66a1dab754 \
> --publicurl 'http://server10.example.com:8774/v2/%(tenant_id)s' \
> --adminurl 'http://server10.example.com:8774/v2/%(tenant_id)s' \
> --internalurl 'http://server10.example.com:8774/v2/%(tenant_id)s'
+-------------+---------------------------------------------------+
| Property | Value |
+-------------+---------------------------------------------------+
| adminurl | http://server10.example.com:8774/v2/%(tenant_id)s |
| id | ed1ecf2502b64c9eac29f8047fad7fe5 |
| internalurl | http://server10.example.com:8774/v2/%(tenant_id)s |
| publicurl | http://server10.example.com:8774/v2/%(tenant_id)s |
| region | regionOne |
| service_id | 7dd84b0c66ea4cd891b11b66a1dab754 |
+-------------+---------------------------------------------------+
修改配置文件:
[root@server10 ~(keystone_admin)]# vim /etc/nova/api-paste.ini
[filter:authtoken] 配置的最後部分
admin_tenant_name = services
admin_user = nova
admin_password = westos
auth_host = 192.168.0.110
[root@server10 ~(keystone_admin)]# vim /etc/nova/nova.conf
qpid_hostname=192.168.0.110
qpid_port=5671
qpid_username=qpidauth
qpid_password=westos
qpid_protocol=ssl
vncserver_listen=192.168.0.110
vncserver_proxyclient_address=192.168.0.110
libvirt_vif_driver=nova.virt.libvirt.vif.LibvirtGenericVIFDriver
auth_strategy = keystone
libvirt_type=qemu
libvirt_cpu_mode=none
verbose=true
api_paste_config=api-paste.ini
(# for i in /etc/init.d/openstack-nova*;do $i restart;done)
#/etc/init.d/libvirtd start
#/etc/init.d/openstack-nova-api start
#/etc/init.d/openstack-nova-compute start
#/etc/init.d/openstack-nova-conductor start
#/etc/init.d/openstack-nova-consoleauth start
#/etc/init.d/openstack-nova-novncproxy start
#/etc/init.d/openstack-nova-scheduler start
[root@server10 ~(keystone_admin)]# chkconfig libvirtd on
[root@server10 ~(keystone_admin)]# chkconfig openstack-nova-api on
[root@server10 ~(keystone_admin)]# chkconfig openstack-nova-compute on
[root@server10 ~(keystone_admin)]# chkconfig openstack-nova-conductor on
[root@server10 ~(keystone_admin)]# chkconfig openstack-nova-consoleauth on
[root@server10 ~(keystone_admin)]# chkconfig openstack-nova-novncproxy on
[root@server10 ~(keystone_admin)]# chkconfig openstack-nova-scheduler on
[root@server10 ~(keystone_admin)]# openstack-status
== Nova services ==
相應的服務都會啓動了active狀態
== Keystone users ==
+----------------------------------+---------+---------+-------+
| id | name | enabled | email |
+----------------------------------+---------+---------+-------+
| f90b1ed5677a42b0b70544367d804222 | admin | True | |
| 912094d6e8c54864aa2606a13daae1c9 | cinder | True | |
| 41be9c4c80b74ec4bc9df05636859985 | glance | True | |
| fd4f1d6540464a32b79c8e3a41ba7e70 | nova | True | |
| 2ea05745a8684da2bcd7ec12fa522cac | quantum | True | |
| 2e86f4f604cd4edaa535caf8f19af9db | swift | True | |
+----------------------------------+---------+---------+-------+
== Glance images ==
+--------------------------------------+---------+-------------+------------------+-----------+--------+
| ID | Name | Disk Format | Container Format | Size | Status |
+--------------------------------------+---------+-------------+------------------+-----------+--------+
| dd5135b4-c2ce-4c66-8b73-454705b2a310 | xxb | qcow2 | bare | 92908032 | active |
| 1e08ab41-58ed-457d-994e-5f8607f5bb67 | xxbandy | qcow2 | bare | 258146304 | active |
+--------------------------------------+---------+-------------+------------------+-----------+--------+
== Nova managed services ==
+------------------+----------------------+----------+---------+-------+----------------------------+-----------------+
| Binary | Host | Zone | Status | State | Updated_at | Disabled Reason |
+------------------+----------------------+----------+---------+-------+----------------------------+-----------------+
| nova-conductor | server10.example.com | internal | enabled | up | 2014-08-02T09:49:44.000000 | None |
| nova-compute | server10.example.com | nova | enabled | up | 2014-08-02T09:49:44.000000 | None |
| nova-consoleauth | server10.example.com | internal | enabled | up | 2014-08-02T09:49:46.000000 | None |
| nova-scheduler | server10.example.com | internal | enabled | up | 2014-08-02T09:49:39.000000 | None |
| nova-cells | server10.example.com | internal | enabled | up | 2014-08-02T09:49:43.000000 | None |
| nova-console | server10.example.com | internal | enabled | up | 2014-08-02T09:49:45.000000 | None |
| nova-network | server10.example.com | internal | enabled | up | 2014-08-02T09:49:38.000000 | None |
| nova-cert | server10.example.com | internal | enabled | up | 2014-08-02T09:49:43.000000 | None |
+------------------+----------------------+----------+---------+-------+----------------------------+-----------------+
== Nova networks ==
== Nova instance flavors ==
+----+-----------+-----------+------+-----------+------+-------+-------------+-----------+
| ID | Name | Memory_MB | Disk | Ephemeral | Swap | VCPUs | RXTX_Factor | Is_Public |
+----+-----------+-----------+------+-----------+------+-------+-------------+-----------+
| 1 | m1.tiny | 512 | 1 | 0 | | 1 | 1.0 | True |
| 2 | m1.small | 2048 | 20 | 0 | | 1 | 1.0 | True |
| 3 | m1.medium | 4096 | 40 | 0 | | 2 | 1.0 | True |
| 4 | m1.large | 8192 | 80 | 0 | | 4 | 1.0 | True |
| 5 | m1.xlarge | 16384 | 160 | 0 | | 8 | 1.0 | True |
+----+-----------+-----------+------+-----------+------+-------+-------------+-----------+
== Nova instances ==
全部檢查OK!
若是可以到這步檢查沒有錯誤就能夠放心的進行下面了。。
第八節 安裝dashboard
[root@server10 ~(keystone_admin)]# yum install mod_wsgi httpd mod_ssl openstack-dashboard python-memcached -y
配置dashboard配置
[root@server10 ~(keystone_admin)]# vim /etc/openstack-dashboard/local_settings
OPENSTACK_HOST = "192.168.0.110"
ALLOWED_HOSTS = ['server10example.com', 'localhost','192.168.0.110']
CACHE_BACKEND = 'memcached://127.0.0.1:11211'
[root@server10 ~(keystone_admin)]# source /root/keystonerc_admin
[root@server10 ~(keystone_admin)]# keystone role-list
+----------------------------------+----------+
| id | name |
+----------------------------------+----------+
| 9fe2ff9ee4384b1894a90878d3e92bab | _member_ |
| ab686060308d470887911c19a8c011b4 | admin |
+----------------------------------+----------+
[root@server10 ~(keystone_admin)]# keystone role-create --name Member 建立一個成員角色
+----------+----------------------------------+
| Property | Value |
+----------+----------------------------------+
| id | 9fcca6054e0f45dc8bfb804219199e71 |
| name | Member |
+----------+----------------------------------+
設置apache可以正確訪問selinux規則
[root@server10 ~(keystone_admin)]# setsebool -P httpd_can_network_connect on
[root@server10 ~(keystone_admin)]# /etc/init.d/httpd restart
[root@server10 ~(keystone_admin)]# chkconfig httpd on
登陸 https://server10.example.com/dashboard (username=admin passwd=westos)
若是不能登陸就修改下面的文件(提示權限問題)
#cd /var/lib/openstack-dashboard/
[root@server10 openstack-dashboard(keystone_admin)]# chown apache:apache .secret_key_store
從新登陸:就能夠進入界面了!!!
linux
固然進去後會發現不少項目服務是空的,那麼就須要咱們按照第一天的步驟來一步步建立其餘服務了。sql
更多高級配置請繼續關注!
數據庫