在minikube中部署MySQL、Nacos、Redis

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 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搭建和管理企业级网站应用
相关文章
|
10天前
|
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. 在增加线程数量的同时,必须观察机器的性能,确保各硬件负载在合理范围
113 72
|
5天前
|
存储 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` 到非默认目录,以防止数据无法正确持久化。
|
20天前
|
存储 关系型数据库 MySQL
美团面试:MySQL为什么 不用 Docker部署?
45岁老架构师尼恩在读者交流群中分享了关于“MySQL为什么不推荐使用Docker部署”的深入分析。通过系统化的梳理,尼恩帮助读者理解为何大型MySQL数据库通常不使用Docker部署,主要涉及性能、管理复杂度和稳定性等方面的考量。文章详细解释了有状态容器的特点、Docker的资源隔离问题以及磁盘IO性能损耗,并提供了小型MySQL使用Docker的最佳实践。此外,尼恩还介绍了Share Nothing架构的优势及其应用场景,强调了配置管理和数据持久化的挑战。最后,尼恩建议读者参考《尼恩Java面试宝典PDF》以提升技术能力,更好地应对面试中的难题。
|
17天前
|
缓存 NoSQL 关系型数据库
Redis与MySQL的数据一致性
在高并发环境下,保持 Redis 和 MySQL 的数据一致性是一个复杂但重要的问题。通过采用读写穿透、写穿透、分布式锁、双写一致性保障和延时双删策略,可以有效地减少数据不一致的风险,确保系统的稳定性和可靠性。通过合理的缓存策略和数据同步机制,可以显著提升系统的性能和用户体验。
76 22
|
1月前
|
SQL 关系型数据库 MySQL
docker-compose部署mysql8
使用docker-compose容器化部署mysql8
|
2月前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
127 14
|
1月前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
122 7
|
NoSQL 关系型数据库 PHP
|
9天前
|
缓存 NoSQL 中间件
Redis,分布式缓存演化之路
本文介绍了基于Redis的分布式缓存演化,探讨了分布式锁和缓存一致性问题及其解决方案。首先分析了本地缓存和分布式缓存的区别与优劣,接着深入讲解了分布式远程缓存带来的并发、缓存失效(穿透、雪崩、击穿)等问题及应对策略。文章还详细描述了如何使用Redis实现分布式锁,确保高并发场景下的数据一致性和系统稳定性。最后,通过双写模式和失效模式讨论了缓存一致性问题,并提出了多种解决方案,如引入Canal中间件等。希望这些内容能为读者在设计分布式缓存系统时提供有价值的参考。感谢您的阅读!
Redis,分布式缓存演化之路
|
2月前
|
存储 缓存 NoSQL
解决Redis缓存数据类型丢失问题
解决Redis缓存数据类型丢失问题
187 85

推荐镜像

更多