首页 > 其他分享 >k8s 安装nacos集群

k8s 安装nacos集群

时间:2024-08-18 14:38:32浏览次数:10  
标签:protocol name nacos TCP server 集群 mysql k8s

需求

使用k8s部署nacos集群,nacos的数据主要保存在mysql中,因此nacos运行时不需要考虑持久化问题。

这里使用2.3.2版本

 

导入mysql数据

github地址:https://github.com/alibaba/nacos/releases

找到2.3.2版本,下载压缩包,得到nacos-server-2.3.2.tar.gz

解压文件,找到文件nacos\conf\mysql-schema.sql

mysql-schema.sql,就是nacos的初始化sql

 

使用客户端工具DBeaver连接到mysql,创建数据库nacos

CREATE DATABASE nacos CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

新建数据库用户nacos_all并授权

CREATE USER 'nacos_all'@'%' IDENTIFIED BY 'abcd@1234';

GRANT ALL PRIVILEGES ON nacos . * TO 'nacos_all'@'%';

FLUSH PRIVILEGES;

 

切换到数据库nacos,执行sql文件mysql-schema.sql,执行完成后,会得到相应的数据表。

编写yaml

nacos-server.yaml

apiVersion: v1
kind: ConfigMap
metadata:
  name: nacos-server-config
  namespace: middleware
data:
  MODE: cluster
  MYSQL_SERVICE_DB_NAME: nacos
  MYSQL_SERVICE_HOST: 192.168.20.131
  MYSQL_SERVICE_USER: nacos_all
  MYSQL_SERVICE_PASSWORD: abcd@1234
  MYSQL_SERVICE_PORT: "3306"
  NACOS_REPLICAS: "3"
  NACOS_SERVER_PORT: "8848"
  NACOS_SERVERS: nacos-server-0.nacos-server-svc.middleware.svc.cluster.local:8848 nacos-server-1.nacos-server-svc.middleware.svc.cluster.local:8848 nacos-server-2.nacos-server-svc.middleware.svc.cluster.local:8848
  PREFER_HOST_MODE: hostname
  SPRING_DATASOURCE_PLATFORM: mysql
  NACOS_AUTH_ENABLE: "false"
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  generation: 15
  labels:
    app: nacos-server
  managedFields:
    - apiVersion: apps/v1
      operation: Update
    - apiVersion: apps/v1
      manager: kube-controller-manager
      operation: Update
      subresource: status
  name: nacos-server
  namespace: middleware
spec:
  podManagementPolicy: OrderedReady
  replicas: 3
  revisionHistoryLimit: 10
  selector:
    matchLabels:
      app: nacos-server
  serviceName: nacos-server-svc
  template:
    metadata:
      labels:
        app: nacos-server
    spec:
      containers:
        - envFrom:
            - configMapRef:
                name: nacos-server-config
          image: 'nacos/nacos-server:v2.3.2'
          imagePullPolicy: IfNotPresent
          name: nacos-server
          ports:
            - containerPort: 8848
              name: web
              protocol: TCP
            - containerPort: 7848
              name: g1
              protocol: TCP
            - containerPort: 9848
              name: g2
              protocol: TCP
            - containerPort: 9849
              name: g3
              protocol: TCP
          resources:
            limits:
              cpu: '0.6'
              ephemeral-storage: 2Gi
            requests:
              cpu: 400m
              memory: 128Mi
          terminationMessagePath: /dev/termination-log
          terminationMessagePolicy: File
      dnsPolicy: ClusterFirst
      restartPolicy: Always
---
apiVersion: v1
kind: Service
metadata:
  name: nacos-server-svc
  namespace: middleware
spec:
  ports:
  - name: web
    port: 8848
    protocol: TCP
    targetPort: 8848
    nodePort: 30788
  - name: grbc
    port: 7848
    protocol: TCP
    targetPort: 7848
  - name: g2
    port: 9848
    protocol: TCP
    targetPort: 9848
    nodePort: 31788
  - name: g3
    port: 9849
    protocol: TCP
    targetPort: 9849
    nodePort: 31789
  selector:
    app: nacos-server
  type: NodePort

这里的nacos直接部署在middleware命名空间,注意修改上面的mysql相关参数。

NACOS_AUTH_ENABLE: "false"

这个参数必须要有,如果没有,默认会开启认证

由于java项目都运行在k8s里面,因此内网访问,就不需要开启nacos认证了。

 

创建命名空间

kubectl create namespace middleware

部署应用

kubectl apply -f nacos-server.yaml

 

等待几分钟,确保3个pod都是Running状态

 

访问nacos页面,这里使用的nodeport方式暴露端口

http://172.16.0.13:30733/nacos/

默认用户名和密码,都是nacos

 

点击左侧的clusterManagement-->Cluster Node List,确保3个节点是UP状态

 

标签:protocol,name,nacos,TCP,server,集群,mysql,k8s
From: https://www.cnblogs.com/xiao987334176/p/18365617

相关文章

  • 微服务通过nacos实现动态路由
    ♥️作者:小宋1021......
  • RocketMQ集群ACL设置
    一、概述因安全需求,需要对RocketMQ添加ACL设置注意:ACL功能需要高版本支持,低版本不行,本文使用的版本为4.9.4 关于搭建RocketMQ集群,请参考链接:https://www.cnblogs.com/xiao987334176/p/16771899.html 二、配置修改配置文件broker-a/broker-a.conf,broker-b/broker-b.conf最......
  • CentOS7部署Kubernetes高可用集群(上)
    目录kubernetes介绍kubernetes具备的功能kubernetes集群角色kubernetes集群类型kubernetes集群规划kubernetes集群环境准备 部署HAProxy及Keepalivedkubernetes集群部署方式介绍kubeadm部署kubernetes集群kubernetes集群初始化部署Pod网络插件Calico部署Nginx测试......
  • 部署 K8s 图形化管理工具 Dashboard
    目录一、Dashboard概述二、GitHub地址三、Dashboard部署安装1、选择兼容版本2、下载配置文件3、添加Dashboard的Service类型4、应用部署5、查看kubernetes-dashboard命名空间下资源状态6、创建访问账户7、授权8、获取账号token9、1.24版本以后的需要创建一个Pod四、浏览器......
  • 登录 k8s-Dashboard 显示 Your connection is not private
    目录一、背景二、解决方案一、背景部署好kubernetes-Dashboard后使用master节点的ip+port登录Dashboard显示Yourconnectionisnotprivate无论是Edge还是GoogleChrome都是这样的情况二、解决方案点击网页空白处,英文输入法输入:thisisunsafe即可正常访问......
  • k8s安全机制
    目录1.认证(Authentication)2. 鉴权(Authorization)3.准入控制(AdmissionControl)Kubernetes作为一个分布式集群的管理工具,保证集群的安全性是其一个重要的任务。APIServer是集群内部各个组件通信的中介,也是外部控制的入口。所以Kubernetes的安全机制基本就是围绕保护......
  • DolphinScheduler集群部署问题(趟坑)总结
    目录官方文档官方项目地址问题解决官方文档DolphinScheduler|文档中心(apache.org)官方项目地址部署及使用过程中的问题可以参见项目Issue:Issues·apache/dolphinscheduler·GitHubGitHub-apache/dolphinschedulerat3.2.2-release问题解决1、JVM在运......
  • k8s集群
    环境初始化#重命名[root@localhost~]#hostnamectlset-hostnamemaster1[root@localhost~]#susu#配置静态IP[root@master1~]#cd/etc/sysconfig/network-scripts/[root@master1network-scripts]#vimifcfg-ens33BOOTPROTO="none"NAME="ens33"DEV......
  • 通过Rancher管理Kubernetes 集群
    目录1.Rancher2.Rancher安装及配置2.1安装rancher2.2 rancher的浏览器使用1.RancherRancher是一个开源的企业级多集群Kubernetes管理平台,实现了Kubernetes集群在混合云+本地数据中心的集中部署与管理,以确保集群的安全性,加速企业数字化转型。超过40000家企......
  • 信创环境:鲲鹏ARM+麒麟V10离线部署K8s和Rainbond信创平台
    在上篇《国产化信创开源云原生平台》文章中,我们介绍了Rainbond作为可能是国内首个开源国产化信创平台,在支持国产化和信创方面的能力,并简要介绍了如何在国产化信创环境中在线部署Kubernetes和Rainbond。然而,对于大多数国产化信创环境,如银行、政府等机构,离线部署的需求更为普......