配置ganesha-nfs对接rgw

简介:

环境

操作系统:CentOS7.5

[root@controller-0 ~]# cat /etc/redhat-release
CentOS Linux release 7.5.1804 (Core)

Ceph版本:Luminous

[root@controller-0 ~]# ceph -v
ceph version 12.2.8 (ae699615bac534ea496ee965ac6192cb7e0e07c0) luminous (stable)

nfs-ganesha版本:V2.5-stable

[root@controller-0 ~]# ganesha.nfsd -v
NFS-Ganesha Release = V2.5.5
nfs-ganesha compiled on Sep  4 2018 at 15:28:48
Release comment = GANESHA file server is 64 bits compliant and supports NFS v3,4.0,4.1 (pNFS) and 9P
Git HEAD = f92d5d184274784956eb5017fd2df633bae49d2b
Git Describe = V2.5.5-0-gf92d5d1

安装配置

1、安装编译需要的公共库

[root@controller-0 ~]# yum -y install gcc git cmake autoconf libtool bison flex doxygen openssl-devel gcc-c++ krb5-libs krb5-devel libuuid-devel nfs-utils
2、下载源码包
[root@controller-0 ~]# git clone -b V2.5-stable https://github.com/nfs-ganesha/nfs-ganesha.git --recursive

这个下载的如果比较慢的话,也可以直接通过云盘进行下载

链接:https://pan.baidu.com/s/175kkzNOWVjV8Xo_ClHhVVA 密码:2ivn

3、安装FSAL_RGW模块

[root@controller-0 ~]# yum -y install librgw2-devel

4、编译安装

[root@controller-0 ~]# cd nfs-ganesha/src/
[root@controller-0 src]# mkdir build
[root@controller-0 src]# cd build/
[root@controller-0 build]# cmake -DUSE_FSAL_RGW=ON ../
[root@controller-0 build]# make
[root@controller-0 build]# make install

cmake编译过程,会输出以下信息,需要确保-- USE_FSAL_RGW = ON,如果是OFF,建议核实一下是否有安装librgw2-devel,如果没有安装的话,先安装这个包,然后删掉build目录,重新进行cmake

……
-- USE_FSAL_CEPH_MKNOD = OFF
-- USE_FSAL_CEPH_SETLK = OFF
-- USE_FSAL_CEPH_LL_LOOKUP_ROOT = ON
-- USE_FSAL_RGW = ON
……

5、修改配置文件

[root@controller-0 ~]# vim /etc/ganesha/ganesha.conf
EXPORT
{
        Export_ID=1;
        Path = "/";
        Pseudo = "/";
        Access_Type = RW;
        Protocols = 4;
        Transports = TCP;
        FSAL {
                Name = RGW;
                User_Id = "admin";
                Access_Key_Id ="OZBC94UP6VNBSF4EXECI";
                Secret_Access_Key = "nrfuys9wMWE7A8TOOPKEMg6gNtM5dzWlVPPQBS9P";
        }
}

RGW {
        ceph_conf = "/etc/ceph/ceph.conf";
        name = "client.rgw.controller-0";
        cluster = "ceph";
}

配置文件中的User_IdAccess_Key_IdSecret_Access_Key这三项的值要替换成指定的s3用户信息。以admin用户为例,如果没有创建s3用户,可以使用命令radosgw-admin user create --uid=admin --display-name=admin进行创建,创建过程会输出这些信息。针对已经存在的s3用户,以admin用户为例,可以使用命令radosgw-admin user info –-uid=admin命令进程查询。

RGW配置项中的name值,可以使用命令ceph auth list进行查询。

6、启动ganesha-nfs

[root@controller-0 ~]# ganesha.nfsd -f /etc/ganesha/ganesha.conf -L /var/log/nfs-ganesha.log -N NIV_DEBUG

启动完成后,可以通过ps -ef | grep ganesha.nfsd 查询是否有生成对应的进程,如果没有,可以查看日志nfs-ganesha.log,根据日志中输出的信息进行一下检查。

7、挂载

[root@controller-0 ~]# showmount -e
Export list for controller-0:
[root@controller-0 ~]# mount -t nfs 10.0.10.10:/ /mnt/

因为rgw是没有文件系统的容量概念,所以挂载之后使用df是查询不到的,需要使用mount命令查看挂载信息

[root@controller-0 ~]# mount | grep mnt
10.0.10.10:/ on /mnt type nfs4 (rw,relatime,vers=4.1,rsize=1048576,wsize=1048576,namlen=255,hard,proto=tcp,timeo=600,retrans=2,sec=sys,clientaddr=10.0.10.10,local_lock=none,addr=10.0.10.10)

8、写入测试

进入挂载的mnt目录,在这个目录下创建新的目录,就相当于是在rgw中创建一个bucket,创建完成后使用s3cmd ls命令可以看到新生成了一个bucket

[root@controller-0 mnt]# mkdir test
[root@controller-0 mnt]# s3cmd ls
2018-09-04 08:39  s3://test

相关文章
|
6月前
|
存储 关系型数据库 API
Ceph RADOS Gateway安装
Ceph RADOS Gateway安装
|
5月前
|
Kubernetes 容器
K8s之部署nfs
K8s之部署nfs
|
存储 JSON Kubernetes
k8s配置glusterFS详解
k8s配置glusterFS详解
|
存储 关系型数据库 网络安全
使用ansible部署ceph集群
使用ansible部署ceph集群
使用ansible部署ceph集群
|
监控
glusterfs 监控
这里以监控gv_KVM这个卷为例 1.启动 Profiling [root@192_168_174_68 ~]# gluster gluster> volume profile gv_KVM start Starting volume profile on gv_KVM has been successful 2.
1619 0
|
Prometheus 监控 Cloud Native
使用 Promwwwzs12558comI3578II9877etheus 监控 Ceph
本文是在 Ubuntu 16.04 最新版基础上安装 Prometheus 监控系统,Ceph 版本为 Luminous 12.2.8。 1. 安装 Prometheus 直接使用 apt 安装的 Prometheus 版本较低,很多新的配置选项都已不再支持,建议使用 Prometheus 的安装包,接下来看看安装包部署的步骤。
2816 0
|
NoSQL 关系型数据库 MySQL
Harbor HA部署-使用Ceph RADOS后端
目录1. 前言2. 配置Ceph radosgw用户3. 部署HA的MariaDB集群4. 部署HA的Redis集群5. 部署Harbor集群参考资料   1. 前言 Harbor 1.4.0版本开始提供了HA部署方式,和非HA的主要区别就是把有状态的服务分离出来,使用外部集群,而不是运行在本地的容器上。
3526 0

热门文章

最新文章