在minikube中部署MySQL、Nacos、Redis

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 在minikube中部署MySQL、Nacos、Redis

部署MySQL、Nacos、Redis

1. 安装mysql

在安装mysql的适合用到了若依的初始化数据,所以需要使用docker compose build ruoyi-mysql 建立镜像。

使用加载镜像:minikube image load mysql镜像

我在部署Mysql时没有用到k8s的存储,此处可以进行自行修改。下面是yaml文件内容:

 

apiVersion: apps/v1

kind: Deployment # 副本控制器RC

metadata:

 name: mysql #RC 的名称,全局唯一

 namespace: default # 默认空间

spec:

 replicas: 1 #Pod 副本的期待数量

 selector:

   matchLabels:

     app: mysql # 符合目标的Pod拥有此标签

 template: # 根据此模版创建Pod的副本

   metadata:

     labels:

       app: mysql # Pod副本拥有的标签,对应RC的Selector

   spec:

     containers: # Pod的内容的定义部分

       - name: mysql # 容器的名称

         image: ry-mysql # 容器对应的Docker Image

         imagePullPolicy: IfNotPresent

         ports:

           - containerPort: 3306 # 容器应用监听的端口号

         env:

           - name: MYSQL_ROOT_PASSWORD # 设置mysql的初始化密码

             value: "password" # 设置mysql的初始化密码

         volumeMounts:

           - name: mysql-data

             mountPath: /var/lib/mysql

     volumes:

       - name: mysql-data

         hostPath:

           path: /var/lib/mysql

---

apiVersion: v1

kind: Service # 表明是Kubernetes Service

metadata:

 name: mysql # Service 的全局唯一名称

spec:

 type: NodePort

 selector:

   app: mysql

 ports: # Service 提供服务的端口

   - port: 3306 # Service 对应的Pod拥有这里定义的标签

     targetPort: 3306

 

 

 

2. 安装Nacos

此处安装需要注意mysql的连接地址和SPRING_DATASOURCE_PLATFORM此参数一定要配置,要不然莫名其妙的使用内嵌数据库,不知道为啥在docker compose和单独部署没有问题,在minikube中部署一定要此参数,此变量折腾了我2天.....

---

apiVersion: v1

kind: ConfigMap

metadata:

 name: nacos-cm-cpf1

data:

 application.properties:  |

   # spring

   server.servlet.contextPath=${SERVER_SERVLET_CONTEXTPATH:/nacos}

   server.contextPath=/nacos

   server.port=${NACOS_APPLICATION_PORT:8848}

   server.tomcat.accesslog.max-days=30

   server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D %{User-Agent}i %{Request-Source}i

   server.tomcat.accesslog.enabled=${TOMCAT_ACCESSLOG_ENABLED:false}

   # default current work dir

   server.tomcat.basedir=file:.

   #*************** Config Module Related Configurations ***************#

   ### Deprecated configuration property, it is recommended to use `spring.sql.init.platform` replaced.

   #spring.datasource.platform=mysql

   spring.sql.init.platform=${SPRING_DATASOURCE_PLATFORM:mysql}

 

   db.num=${MYSQL_DATABASE_NUM:1}

   db.url.0=jdbc:mysql://${MYSQL_SERVICE_HOST}:${MYSQL_SERVICE_PORT:3306}/${MYSQL_SERVICE_DB_NAME}?${MYSQL_SERVICE_DB_PARAM:characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false}

   db.user.0=${MYSQL_SERVICE_USER}

   db.password.0=${MYSQL_SERVICE_PASSWORD}

 

 

 

 

---

apiVersion: v1

kind: ConfigMap

metadata:

 name: nacos-cm-cpf

data:

 application.properties:  |

   # spring

   server.servlet.contextPath=${SERVER_SERVLET_CONTEXTPATH:/nacos}

   server.contextPath=/nacos

   server.port=${NACOS_APPLICATION_PORT:8848}

   server.tomcat.accesslog.max-days=30

   server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D %{User-Agent}i %{Request-Source}i

   server.tomcat.accesslog.enabled=${TOMCAT_ACCESSLOG_ENABLED:false}

   # default current work dir

   server.tomcat.basedir=file:.

   #*************** Config Module Related Configurations ***************#

   ### Deprecated configuration property, it is recommended to use `spring.sql.init.platform` replaced.

   #spring.datasource.platform=mysql

   spring.sql.init.platform=${SPRING_DATASOURCE_PLATFORM:}

   nacos.cmdb.dumpTaskInterval=3600

   nacos.cmdb.eventTaskInterval=10

   nacos.cmdb.labelTaskInterval=300

   nacos.cmdb.loadDataAtStart=false

   db.num=${MYSQL_DATABASE_NUM:1}

   db.url.0=jdbc:mysql://${MYSQL_SERVICE_HOST}:${MYSQL_SERVICE_PORT:3306}/${MYSQL_SERVICE_DB_NAME}?${MYSQL_SERVICE_DB_PARAM:characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useSSL=false}

   db.user.0=${MYSQL_SERVICE_USER}

   db.password.0=${MYSQL_SERVICE_PASSWORD}

   ### The auth system to use, currently only 'nacos' and 'ldap' is supported:

   nacos.core.auth.system.type=${NACOS_AUTH_SYSTEM_TYPE:nacos}

   ### worked when nacos.core.auth.system.type=nacos

   ### The token expiration in seconds:

   nacos.core.auth.plugin.nacos.token.expire.seconds=${NACOS_AUTH_TOKEN_EXPIRE_SECONDS:18000}

   ### The default token:

   nacos.core.auth.plugin.nacos.token.secret.key=${NACOS_AUTH_TOKEN:SecretKey012345678901234567890123456789012345678901234567890123456789}

   ### Turn on/off caching of auth information. By turning on this switch, the update of auth information would have a 15 seconds delay.

   nacos.core.auth.caching.enabled=${NACOS_AUTH_CACHE_ENABLE:false}

   nacos.core.auth.enable.userAgentAuthWhite=${NACOS_AUTH_USER_AGENT_AUTH_WHITE_ENABLE:false}

   nacos.core.auth.server.identity.key=${NACOS_AUTH_IDENTITY_KEY:serverIdentity}

   nacos.core.auth.server.identity.value=${NACOS_AUTH_IDENTITY_VALUE:security}

   ## spring security config

   ### turn off security

   nacos.security.ignore.urls=${NACOS_SECURITY_IGNORE_URLS:/,/error,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.ico,/console-fe/public/**,/v1/auth/**,/v1/console/health/**,/actuator/**,/v1/console/server/**}

   # metrics for elastic search

   management.metrics.export.elastic.enabled=false

   management.metrics.export.influx.enabled=false

   nacos.naming.distro.taskDispatchThreadCount=10

   nacos.naming.distro.taskDispatchPeriod=200

   nacos.naming.distro.batchSyncKeyCount=1000

   nacos.naming.distro.initDataRatio=0.9

   nacos.naming.distro.syncRetryDelay=5000

   nacos.naming.data.warmup=true

 

 

 

---

apiVersion: v1

kind: Service

metadata:

 name: nacos-headless-cpf

 labels:

   app: nacos-headless-cpf

spec:

 type: NodePort

#  clusterIP: None

 ports:

   - port: 8848

     name: server

     targetPort: 8848

#      nodePort: 30000

   - port: 9848

     name: client-rpc

     targetPort: 9848

   - port: 9849

     name: raft-rpc

     targetPort: 9849

   ## 兼容1.4.x版本的选举端口

   - port: 7848

     name: old-raft-rpc

     targetPort: 7848

 selector:

   app: nacos-cpf

---

apiVersion: v1

kind: ConfigMap

metadata:

 name: nacos-cm

data:

 mysql.host: "mysql"

 mysql.db.name: "ry-config"

 mysql.port: "3306"

 mysql.user: "root"

 mysql.password: "password"

 

 

---

apiVersion: apps/v1

kind: StatefulSet

metadata:

 name: nacos-cpf

spec:

 serviceName: nacos-headless

 replicas: 1

 template:

   metadata:

     labels:

       app: nacos-cpf

     annotations:

       pod.alpha.kubernetes.io/initialized: "true"

   spec:

     volumes:

       - name: application-conf

         configMap:

           name: nacos-cm-cpf

     containers:

       - name: k8snacos-cpf

         imagePullPolicy: IfNotPresent

         image: nacos/nacos-server:latest

         resources:

           requests:

             memory: "1Gi"

             cpu: "500m"

         ports:

           - containerPort: 8848

             name: client

           - containerPort: 9848

             name: client-rpc

           - containerPort: 9849

             name: raft-rpc

           - containerPort: 7848

             name: old-raft-rpc

         env:

           - name: MODE

             value: "standalone"

           - name: SPRING_DATASOURCE_PLATFORM #此参数必须配置,要不然出现莫名其妙的问题而不能启动

             value: "mysql"

#            - name: NACOS_REPLICAS

#              value: "1"

           - name: MYSQL_SERVICE_HOST

             valueFrom:

               configMapKeyRef:

                 name: nacos-cm

                 key: mysql.host

           - 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: NACOS_APPLICATION_PORT

             value: "8848"

           - name: PREFER_HOST_MODE

             value: "hostname"

#            - name: NACOS_SERVERS

#              value: "nacos-0.nacos-headless.default.svc.cluster.local:8848 nacos-1.nacos-headless.default.svc.cluster.local:8848 nacos-2.nacos-headless.default.svc.cluster.local:8848"

         volumeMounts:

           - name: application-conf

             mountPath: /home/nacos/conf/application.properties

             readOnly: true

             subPath: application.properties

#            - name: application-conf

#              mountPath: /home/nacos/conf/nacos-logback.xml

#              readOnly: true

#              subPath: nacos-logback.xml

 

 

 selector:

   matchLabels:

     app: nacos-cpf

 

 

3. 安装Redis

安装redis没有遇到啥坑,直接安装就可以。

apiVersion: apps/v1

kind: Deployment

metadata:

 name: redis

 labels:

   app: redis

spec:

 strategy:

   type: Recreate

 selector:

   matchLabels:

     app: redis

 template:

   metadata:

     labels:

       app: redis

   spec:

     containers:

     - name: redis

       image: redis

       imagePullPolicy: IfNotPresent

#        command: ["redis-server","/etc/redis/redis.conf"]

       ports:

       - containerPort: 6379

 

---

kind: Service

apiVersion: v1

metadata:

 name: redis

spec:

 type: ClusterIP

 selector:

   app: redis

 ports:

 - port: 6379


代码地址:https://gitee.com/cpf84/myminikube 欢迎star

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
11天前
|
SQL 关系型数据库 MySQL
docker-compose部署mysql8
使用docker-compose容器化部署mysql8
|
21天前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
82 14
|
18天前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
68 7
|
1月前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
148 26
|
27天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
175 7
|
1月前
|
Java 关系型数据库 MySQL
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
68 5
|
1月前
|
存储 缓存 NoSQL
解决Redis缓存数据类型丢失问题
解决Redis缓存数据类型丢失问题
175 85
|
3月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
92 6
|
6天前
|
存储 缓存 NoSQL
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应
|
6天前
|
缓存 NoSQL 关系型数据库
云端问道21期实操教学-应对高并发,利用云数据库 Tair(兼容 Redis®)缓存实现极速响应
本文介绍了如何通过云端问道21期实操教学,利用云数据库 Tair(兼容 Redis®)缓存实现高并发场景下的极速响应。主要内容分为四部分:方案概览、部署准备、一键部署和完成及清理。方案概览中,展示了如何使用 Redis 提升业务性能,降低响应时间;部署准备介绍了账号注册与充值步骤;一键部署详细讲解了创建 ECS、RDS 和 Redis 实例的过程;最后,通过对比测试验证了 Redis 缓存的有效性,并指导用户清理资源以避免额外费用。