# 在部署对象存储服务(swift)之前,你的环境必须包含身份验证服务(keystone);
# keystone需要MySQL数据库,Rabbitmq服务,Memcached服务;
# 内存:4G
# 系统:Ubuntu Server-14.04.5
# 安装方法:http://www.jianshu.com/p/9e77b3ad930a
# IP地址:192.168.10.55
# 主机名:object
基本环境配置
配置主机静态IP地址
vim /etc/network/interfaces
auto lo
iface lo inet loopback
auto eth0
# 将dhcp修改为static
iface eth0 inet static
# 静态IP地址
address 192.168.10.55
# 子网掩码
netmask 255.255.255.0
# 广播地址
broadcast 192.168.10.255
# 默认网关
gateway 192.168.10.2
# DNS服务器
## 谷歌DNS
dns-nameservers 8.8.8.8
## 阿里DNS
dns-nameservers 223.5.5.5
重启网卡
# 关闭网卡
ifdown eth0
# 开启网卡
ifup eth0
配置主机名
vim /etc/hostname
# 对于不同的节点,请做出相应的修改
# 清空文件内容
# 主机名
object
配置主机名解析
vim /etc/hosts
# 文件内容,请视实际情况做相应的修改
192.168.10.55 object
验证操作
ping -c 4 主机名
# 例如
ping -c 4 object
配置Ubuntu更新源
vim /etc/apt/sources.list
更新系统
apt-get update && apt-get dist-upgrade
添加OpenStack库
apt-get install software-properties-common
安装OpenStack客户端
apt-get install python-openstackclient
更新系统
# 此处为必需步骤
apt-get update && apt-get dist-upgrade
重启主机
shutdown -r now
# 重启电脑后,XShell要用新的IP地址连接虚拟机
# XShell的使用方法:http://www.jianshu.com/p/ada93cba0acd
MySQL服务
安装软件包
# 此处会提示用户设置数据库密码
apt-get install mariadb-server python-pymysql
配置openstack.cnf
vim /etc/mysql/conf.d/openstack.cnf
[mysqld]
重启mysql服务
service mysql restart
mysql安全初始化
# 提示输入密码,问题推荐输入n、y、y、y、y
mysql_secure_installation
Rabbitmq服务
安装软件包
apt-get install rabbitmq-server
添加OpenStack用户
# 此处密码为0901
rabbitmqctl add_user openstack 0901
为OpenStack用户添加读、写及访问权限
rabbitmqctl set_permissions openstack ".*" ".*" ".*"
Memcached服务
安装软件包
apt-get install memcached python-memcache
配置memcached.conf
vim /etc/memcached.conf
# object的IP地址
-l 192.168.10.55
重启服务
service memcached restart
keystone的安装
进入数据库
创建keystone数据库
CREATE DATABASE keystone;
赋予keystone相关权限
# 根据实际情况修改密码
GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'localhost' IDENTIFIED BY '0901';
GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'%' IDENTIFIED BY '0901';
退出数据库
exit
生成随机值作为临时令牌(token)
禁用keystone在安装完成后自启
echo "manual" > /etc/init/keystone.override
安装软件包
apt-get install keystone apache2 libapache2-mod-wsgi
配置keystone.conf
vim /etc/keystone/keystone.conf
[DEFAULT]
同步keystone数据库
su -s /bin/sh -c "keystone-manage db_sync" keystone
初始化Fernet键
keystone-manage fernet_setup --keystone-user keystone --keystone-group keystone
配置apache2.conf
vim /etc/apache2/apache2.conf
新建并配置wsgi-keystone.conf
vim /etc/apache2/sites-available/wsgi-keystone.conf
Listen 5000
Listen 35357
<VirtualHost *:5000>
WSGIDaemonProcess keystone-public processes=5 threads=1 user=keystone group=keystone display-name=%{GROUP}
WSGIProcessGroup keystone-public
WSGIScriptAlias / /usr/bin/keystone-wsgi-public
WSGIApplicationGroup %{GLOBAL}
WSGIPassAuthorization On
ErrorLogFormat "%{cu}t %M"
ErrorLog /var/log/apache2/keystone.log
CustomLog /var/log/apache2/keystone_access.log combined
<Directory /usr/bin>
Require all granted
</Directory>
</VirtualHost>
<VirtualHost *:35357>
WSGIDaemonProcess keystone-admin processes=5 threads=1 user=keystone group=keystone display-name=%{GROUP}
WSGIProcessGroup keystone-admin
WSGIScriptAlias / /usr/bin/keystone-wsgi-admin
WSGIApplicationGroup %{GLOBAL}
WSGIPassAuthorization On
ErrorLogFormat "%{cu}t %M"
ErrorLog /var/log/apache2/keystone.log
CustomLog /var/log/apache2/keystone_access.log combined
<Directory /usr/bin>
Require all granted
</Directory>
</VirtualHost>
使apache支持虚拟机的身份认证服务
ln -s /etc/apache2/sites-available/wsgi-keystone.conf /etc/apache2/sites-enabled
重启appache服务
service apache2 restart
删除SQLite数据库文件
rm -f /var/lib/keystone/keystone.db
配置身份验证令牌
# token值要与前文统一
export OS_TOKEN=0c7030a400cf77890c75
配置Endpoint的URL
export OS_URL=http:
配置API版本
export OS_IDENTITY_API_VERSION=3
创建identity服务实体
创建identity服务endpoint
# 执行结果为表格
openstack endpoint create --region RegionOne identity public http:
创建一个默认的domain
# 执行结果为表格
openstack domain create --description "Default Domain" default
创建一个admin project
创建一个admin user
创建一个admin role
将role添加到admin project和admin user里面去
创建一个service project
配置keystone-paste.ini
vim /etc/keystone/keystone-paste.ini
# 分别从[pipeline:public_api]、[pipeline:admin_api] and [pipeline:api_v3] 移除 admin_token_auth
移除临时token
unset OS_TOKEN OS_URL
作为admin管理员请求一个身份验证令牌
简化操作
重新加载配置文件
source /etc/profile
请求获取令牌
openstack token issue
Swift单节点安装
创建swift用户
将admin role添加到swift user
创建Object Storage服务实体
创建Object Storage服务endpoint
openstack endpoint create --region RegionOne object-store public http:
安装软件包
apt-get install swift swift-proxy python-swiftclient python-keystoneclient python-keystonemiddleware memcached
创建swift目录
mkdir -p /etc/swift
从对象存储源仓库中获取代理服务配置文件
配置proxy-server.conf
vim /etc/swift/proxy-server.conf
[DEFAULT]
bind_port = 8080
user = swift
swift_dir = /etc/swift
磁盘模拟存储节点
# 模拟两个存储节点,每个节点2个空磁盘
# 关闭虚拟机,为我们的虚拟机添加4个10G的空磁盘;
# 虚拟机磁盘名称:sda(系统区)、sdb、sdc、sdd、sde;
# 验证检查,查看是否有以上磁盘;
ls /dev/sd*
步骤1
步骤2
步骤3
步骤4
步骤5
步骤6
步骤7
安装软件包
apt-get install xfsprogs rsync
格式化空磁盘
mkfs.xfs /dev/sdb
mkfs.xfs /dev/sdc
mkfs.xfs /dev/sdd
mkfs.xfs /dev/sde
创建挂载点目录结构
mkdir -p /srv/node/sdb
mkdir -p /srv/node/sdc
mkdir -p /srv/node/sdd
mkdir -p /srv/node/sde
配置fstab(自动挂载)
vim /etc/fstab
挂载设备
mount /srv/node/sdb
mount /srv/node/sdc
mount /srv/node/sdd
mount /srv/node/sde
配置rsyncd.conf
vim /etc/rsyncd.conf
uid = swift
gid = swift
log file = /var/log/rsyncd.log
pid file = /var/run/rsyncd.pid
配置开启rsync服务
vim /etc/default/rsync
RSYNC_ENABLE=true
启动rsyns服务
service rsync start
安装软件包
apt-get install swift swift-account swift-container swift-object
获取配置文件
配置account-server.conf
vim /etc/swift/account-server.conf
[DEFAULT]
配置container-server.conf
vim /etc/swift/container-server.conf
[DEFAULT]
配置object-server.conf
vim /etc/swift/object-server.conf
[DEFAULT]
修改挂载点的权限
chown -R swift:swift /srv/node
创建recon目录并设置权限
mkdir -p /var/cache/swift
chown -R root:swift /var/cache/swift
chmod -R 775 /var/cache/swift
创建并分配初始化环(rings)
切换到swift目录
cd /etc/swift
创建account.builder文件
# 此处无输出则正确
swift-ring-builder account.builder create 10 3 1
将每个存储节点添加到环(ring)中
swift-ring-builder account.builder add --region 1 --zone 1 --ip 192.168.10.55 --port 6002 --device sdb --weight 100
swift-ring-builder account.builder add --region 1 --zone 1 --ip 192.168.10.55 --port 6002 --device sdc --weight 100
swift-ring-builder account.builder add --region 1 --zone 2 --ip 192.168.10.55 --port 6002 --device sdd --weight 100
swift-ring-builder account.builder add --region 1 --zone 2 --ip 192.168.10.55 --port 6002 --device sde --weight 100
验证操作
swift-ring-builder account.builder
平衡环
swift-ring-builder account.builder rebalance
切换到swift目录
cd /etc/swift
创建container.builder文件
# 此处无输出则正确
swift-ring-builder container.builder create 10 3 1
将每个存储节点添加到环(ring)中
swift-ring-builder container.builder add --region 1 --zone 1 --ip 192.168.10.55 --port 6001 --device sdb --weight 100
swift-ring-builder container.builder add --region 1 --zone 1 --ip 192.168.10.55 --port 6001 --device sdc --weight 100
swift-ring-builder container.builder add --region 1 --zone 2 --ip 192.168.10.55 --port 6001 --device sdd --weight 100
swift-ring-builder container.builder add --region 1 --zone 2 --ip 192.168.10.55 --port 6001 --device sde --weight 100
验证操作
swift-ring-builder container.builder
平衡环
swift-ring-builder container.builder rebalance
切换到swift目录
cd /etc/swift
创建object.builder文件
# 此处无输出则正确
swift-ring-builder object.builder create 10 3 1
将每个存储节点添加到环(ring)中
swift-ring-builder object.builder add --region 1 --zone 1 --ip 192.168.10.55 --port 6000 --device sdb --weight 100
swift-ring-builder object.builder add --region 1 --zone 1 --ip 192.168.10.55 --port 6000 --device sdc --weight 100
swift-ring-builder object.builder add --region 1 --zone 2 --ip 192.168.10.55 --port 6000 --device sdd --weight 100
swift-ring-builder object.builder add --region 1 --zone 2 --ip 192.168.10.55 --port 6000 --device sde --weight 100
验证操作
swift-ring-builder object.builder
平衡环
swift-ring-builder object.builder rebalance
从源仓库获取swift.conf
配置swift.conf
vim /etc/swift/swift.conf
[swift-hash]
设置权限
chown -R root:swift /etc/swift
重启服务
service memcached restart
service swift-proxy restart
swift-init all start
查看swift状态
swift stat
创建容器Ben
openstack container create Ben
上传测试文件到容器Ben
# 文件需要我们自行去创建
# 注意 FILENAME 的修改
openstack object create Ben FILENAME
列出容器 Ben 存储的FILES
openstack object list Ben
下载容器Ben存储的FILENAME
# 此处无输出则正确
openstack object save Ben FILENAME