KubeSphere中间件部署

devtools/2024/12/22 19:08:21/

中间件部署实战 · 语雀

RuoYi-Cloud部署实战 · 语雀

https://www.bilibili.com/video/BV13Q4y1C7hS?p=79

1. 应用部署三要素

应用的部署方式(Deployment、StatefulSet、DaemonSet)

应用的数据挂载(数据、配置文件)

应用的可访问性(Service)

在这里插入图片描述

2. 部署MySQL

2.1 DockerHub官网了解

去DockerHub找到镜像

在这里插入图片描述

参考官网的命令,启动一个MySQL实例(比如用docker的话-e是指定环境变量)

docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag

在这里插入图片描述

官网上对镜像也有描述:MySQL的配置文件在/etc/mysql/my.cnf下,

在这里插入图片描述

使用自定义MySQL配置文件

MySQL的默认配置在/etc/mysql/my.cnf中。它可能会包含其他目录,如/etc/mysql/conf.d/etc/mysql/mysql.conf.d

请检查mysql镜像本身中的相关文件和目录以了解更多详细信息。

如果/my/custom/config-file.cnf是您的自定义配置文件的路径和名称,您可以像这样启动您的mysql容器(注意,只有自定义的目录路径config文件用于此命令)

docker run --name some-mysql -v /my/custom:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag

这将启动一个新的容器some-mysql,其中mysql实例使用/etc/mysql/my.cnf/etc/mysql/conf.d/config-file.cnf的组合启动设置,后者的设置优先。

不带cnf文件的配置

许多配置选项可作为标志传递给mysqld。这将使您能够灵活地自定义容器,而不需要cnf文件。例如,将所有表的默认编码和排序规则更改为使用UTF-8(utf8mb4),运行以下命令:

docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

查看可用选项的完整列表,运行:

docker run -it --rm mysql:tag --verbose --help

2.2 以前用Docker启动MySQL容器

docker run -p 3306:3306 --name mysql-01 \
-v /mydata/mysql/log:/var/log/mysql \
-v /mydata/mysql/data:/var/lib/mysql \
-v /mydata/mysql/conf:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=root \
--restart=always \
-d mysql:5.7 

2.3 分析

在这里插入图片描述

Pod里面是使用官方镜像的Mysql容器

启动时指定环境变量MYSQL_ROOT_PASSWORD

MySql的所有数据在容器内/var/lib/mysql路径下,此目录应以PVC方式挂载出来

配置文件在容器内/etc/mysql/conf.d路径下,k8s中,中间件的配置文件可以以configMap的方式做配置集

2.4 Mysql配置

部署Mysql之前,先把Mysql的ConfigMap做出来,在/etc/mysql/conf.d路径下以.cnf结尾的文件都会被Mysql识别为配置文件,所以ConfigMap的key可以写作my.cnf

在这里插入图片描述

mysql配置具体内容(ConfigMap的Value)

[client]
default-character-set=utf8mb4[mysql]
default-character-set=utf8mb4[mysqld]
init_connect='SET collation_connection = utf8mb4_unicode_ci'
init_connect='SET NAMES utf8mb4'
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
skip-character-set-client-handshake
skip-name-resolve

2.5 PVC

本次采用先创建好,在后续创建副本集时直接选用,其实也可以在创建副本集时直接创建挂载卷。

系统内有默认的nfs存储类型

弹幕:没有nfs-storage的,要装一下nfs服务器,并设置为默认默认存储,参照kubernetes上安装kubesphere第三节的第一小节

有状态服务一般使用单节点读写,无状态的使用多节点读写

创建完后该卷是【未挂载】的状态。

在这里插入图片描述

2.6 创建有状态副本集

可以限制cpu和内存,但可以不预留

在这里插入图片描述

页面下边环境变量配置好MYSQL_ROOT_PASSWORD=my-secret-pw

勾选【同步主机时区】

添加存储卷,选择前一步创建好的PVC并设置路径

在这里插入图片描述

挂载配置文件或秘钥,选择先前创建好的并设置路径。创建ConfigMap时命名的key(my.cnf)将作为文件名添加到该路径下。

在这里插入图片描述

在这里插入图片描述

启动好之后,可以进容器内部查看文件

在这里插入图片描述

在页面上更改了ConfigMap的配置内容,会同步到容器里面的该配置文件,但Mysql不支持热更新,还是需要重启生效。

1、集群内部,直接通过应用的 【服务名.项目名】 直接访问mysql -uroot -hhis-mysql-glgf.his -p

2、集群外部,需要添加配置

在这里插入图片描述

3. 部署Redis

3.1 以前用Docker启动Redis

# 创建配置文件
## 1、准备redis配置文件内容
mkdir -p /mydata/redis/conf && vim /mydata/redis/conf/redis.conf
## 2、配置文件内容示例
appendonly yes
port 6379
bind 0.0.0.0# docker启动redis
## 弹幕:新版本好像变成/usr/local/etc/redis/路径存放配置文件了
docker run -d -p 6379:6379 --restart=always \
-v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf \
-v  /mydata/redis-01/data:/data \--name redis-01 redis:6.2.5 \redis-server /etc/redis/redis.conf

3.2 分析

Redis想持久化存储,加参数--appendonly yes

redis默认数据目录是/data,

准备一个Redis的Pod,

在这里插入图片描述

Redis要自定义配置文件,启动命令就变了

后续在页面上的创建操作与前面Mysql雷同

4. 部署ElasticSearch

4.1 以前用Docker启动

# 创建数据目录
mkdir -p /mydata/es-01 && chmod 777 -R /mydata/es-01# 容器启动
docker run --restart=always -d -p 9200:9200 -p 9300:9300 \
-e "discovery.type=single-node" \
-e ES_JAVA_OPTS="-Xms512m -Xmx512m" \
-v es-config:/usr/share/elasticsearch/config \
-v /mydata/es-01/data:/usr/share/elasticsearch/data \
--name es-01 \
elasticsearch:7.13.4

4.2 分析

数据可以挂载到外边的PVC

但是配置文件只想挂载该路径下所有文件中的两个:elasticsearch.yml和jvm.options,需要在ConfigMap中准备两个配置项,key分别是两个文件的文件名

在这里插入图片描述

注意: 子路径挂载,配置修改后,k8s不会对其Pod内的相关配置文件进行热更新,需要自己重启Pod

页面上操作时,因为不是映射全部的/usr/share/elasticsearch/config,所以要注意设置子路径

在这里插入图片描述

在【选择特定的键和路径】下选择ConfigMap中对应的配置

在这里插入图片描述

5. 应用商店

可以使用具有更高权限的管理员账户登录,从应用商店部署

6. 应用仓库

使用企业空间管理员登录,设置应用仓库

学习Helm即可,去helm的应用市场添加一个仓库地址,比如:bitnami


http://www.ppmy.cn/devtools/2872.html

相关文章

K8S之Resource Quotas

参考文档:资源配额 | Kubernetes 1.Resource Quotas:资源配额管理 当多个用户或团队共享具有固定节点数目的集群时,人们会担心有人使用超过其基于公平原则所分配到的资源量。 资源配额是帮助管理员解决这一问题的工具。 资源配额&#xff0c…

Linux安装docker(含Centos系统和Ubuntu系统)

一、Centos系统 1. 卸载旧版本依赖 sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine 2. 设置仓库 安装所需的软件包。yum-utils 提供了 yum-config-manager &…

【笔记】编写cmakelist的常用命令含义及使用

文章目录 命令projectfilesetconfigure_filelistadd_libraryset_target_propertiestarget_link_directoriestarget_link_librariestarget_compile_definitionsadd_subdirectoryfunction 持续更新 命令 project 用于定义一个项目,它是 CMakeLists.txt 文件中的第一个…

华为校园公开课走入上海交大,鸿蒙成为专业核心课程

4月12日,华为校园公开课在中国上海交通大学成功举办,吸引了来自计算机等相关专业的150余名学生参加。据了解,由吴帆、陈贵海、过敏意、吴晨涛、刘生钟等教授在中国上海交通大学面向计算机系本科生开设的《操作系统》课程,是该系学…

[MySQL数据库] 索引与事务

1. 索引 1.1 概念 索引是一种特殊的文件,包含着对数据表里所有记录的引用指针.可以对表中的一列或多列创建索引,并指定索引的类型,各类索引有各自的数据结构实现. 1.2 作用 数据库中的表、数据、索引之间的关系,类似于书架上的图书、书籍…

【Java探索之旅】数组使用 初探JVM内存布局

🎥 屿小夏 : 个人主页 🔥个人专栏 : Java编程秘籍 🌄 莫道桑榆晚,为霞尚满天! 文章目录 📑前言一、数组的使用1.1 元素访问1.2 数组遍历 二、JVM的内存布局🌤️全篇总结 …

vulfocus靶场tomcat-cve_2017_12615 文件上传

7.0.0-7.0.81 影响版本 Windows上的Apache Tomcat如果开启PUT方法(默认关闭),则存在此漏洞,攻击者可以利用该漏洞上传JSP文件,从而导致远程代码执行。 Tomcat 是一个小型的轻量级应用服务器,在中小型系统和并发访问用户不是很多…

mfc 带有复选框的ListBox

mfc 带有复选框的 ListBox 效果: 添加 ListBox 控件 从工具箱拖拽 ListBox 控件到窗口上,并设置属性: 包含字符串:true所有者描述:Fixed 给ListBox添加控制变量 添加完后,将m_list_box的类型使用CC…