kubernetes 上部署 Nacos NFS

系统环境
kubernetes 版本:1.14.0
nacos 版本:1.2.1
NFS 版本: V4

一、NFS 版本安装和配置

1、 NFS介绍

NFS是Network File System的简写,即网络文件系统,NFS是FreeBSD支持的文件系统中的一种。NFS基于RPC(Remote Procedure Call)远程过程调用实现,其允许一个系统在网络上与它人共享目录和文件。通过使用NFS,用户和程序就可以像访问本地文件一样访问远端系统上的文件。NFS是一个非常稳定的,可移植的网络文件系统。具备可扩展和高性能等特性,达到了企业级应用质量标准。由于网络速度的增加和延迟的降低,NFS系统一直是通过网络提供文件系统服务的有竞争力的选择 。

2、NFS原理

NFS 使用RPC(Remote Procedure Call)的机制进行实现,RPC使得客户端可以调用服务端的函数。同时,由于有 VFS 的存在,客户端可以像使用其它普通文件系统一样使用 NFS 文件系统。经由操作系统的内核,将 NFS 文件系统的调用请求通过 TCP/IP 发送至服务端的 NFS 服务。NFS服务器执行相关的操作,并将操作结果返回给客户端。

查看nfs 版本号 V4

nfsstat -s

主要配置文件:/etc/exports
查看命令

 cat /etc/exports
/mnt/nfs/ 192.168.0.0/25(rw,no_root_squash)
/data/nfs-share/ *(rw,no_root_squash)
/data/nacos/ *(rw,no_root_squash)

修改配置后执行 ,立即生效

exportfs -r

二、 Nacos V1.2.1 安装

a、创建K8s命名空间

ns.yaml

apiVersion: v1
kind: Namespace
metadata:
  name: sscloud

执行命令

kubectl create -f ns.yaml

b、创建角色

1、Role.yaml

kind: Role
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: leader-locking-nfs-client-provisioner
  namespace: sscloud  
rules:
- apiGroups: [""]
  resources: ["endpoints"]
  verbs: ["get", "list", "watch", "create", "update", "patch"]

执行命令

kubectl create -f Role.yaml

2、 RoleBinding.yaml

kind: RoleBinding
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: leader-locking-nfs-client-provisioner
  namespace: sscloud
subjects:
- kind: ServiceAccount
  name: nfs-client-provisioner
  # replace with namespace where provisioner is deployed
  namespace: sscloud
roleRef:
  kind: Role
  name: leader-locking-nfs-client-provisioner
  apiGroup: rbac.authorization.k8s.io

执行命令

kubectl create -f RoleBinding.yaml

3、 ClusterRole.yaml

kind: ClusterRole
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: nfs-client-provisioner-runner
  namespace: sscloud
rules:
- apiGroups: [""]
  resources: ["persistentvolumes"]
  verbs: ["get", "list", "watch", "create", "delete"]
- apiGroups: [""]
  resources: ["persistentvolumeclaims"]
  verbs: ["get", "list", "watch", "update"]
- apiGroups: [""]
  resources: ["endpoints"]
  verbs: ["get", "list", "watch", "create", "update", "patch"]
- apiGroups: ["storage.k8s.io"]
  resources: ["storageclasses"]
  verbs: ["get", "list", "watch"]
- apiGroups: [""]
  resources: ["events"]
  verbs: ["create", "update", "patch"]

执行命令

kubectl create -f ClusterRole.yaml

4、ClusterRoleBinding.yaml

kind: ClusterRoleBinding
apiVersion: rbac.authorization.k8s.io/v1
metadata:
  name: run-nfs-client-provisioner
  namespace: sscloud
subjects:
- kind: ServiceAccount
  name: nfs-client-provisioner
  namespace: sscloud
roleRef:
  kind: ClusterRole
  name: nfs-client-provisioner-runner
  apiGroup: rbac.authorization.k8s.io

执行命令

kubectl create -f ClusterRoleBinding.yaml

5、deployment.yaml

创建 ServiceAccount 和部署 NFS-Client Provisioner

apiVersion: v1
kind: ServiceAccount
metadata:
  name: nfs-client-provisioner
  namespace: sscloud
---
kind: Deployment
apiVersion: extensions/v1beta1
metadata:
  name: nfs-client-provisioner
  namespace: sscloud
spec:
  replicas: 1
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        app: nfs-client-provisioner
    spec:
      serviceAccount: nfs-client-provisioner
      containers:
      - name: nfs-client-provisioner
        image: registry.cn-hangzhou.aliyuncs.com/open-ali/nfs-client-provisioner:latest
        volumeMounts:
        - name: nfs-client-root
          mountPath: /persistentvolumes
        env:
        - name: PROVISIONER_NAME
          value: fuseim.pri/ifs
        - name: NFS_SERVER
          value: 192.168.0.249
        - name: NFS_PATH
          value: /data/nfs-share
      volumes:
      - name: nfs-client-root
        nfs:
          server: 192.168.0.249
          path: /data/nfs-share

执行命令

kubectl create -f deployment.yaml

6、创建 NFS StorageClass

class.yaml

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: managed-nfs-storage
  namespace: sscloud
provisioner: fuseim.pri/ifs
parameters:
  archiveOnDelete: "false"

执行命令

kubectl create -f class.yaml

验证NFS部署成功

kubectl get pod -l app=nfs-client-provisioner -n sscloud

三、部署数据库

mysql-nfs.yaml

apiVersion: v1
kind: ReplicationController
metadata:
  name: mysql
  namespace: sscloud
  labels:
    name: mysql
spec:
  replicas: 1
  selector:
    name: mysql
  template:
    metadata:
      namespace: sscloud
      labels:
        name: mysql
    spec:
      containers:
      - name: mysql
        image: nacos/nacos-mysql:5.7
        ports:
        - containerPort: 3306
        volumeMounts:
        - name: mysql-data
          mountPath: /var/lib/mysql
        env:
        - name: MYSQL_ROOT_PASSWORD
          value: "root"
        - name: MYSQL_DATABASE
          value: "nacos_devtest"
        - name: MYSQL_USER
          value: "nacos"
        - name: MYSQL_PASSWORD
          value: "nacos"
      volumes:
      - name: mysql-data
        nfs:
          server: 192.168.0.249
          path: /data/nfs-share/mysql
---
apiVersion: v1
kind: Service
metadata:
  name: mysql
  namespace: sscloud
  labels:
    name: mysql
spec:
  ports:
  - port: 3306
    targetPort: 3306
  selector:
    name: mysql

执行命令

kubectl create -f mysql-nfs.yaml

四、 部署Nacos

nacos-pvc-nfs.yaml

---
apiVersion: v1
kind: Service
metadata:
  name: nacos-headless
  namespace: sscloud
  labels:
    app: nacos
  annotations:
    service.alpha.kubernetes.io/tolerate-unready-endpoints: "true"
spec:
  ports:
    - port: 8848
      name: server
      targetPort: 8848
  clusterIP: None
  selector:
    app: nacos
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: nacos-cm
  namespace: sscloud
data:
  mysql.db.name: "nacos_devtest"
  mysql.port: "3306"
  mysql.user: "nacos"
  mysql.password: "nacos"
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: nacos
  namespace: sscloud
spec:
  serviceName: nacos-headless
  replicas: 3
  template:
    metadata:
      namespace: sscloud
      labels:
        app: nacos
      annotations:
        pod.alpha.kubernetes.io/initialized: "true"
    spec:
      affinity:
        podAntiAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            - labelSelector:
                matchExpressions:
                  - key: "app"
                    operator: In
                    values:
                      - nacos
              topologyKey: "kubernetes.io/hostname"
      serviceAccountName: nfs-client-provisioner
      initContainers:
        - name: peer-finder-plugin-install
          image: nacos/nacos-peer-finder-plugin:1.0
          imagePullPolicy: Always
          volumeMounts:
            - mountPath: "/home/nacos/plugins/peer-finder"
              name: plugindir
      containers:
        - name: nacos
          imagePullPolicy: Always
          image: nacos/nacos-server:latest
          resources:
            requests:
              memory: "2Gi"
              cpu: "500m"
          ports:
            - containerPort: 8848
              name: client-port
          env:
            - name: NACOS_REPLICAS
              value: "3"
            - name: SERVICE_NAME
              value: "nacos-headless"
            - name: DOMAIN_NAME
              value: "cluster.local"
            - name: POD_NAMESPACE
              valueFrom:
                fieldRef:
                  apiVersion: v1
                  fieldPath: metadata.namespace
            - name: MYSQL_SERVICE_DB_NAME
              valueFrom:
                configMapKeyRef:
                  name: nacos-cm
                  key: mysql.db.name
            - name: MYSQL_SERVICE_PORT
              valueFrom:
                configMapKeyRef:
                  name: nacos-cm
                  key: mysql.port
            - name: MYSQL_SERVICE_USER
              valueFrom:
                configMapKeyRef:
                  name: nacos-cm
                  key: mysql.user
            - name: MYSQL_SERVICE_PASSWORD
              valueFrom:
                configMapKeyRef:
                  name: nacos-cm
                  key: mysql.password
            - name: NACOS_SERVER_PORT
              value: "8848"
            - name: PREFER_HOST_MODE
              value: "hostname"
          volumeMounts:
            - name: plugindir
              mountPath: /home/nacos/plugins/peer-finder
            - name: datadir
              mountPath: /home/nacos/data
            - name: logdir
              mountPath: /home/nacos/logs
  volumeClaimTemplates:
    - metadata:
        name: plugindir
        annotations:
          volume.beta.kubernetes.io/storage-class: "managed-nfs-storage"
      spec:
        accessModes: [ "ReadWriteMany" ]
        resources:
          requests:
            storage: 5Gi
    - metadata:
        name: datadir
        annotations:
          volume.beta.kubernetes.io/storage-class: "managed-nfs-storage"
      spec:
        accessModes: [ "ReadWriteMany" ]
        resources:
          requests:
            storage: 5Gi
    - metadata:
        name: logdir
        annotations:
          volume.beta.kubernetes.io/storage-class: "managed-nfs-storage"
      spec:
        accessModes: [ "ReadWriteMany" ]
        resources:
          requests:
            storage: 5Gi
  selector:
    matchLabels:
      app: nacos

执行命令

kubectl create -f nacos-pvc-nfs.yaml

对外暴露端口
nacos-nodeport.yaml

apiVersion: v1
kind: Service
metadata:
  name: nacos-nodeport
  namespace: sscloud
  labels:
    app: nacos-nodeport
spec:
  type: NodePort
  ports:
    - name: nacos
      port: 8848
      targetPort: 8848
      nodePort: 32000
  selector:
    app: nacos

部署完毕, 访问 http://192.168.0.249:32000/nacos
249 是 k8s 主节点
在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Linux上进行单机部署Nacos,你可以按照以下步骤进行操作: 1. 首先,你需要准备好Nacos-2.0.3的安装包。你可以参考《Linux部署Nacos-2.0.3集群环境》或《Docker部署Nacos-2.0.3单机环境》来获取安装包的具体步骤和下载链接。 2. 下载安装包后,你需要创建一个自启服务,以便在系统启动时自动启动Nacos。你可以使用命令行编辑器(如vim)打开一个新的nacos.service文件: ``` vim /usr/lib/systemd/system/nacos.service ``` 在该文件中,你需要配置一些必要的信息,如Nacos的安装路径、启动命令等。你可以参考《Docker部署Nacos-2.0.3单机环境》中的自启服务配置来设置。确保你在文件中正确地指定了Nacos的安装路径和启动命令。 3. 保存并退出nacos.service文件后,你可以使用以下命令来启动Nacos: ``` cd /opt/cloud/nacos/bin sh startup.sh -m standalone ``` 这将进入Nacos的安装目录,并执行startup.sh脚本来启动Nacos。通过参数“-m standalone”,你将以单机模式启动Nacos。 请注意,以上步骤仅提供了在Linux上进行单机部署Nacos的基本指南。具体的实施细节可能会因你的操作系统、Nacos版本等因素而有所不同。为了确保成功部署Nacos,建议你参考官方文档或相关教程进行更详细的了解和操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Nacos(一)Linux部署Nacos单机环境(兼容Nacos1.x与2.x)](https://blog.csdn.net/zhuocailing3390/article/details/123056124)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值