在minikube中部署MySQL、Nacos、Redis

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容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搭建和管理企业级网站应用
相关文章
|
21天前
|
SQL Java 关系型数据库
MySQL原理简介—3.生产环境的部署压测
本文介绍了Java系统和数据库在高并发场景下的压测要点: 1. 普通系统在4核8G机器上每秒能处理几百个请求 2. 高并发下数据库建议使用8核16G或更高配置的机器 3. 数据库部署后需进行基准压测,以评估其最大承载能力 4. QPS和TPS的区别及重要性 5. 压测时需关注IOPS、吞吐量、延迟 6. 除了QPS和TPS,还需监控CPU、内存、磁盘IO、网络带宽 7. 影响每秒可处理并发请求数的因素包括线程数、CPU、内存、磁盘IO和网络带宽 8. Sysbench是数据库压测工具,可构造测试数据并模拟高并发场景 9. 在增加线程数量的同时,必须观察机器的性能,确保各硬件负载在合理范围
122 72
|
16天前
|
存储 NoSQL Redis
Docker 部署 Redis
在使用 Docker 部署 Redis 时,为实现数据持久化,需正确挂载容器内的数据目录到宿主机。推荐命令如下: ``` docker run -d --name redis -v /mnt/data/redis:/data -p 6379:6379 redis ``` 该命令将宿主机的 `/mnt/data/redis` 目录挂载到容器的 `/data` 目录,确保 Redis 数据持久化。此路径更通用,适合大多数场景。避免使用不匹配的挂载路径,如 `/var/lib/redis` 或 `/mnt/data/redis` 到非默认目录,以防止数据无法正确持久化。
|
30天前
|
存储 关系型数据库 MySQL
美团面试:MySQL为什么 不用 Docker部署?
45岁老架构师尼恩在读者交流群中分享了关于“MySQL为什么不推荐使用Docker部署”的深入分析。通过系统化的梳理,尼恩帮助读者理解为何大型MySQL数据库通常不使用Docker部署,主要涉及性能、管理复杂度和稳定性等方面的考量。文章详细解释了有状态容器的特点、Docker的资源隔离问题以及磁盘IO性能损耗,并提供了小型MySQL使用Docker的最佳实践。此外,尼恩还介绍了Share Nothing架构的优势及其应用场景,强调了配置管理和数据持久化的挑战。最后,尼恩建议读者参考《尼恩Java面试宝典PDF》以提升技术能力,更好地应对面试中的难题。
|
28天前
|
缓存 NoSQL 关系型数据库
Redis与MySQL的数据一致性
在高并发环境下,保持 Redis 和 MySQL 的数据一致性是一个复杂但重要的问题。通过采用读写穿透、写穿透、分布式锁、双写一致性保障和延时双删策略,可以有效地减少数据不一致的风险,确保系统的稳定性和可靠性。通过合理的缓存策略和数据同步机制,可以显著提升系统的性能和用户体验。
92 22
|
1月前
|
SQL 关系型数据库 MySQL
docker-compose部署mysql8
使用docker-compose容器化部署mysql8
|
1月前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
135 7
|
2月前
|
存储 网络协议 Nacos
高效搭建Nacos:实现微服务的服务注册与配置中心
Nacos(Dynamic Naming and Configuration Service)是阿里巴巴开源的一款动态服务发现、配置管理和服务管理平台。它旨在帮助开发者更轻松地构建、部署和管理分布式系统,特别是在微服务架构中。
560 81
高效搭建Nacos:实现微服务的服务注册与配置中心
|
3天前
|
Cloud Native Java Nacos
springcloud/springboot集成NACOS 做注册和配置中心以及nacos源码分析
通过本文,我们详细介绍了如何在 Spring Cloud 和 Spring Boot 中集成 Nacos 进行服务注册和配置管理,并对 Nacos 的源码进行了初步分析。Nacos 作为一个强大的服务注册和配置管理平台,为微服务架构提供
29 14
|
2月前
|
JSON Java Nacos
SpringCloud 应用 Nacos 配置中心注解
在 Spring Cloud 应用中可以非常低成本地集成 Nacos 实现配置动态刷新,在应用程序代码中通过 Spring 官方的注解 @Value 和 @ConfigurationProperties,引用 Spring enviroment 上下文中的属性值,这种用法的最大优点是无代码层面侵入性,但也存在诸多限制,为了解决问题,提升应用接入 Nacos 配置中心的易用性,Spring Cloud Alibaba 发布一套全新的 Nacos 配置中心的注解。
362 20
|
3月前
|
监控 Java 测试技术
Nacos 配置中心变更利器:自定义标签灰度
本文是对 MSE Nacos 应用自定义标签灰度的功能介绍,欢迎大家升级版本进行试用。
607 19