热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

安装多节点swift(OpenStackswiftinstallMultinode)

拓扑图实验环境:4台ESXi上的ubuntu-11.04-server-i386虚拟机,每个存储节点上多有10G虚拟存储/dev/sdb个人感觉官方配置文档中的,通用配置部分,下面两句容易引起歧义,可以忽略exportSTORAGE_LOCAL_NET_IP10.1.2.3exportPROXY_LOCAL_NET_I

 swift <wbr>多节点安装 <wbr>(openstack <wbr>swift <wbr>install <wbr>Multinode)

拓扑图

实验环境:4台ESXi上的ubuntu-11.04-server-i386 虚拟机,每个存储节点上多有10G虚拟存储/dev/sdb

个人感觉官方配置文档中的,通用配置部分,下面两句容易引起歧义,可以忽略

export STORAGE_LOCAL_NET_IP=10.1.2.3

export PROXY_LOCAL_NET_IP=10.1.2.4

 1)配置代理节点

"EN-US">perl -pi -e "s/-l 127.0.0.1/-l 192.168.1.37/" /etc/memcached.conf

Vim /etc/proxy-server.conf

[DEFAULT]

cert_file = /etc/swift/cert.crt

key_file = /etc/swift/cert.key

bind_port = 443

workers = 8

user = root

 

[pipeline:main]

pipeline = healthcheck cache swauth proxy-server

 

[app:proxy-server]

use = egg:swift#proxy

allow_account_management = true

 

[filter:swauth]

use = egg:swauth#swauth

default_swift_cluster = local#https://192.168.1.37:443/v1

super_admin_key = password

 

[filter:healthcheck]

use = egg:swift#healthcheck

 

[filter:cache]

use = egg:swift#memcache

memcache_servers = 192.168.1.37:11211

 使用swauth认证,具体安装参考:http://blog.sina.com.cn/s/blog_4b8481f70100x9kk.html

Vim ring.sh

#!/bin/bash

a=1

swift-ring-builder account.builder create 18 $a 1

swift-ring-builder container.builder create 18 $a 1

swift-ring-builder object.builder create 18 $a 1

echo "swift-ring-builder 18 $a 1 done"

注a 表示为备份数目

 

Vim addring.sh

#!/bin/bash

ip=192.168.1.60

z=2

export ZOnE=$z                    # set the zone number for that storage device

export STORAGE_LOCAL_NET_IP=$ip   # and the IP address

export WEIGHT=100               # relative weight (higher for bigger/faster disks)

export DEVICE=sdb1

swift-ring-builder account.builder add z$ZONE-$STORAGE_LOCAL_NET_IP:6002/$DEVICE $WEIGHT

swift-ring-builder container.builder add z$ZONE-$STORAGE_LOCAL_NET_IP:6001/$DEVICE $WEIGHT

swift-ring-builder object.builder add z$ZONE-$STORAGE_LOCAL_NET_IP:6000/$DEVICE $WEIGHT

备注:ip 和z选项需对应变化,

如ip=192.168.1.69, z=0; ip=192.168.1.82,z=1; ip=192.168.1.60,z=2

表示每台服务器对应一个zone。

 

Vim verify.sh

#!/bin/bash

swift-ring-builder account.builder

swift-ring-builder container.builder

swift-ring-builder object.builder

 

Vim rebalance.sh

#!/bin/bash

swift-ring-builder account.builder rebalance

swift-ring-builder container.builder rebalance

swift-ring-builder object.builder rebalance

2)配置存储节点

所有的存储节点配置大径相同,本文以Storage1:192.168.1.69为例

1.必要存储节点安装包

apt-get install swift-account swift-container swift-object xfsprogs

2创建XFS卷

fdisk /dev/sdb  (set up a single partition)

mkfs.xfs -i size=1024 /dev/sdb1

echo "/dev/sdb1 /srv/node/sdb1 xfs noatime,nodiratime,nobarrier,logbufs=8 0 0" >> /etc/fstab

mkdir -p /srv/node/sdb1

mount /srv/node/sdb1

chown -R swift:swift /srv/node

注:我做实验的时候改成chown ?R root:root /srv/node ,会出现错误

root@swift-proxy:/usr/src/lyq/swauth# swauth-prep -K password  -A https://127.0.0.1/auth/
Auth subsystem prep failed: 500 Server Error

 

Vim /etc/rsyncd.conf

uid = root

gid = root

log file = /var/log/rsyncd.log

pid file = /var/run/rsyncd.pid

address = 192.168.1.69

[account]

max cOnnections= 2

path = /srv/node/

read Only= false

lock file = /var/lock/account.lock

[container]

max cOnnections= 2

path = /srv/node/

read Only= false

lock file = /var/lock/container.lock

[object]

max cOnnections= 2

path = /srv/node/

read Only= false

lock file = /var/lock/object.lock

 

vim account-server.conf

[DEFAULT]

bind_ip = 192.168.1.69

workers = 2

[pipeline:main]

pipeline = account-server

[app:account-server]

use = egg:swift#account

[account-replicator]

[account-auditor]

[account-reaper]

vim container-server.conf

[DEFAULT]

bind_ip = 192.168.1.69

workers = 2

[pipeline:main]

pipeline = container-server

[app:container-server]

use = egg:swift#container

[container-replicator]

[container-updater]

[container-auditor]

vim object-server.conf

[DEFAULT]

bind_ip = 192.168.1.69

workers = 2

[pipeline:main]

pipeline = object-server

[app:object-server]

use = egg:swift#object

[object-replicator]

[object-updater]

[object-auditor]

 

注:与上述的过程类似,可以成功的将所有的服务多装在任一台机器上,这就和官网上的SAIO的功能相同了,而且比官网的配置过程简单


推荐阅读
  • 阿里云服务器搭建详解——Ubuntu
    由于自己电脑配置跟不上,双系统一开,整个电脑就会变得非常卡顿,所以决定在阿里云买一个云服务器。听朋友说,学生买的话是非常便宜 ... [详细]
  • Docker安全策略与管理
    本文探讨了Docker的安全挑战、核心安全特性及其管理策略,旨在帮助读者深入理解Docker安全机制,并提供实用的安全管理建议。 ... [详细]
  • 搭建个人博客:WordPress安装详解
    计划建立个人博客来分享生活与工作的见解和经验,选择WordPress是因为它专为博客设计,功能强大且易于使用。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文详细介绍了如何在ARM架构的目标设备上部署SSH服务端,包括必要的软件包下载、交叉编译过程以及最终的服务配置与测试。适合嵌入式开发人员和系统集成工程师参考。 ... [详细]
  • 在Ubuntu 16.10 (x86) 上安装 WordPress 4.7.115
    本文介绍如何在Ubuntu 16.10 (x86) 系统上安装WordPress 4.7.115,包括下载、解压、配置等步骤,确保安装过程顺利进行。 ... [详细]
  • 本文详细介绍了在Mac平台上安装和配置MySQL的步骤,包括下载安装包、卸载MySQL以及解决命令行中找不到mysql命令的问题。 ... [详细]
  • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
  • 本文详细介绍了如何在 Ubuntu 14.04 系统上搭建仅使用 CPU 的 Caffe 深度学习框架,包括环境准备、依赖安装及编译过程。 ... [详细]
  • 在尝试加载支持推送通知的iOS应用程序的Ad Hoc构建时,遇到了‘no valid aps-environment entitlement found for application’的错误提示。本文将探讨此错误的原因及多种可能的解决方案。 ... [详细]
  • 精选10款Python框架助力并行与分布式机器学习
    随着神经网络模型的不断深化和复杂化,训练这些模型变得愈发具有挑战性,不仅需要处理大量的权重,还必须克服内存限制等问题。本文将介绍10款优秀的Python框架,帮助开发者高效地实现分布式和并行化的深度学习模型训练。 ... [详细]
  • 本文将详细探讨PHP中C的作用,并对比其他编程语言如Java和C的特点及其适用场景。 ... [详细]
  • Java EE 平台集成了多种服务、API 和协议,旨在支持基于 Web 的多层应用程序开发。本文将详细介绍 Java EE 中的 13 种关键技术规范,帮助开发者更好地理解和应用这些技术。 ... [详细]
  • 解决Parallels Desktop错误15265的方法
    本文详细介绍了在使用Parallels Desktop时遇到错误15265的多种解决方案,包括检查网络连接、关闭代理服务器和修改主机文件等步骤。 ... [详细]
  • 本文介绍了如何利用Shell脚本高效地部署MHA(MySQL High Availability)高可用集群。通过详细的脚本编写和配置示例,展示了自动化部署过程中的关键步骤和注意事项。该方法不仅简化了集群的部署流程,还提高了系统的稳定性和可用性。 ... [详细]
author-avatar
80后女孩香香521
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有