OpenStack-M版(Mitaka)搭建基于(Centos7.2)+++十、Openstack对象存储服务(swift)上

十、Openstack对象存储服务(swift)上


配置:我在计算节点添加了两块硬盘(sdb,sdc)用来当存储用,在我这搭建中计算节点也就是存储节点了,原因电脑无法拉动更多虚拟几所以咯。。。

简单介绍:

swift主要有四个组件:swift-proxy-serverswift-account-serverswift-container-serverswift-object-server

swift-proxy-server(代理服务):对外提供对象服务 API

swift-account-server(账户服务):提供账户元数据和统计信息,并维护所含容器列表的服务,管理由对象存储定义的账户

swift-container-server(容器服务):提供容器元数据和统计信息,并维护所含对象列表的服务

swift-object-server(对象服务):提供对象元数据和内容服务,每个对象的内容会以文件的形式存储在文件系统中,元数据会作为文件属性来存储,建议采用支持扩展属性的 XFS 文件系统



控制节点上

swift不需要数据库我们直接创建服务


1.创建swift用户

需要管理员权限

. admin-openrc

openstack user create --domain default --password-prompt swift

[root@controller ~]# . admin-openrc 
[root@controller ~]# openstack user create --domain default --password-prompt swift
User Password:
Repeat User Password:
+-----------+----------------------------------+
| Field     | Value                            |
+-----------+----------------------------------+
| domain_id | b24b3093654b4ba4be706fe675a03b2d |
| enabled   | True                             |
| id        | 90f27d7d1fb644babb1f35f6a7919866 |
| name      | swift                            |
+-----------+----------------------------------+

2.添加 admin 角色到swift 用户和 service 项目上

openstack role add --project service --user swift admin

[root@controller ~]# openstack role add --project service --user swift admin
此操作无返回


3.创建swift服务实体

openstack service create --name swift --description "OpenStack Object Storage" object-store

[root@controller ~]# openstack service create --name swift \
>   --description "OpenStack Object Storage" object-store
+-------------+----------------------------------+
| Field       | Value                            |
+-------------+----------------------------------+
| description | OpenStack Object Storage         |
| enabled     | True                             |
| id          | 1fbb8b2624694fc780291896d2f210a7 |
| name        | swift                            |
| type        | object-store                     |
+-------------+----------------------------------+

4.创建镜像服务的 API 端点

openstack endpoint create --region RegionOne object-store public http://controller:8080/v1/AUTH_% \  (括号前面是有\ 的)(tenant_id \ )s

openstack endpoint create --region RegionOne object-store internal http://controller:8080/v1/AUTH_% \ (tenant_id \ )s

openstack endpoint create --region RegionOne object-store admin http://controller:8080/v1

[root@controller ~]# openstack endpoint create --region RegionOne \
>   object-store public http://controller:8080/v1/AUTH_%(tenant_id)s
+--------------+----------------------------------------------+
| Field        | Value                                        |
+--------------+----------------------------------------------+
| enabled      | True                                         |
| id           | bc95965d7d084ca68e07e7259bb78385             |
| interface    | public                                       |
| region       | RegionOne                                    |
| region_id    | RegionOne                                    |
| service_id   | 1fbb8b2624694fc780291896d2f210a7             |
| service_name | swift                                        |
| service_type | object-store                                 |
| url          | http://controller:8080/v1/AUTH_%(tenant_id)s |
+--------------+----------------------------------------------+
[root@controller ~]# openstack endpoint create --region RegionOne \
>   object-store internal http://controller:8080/v1/AUTH_%(tenant_id)s
+--------------+----------------------------------------------+
| Field        | Value                                        |
+--------------+----------------------------------------------+
| enabled      | True                                         |
| id           | 83e47740125d42bea679097908bff9fa             |
| interface    | internal                                     |
| region       | RegionOne                                    |
| region_id    | RegionOne                                    |
| service_id   | 1fbb8b2624694fc780291896d2f210a7             |
| service_name | swift                                        |
| service_type | object-store                                 |
| url          | http://controller:8080/v1/AUTH_%(tenant_id)s |
+--------------+----------------------------------------------+
[root@controller ~]# openstack endpoint create --region RegionOne \
>   object-store admin http://controller:8080/v1
+--------------+----------------------------------+
| Field        | Value                            |
+--------------+----------------------------------+
| enabled      | True                             |
| id           | b75d6e318ae5481fbb602551a2e2278f |
| interface    | admin                            |
| region       | RegionOne                        |
| region_id    | RegionOne                        |
| service_id   | 1fbb8b2624694fc780291896d2f210a7 |
| service_name | swift                            |
| service_type | object-store                     |
| url          | http://controller:8080/v1        |
+--------------+----------------------------------+

5.安装软件包

yum install openstack-swift-proxy python-swiftclient python-keystoneclient python-keystonemiddleware memcached


从对象存储的仓库源中获取代理服务的配置文件(需要联网,否则自己浏览器打开自己粘贴创建文件)

curl -o /etc/swift/proxy-server.conf https://git.openstack.org/cgit/openstack/swift/plain/etc/proxy-server.conf-sample

[root@controller ~]# curl -o /etc/swift/proxy-server.conf https://git.openstack.org/cgit/openstack/swift/plain/etc/proxy-server.conf-sample
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100 41023  100 41023    0     0  27880      0  0:00:01  0:00:01 --:--:-- 27887

6.修改配置文件/etc/swift/proxy-server.conf

vi /etc/swift/proxy-server.conf

[DEFAULT]
bind_port = 8080绑定端口
user = swift用户
swift_dir = /etc/swift目录

将原句注释直接复制粘贴(很长这是一句不要回车,不要改顺序,不然会报错8080)

[pipeline:main]
pipeline = catch_errors gatekeeper healthcheck proxy-logging cache container_sync bulk ratelimit authtoken keystoneauth container-quotas account-quotas slo dlo versioned_writes proxy-logging proxy-server


启动自动账户创建

[app:proxy-server]
use = egg:swift#proxy
account_autocreate = True

配置操作员角色
这个配置是注释了的可以直接包括头[filter:keystoneauth]添加在配置最下面(不放心的去自己搜索看看)

[filter:keystoneauth]
use = egg:swift#keystoneauth
operator_roles = admin,user

配置认证服务访问
这个配置也是注释了的可以直接包括头[filter:authtoken]添加在配置最下面(不放心的去自己搜索看看)

[filter:authtoken]
paste.filter_factory = keystonemiddleware.auth_token:filter_factory
auth_uri = http://controller:5000
auth_url = http://controller:35357
memcached_servers = controller:11211
auth_type = password
project_domain_name = default
user_domain_name = default
project_name = service
username = swift
password = 123456(创建用户时你为swift设置的密码)
delay_auth_decision = True

配置 memcached 的位置

[filter:cache]
use = egg:swift#memcache
memcache_servers = controller:11211

<think>我们正在解决在CentOS系统中无法通过yum安装openstack-packstack和centos-release-openstack-mitaka的问题,具体表现为执行安装命令时提示"Nopackageavailable"。根据引用[1]和引用[2],通常需要先安装centos-release-openstack-mitaka仓库,然后再安装openstack-packstack。但用户已经遇到了这两个包都无法安装的情况。可能的原因及解决思路:1.系统本不匹配:OpenStackMitaka本较老,可能只支持CentOS7,且需要特定的仓库配置。2.仓库未正确配置:可能缺少EPEL仓库或者基础仓库,或者仓库配置有重复(如用户输出中提到的epel仓库重复)。3.网络问题:无法访问仓库镜像。4.仓库已被移除:由于Mitaka是很旧的本,可能官方仓库已经不再提供。步骤:1.确认系统本:如果是CentOS7,则继续;如果是CentOS8,则可能需要使用其他方法(因为CentOS8默认不支持Mitaka)。2.清理yum缓存并更新。3.检查仓库配置,确保没有冲突。4.尝试手动下载仓库安装包进行安装(如果yum无法安装仓库包)。5.如果Mitaka仓库确实不可用,考虑使用其他本的OpenStack(如Queens、Rocky等)或使用RDO仓库。具体操作:步骤1:确认系统本执行命令:`cat/etc/centos-release`步骤2:如果是CentOS7,尝试添加EPEL仓库(如果尚未添加)因为OpenStack仓库可能依赖EPEL。```sudoyuminstall-yepel-release```步骤3:清理yum缓存并更新```sudoyumcleanallsudoyummakecachesudoyumupdate-y```步骤4:尝试安装centos-release-openstack-mitaka```sudoyuminstall-ycentos-release-openstack-mitaka```如果仍然找不到包,我们可以尝试手动下载并安装该仓库的rpm包。手动下载安装(以Mitaka为例):```wgethttp://vault.centos.org/7.9.2009/cloud/x86_64/openstack-mitaka/centos-release-openstack-mitaka-1-3.el7.noarch.rpmsudoyuminstall-ycentos-release-openstack-mitaka-1-3.el7.noarch.rpm```注意:这里我们使用了CentOS的归档仓库(vault.centos.org),因为Mitaka本较老,在官方仓库中可能已被移除。步骤5:安装openstack-packstack在成功安装仓库后,更新缓存并安装:```sudoyumupdate-ysudoyuminstall-yopenstack-packstack```步骤6:如果系统是CentOS8由于CentOS8默认不提供Mitaka,建议使用更新的OpenStack本。例如,安装Rocky本的仓库:```sudodnfinstall-ycentos-release-openstack-rockysudodnfupdate-ysudodnfinstall-yopenstack-packstack```注意:在CentOS8上,可能需要先启用PowerTools仓库(引用[4]):```sudodnfconfig-manager--set-enabledpowertools```步骤7:如果以上方法都失败,考虑使用RDO仓库RDO项目提供了OpenStack的安装包,可以尝试:```#对于CentOS7sudoyuminstall-yhttps://repos.fedorapeople.org/repos/openstack/openstack-mitaka/rdo-release-mitaka-9.noarch.rpmsudoyuminstall-yopenstack-packstack#对于CentOS8,使用Rocky本sudodnfinstall-yhttps://repos.fedorapeople.org/repos/openstack/openstack-rocky/rdo-release-rocky-3.noarch.rpmsudodnfinstall-yopenstack-packstack```注意:由于OpenStack本较老,可能遇到依赖问题,需要耐心调整。步骤8:处理安装中的依赖问题如果安装过程中出现依赖问题,如缺少`deltarpm`(引用[3])或`python-devel`(引用[5]),则安装:```sudoyuminstall-ydeltarpm#针对CentOS7sudoyuminstall-ypython-devel#针对Python依赖```总结:根据系统本选择合适的方法,优先尝试使用官方仓库,如果官方仓库已移除,则使用归档仓库或RDO仓库。相关问题:1.如何确定当前系统可用的OpenStack仓库本?2.CentOS8上安装OpenStackYoga本需要哪些步骤?3.如何解决OpenStack安装过程中的依赖冲突?4.安装完成后运行`packstack--allinone`报错如何调试?5.如何为OpenStack添加国内镜像源加速安装?</think>### 解决 CentOS无法安装 openstack-packstack 和 centos-release-openstack-mitaka 的问题 #### 问题原因分析 1. **仓库配置缺失** OpenStack 软件包不在默认仓库中,需要手动添加特定本的 OpenStack 仓库[^1][^2]。 2. **本不匹配** Mitaka 是较旧的 OpenStack 本(2016年发布),现代 CentOS 系统默认仓库可能已移除支持[^3]。 3. **仓库镜像失效** 官方仓库可能已迁移,需使用归档仓库或替代源[^3]。 --- #### 解决方案(分步骤操作) ##### ✅ 步骤 1:确认系统本 ```bash cat /etc/centos-release ``` - **CentOS 7** → 继续步骤 2 - **CentOS 8/9** → 跳至步骤 5 ##### ✅ 步骤 2:手动添加 Mitaka 仓库(CentOS 7) ```bash # 添加归档仓库(Vault 源) sudo tee /etc/yum.repos.d/openstack-mitaka.repo <<'EOF' [openstack-mitaka] name=CentOS OpenStack Mitaka baseurl=https://vault.centos.org/7.9.2009/cloud/x86_64/openstack-mitaka/ gpgcheck=1 enabled=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-SIG-Cloud EOF # 导入 GPG 密钥 sudo curl -o /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-SIG-Cloud \ https://www.centos.org/keys/RPM-GPG-KEY-CentOS-SIG-Cloud ``` ##### ✅ 步骤 3:安装软件包 ```bash # 更新仓库缓存 sudo yum clean all sudo yum makecache # 安装软件包 sudo yum install -y centos-release-openstack-mitaka openstack-packstack ``` ##### ✅ 步骤 4:验证安装 ```bash # 检查 packstack 本 packstack --version # 预期输出:openstack-packstack-2016.1.1-1.el7.noarch ``` ##### ⚠️ 步骤 5:CentOS 8/9 替代方案 ```bash # 安装较新本(如 Yoga) sudo dnf install -y centos-release-openstack-yoga sudo dnf install -y openstack-packstack # 或使用 RDO 仓库 sudo dnf install -y https://repos.fedorapeople.org/repos/openstack/openstack-yoga/rdo-release-yoga-1.el8.noarch.rpm sudo dnf install -y openstack-packstack ``` --- #### 关键注意事项 1. **依赖处理** 若出现依赖错误: ```bash # 安装基础依赖 sudo yum install -y epel-release sudo yum install -y python-devel gcc openssl-devel ``` 2. **网络配置** 国内用户可使用阿里云镜像加速: ```bash sudo sed -i 's|https://vault.centos.org|https://mirrors.aliyun.com/centos-vault|g' \ /etc/yum.repos.d/openstack-mitaka.repo ``` 3. **SELinux 配置** 避免权限问题[^3]: ```bash sudo setenforce 0 sudo sed -i 's/SELINUX=enforcing/SELINUX=permissive/g' /etc/selinux/config ``` > **提示**:Mitaka 已结束支持,建议新部署使用 Yoga(2022) 或 Zed(2023) 等较新本[^1][^2]。 --- ### 相关问题 1. 如何确认 OpenStack 仓库是否成功添加到 yum? 2. 安装完成后运行 `packstack --allinone` 报错如何处理? 3. CentOS Stream 9 支持哪些 OpenStack 本? 4. 如何解决安装过程中的 `Error: Unable to find a match` 错误? 5. OpenStack Mitaka 与 Yoga 本的主要区别是什么?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值