KubeSphere 核心实战之一【在kubesphere平台上部署mysql】(实操篇 1/3)

文章目录

    • 1、登录kubesphere平台
    • 2、kubesphere部署应用分析
      • 2.1、工作负载
      • 2.2、服务
      • 2.3、应用路由
      • 2.4、任务
      • 2.5、存储与配置
      • 2.6、部署应用三要素
    • 3、部署mysql
      • 3.1、mysql容器启动实例
      • 3.2、mysql部署分析
      • 3.3、创建mysql的配置
      • 3.4、创建mysql的数据卷pvc
      • 3.5、创建mysql工作负载
      • 3.6、创建mysql服务service
    • 4、使用navicat测试连接mysql

在在kubesphere平台上部署MySQL,首先搭建好k8s集群,并且在集群上安装配置好kubesphere。详细安装配置教程请参见我的上个博客文章:

Kubernetes上安装KubeSphere(亲测–实操完整版)

1、登录kubesphere平台

游览器输入自己搭建的kubesphere平台网址:http://192.168.162.31:30880/login

注意:登录成功后,首先创建一个拥有platform-admin角色的用户 账号,然后创建自己的企业空间和项目。
具体的创建企业空间、项目、用户和平台角色,详见kubesphere官网:
https://kubesphere.io/zh/docs/v3.4/quick-start/create-workspace-and-project/

登录后进入自己的项目。
在这里插入图片描述
在这里插入图片描述

2、kubesphere部署应用分析

在这里插入图片描述

2.1、工作负载

问题一:在云上部署应用,需要用什么样的方式进行部署?

采用工作负载,kubesphere针对三种应用采用三种方式进行部署:

  1. 无状态部署Depolyment:主要针对微服务等应用
  2. 有状态副本集 StatefulSet:mysql、redis等有状态且数据动态变化的服务
  3. 守护进程集 DaemonSet:日志收集器应用。

在这里插入图片描述
无论是哪种服务,部署后最终以pod容器组的形式运行在k8s集群中。

2.2、服务

问题二:部署后的应用服务或者说pod,如何实现在集群内或者集群外的访问?

通过服务Service,两种网络访问模式:

  1. ClusterIP模式:集群内部访问
  2. NodePort模式:外部访问

2.3、应用路由

问题三:服务应用路由如何实现?

kubesphere中的应用路由对应的是kubernetes中的ingress服务。

2.4、任务

问题四:任务如何实现?

kubesphere中的任务对应的是kubernetes中的Job和CronJob。

2.5、存储与配置

问题五:容器组pod中涉及的数据存储和配置如何实现?

kubesphere中的存储中的持久卷申明 对应的是kubernetes中的数据存储卷PVC挂载。
kubesphere中的配置中的配置字典 对应的是kubernetes中的配置集ConfigMap。

2.6、部署应用三要素

总结:
部署一种应用需要考虑的三要素:

  1. 应用的部署方式:选择一种工作负载进行部署
  2. 应用的数据挂载(数据、配置文件):部署期间需要配置存储卷PVC和配置集ConfigMap的创建
  3. 应用的可访问性:服务访问Service(两种模式)

3、部署mysql

3.1、mysql容器启动实例

所有应用部署需要参照docker hub中对应镜像的说明进行。

启动msyql服务的实例:

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 

3.2、mysql部署分析

在这里插入图片描述

3.3、创建mysql的配置

在kubesphere平台中创建mysql的配置文件。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

mysql配置文件示例(文件名:my.cnf) ,内容如下:

[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

3.4、创建mysql的数据卷pvc

在这里插入图片描述
在这里插入图片描述

如果没有nfs-storage,需要安装一下nfs服务器,并设置为默认存储。参照我的博客 kubernetes上安装kubesphere中的安装nfs网络存储文件内容:
Kubernetes上安装KubeSphere(亲测–实操完整版)

创建mysql-pvc成功:
在这里插入图片描述

3.5、创建mysql工作负载

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
输入mysql:5.7.35 回车
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
挂载数据存储卷:
在这里插入图片描述
在这里插入图片描述
挂载配置文件:
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
等待更新完成,状态变为运行中。

测试进入mysql
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

# cd /etc/mysql/conf.d
# ls
my.cnf
# cat my.cnf

如果修改配置文件,也会同步到mysq状态集的配置内容。

测试 集群内部访问使用服务名.项目名 进行访问

mysql -uroot -hhis-mysql.his -p

在这里插入图片描述

1、集群内部,直接通过应用的 【服务名.项目名】 直接访问

mysql -uroot -hhis-mysql.his -p

2、集群外部,用node ip+端口号 +mysql密码

3.6、创建mysql服务service

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4、使用navicat测试连接mysql

在这里插入图片描述
连接成功。

1、集群内部,直接通过应用的 【服务名.项目名】 直接访问

mysql -uroot -hhis-mysql.his -p

2、集群外部,用node ip+端口号 +mysql密码

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/627694.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java应用中swagger使用

文章目录 前言使用依赖引入配置注解使用controller中注解实体类注解 页面展示 前言 现在前后端分离式开发,最头疼的部分就是接口文档了。最讨厌两种人,一种是不写接口文档的人,另一种则是让我写接口文档的人。实际上,我们有一款特…

python/c++ Leetcode题解——20. 有效的括号

目录 题解 方法一:栈 复杂度分析 题解 方法一:栈 判断括号的有效性可以使用「栈」这一数据结构来解决。 我们遍历给定的字符串 s。当我们遇到一个左括号时,我们会期望在后续的遍历中,有一个相同类型的右括号将其闭合。由于后…

yolov5_obb win10环境安装

1、项目地址: GitHub - hukaixuan19970627/yolov5_obb: yolov5 csl_label.(Oriented Object Detection)(Rotation Detection)(Rotated BBox)基于yolov5的旋转目标检测yolov5 csl_label.(Oriented Object Detection)…

手机与电脑更改IP地址怎么使用代理IP?

在现代互联网时代,代理IP已成为许多人日常生活和工作中不可或缺的一部分。通过代理IP,用户可以隐藏自己的真实IP地址,并获得更好的网络体验。本文将详细介绍如何在手机和电脑上更改IP地址并使用代理IP。 一、手机使用代理IP 1. 打开手机设置&…

微服务接口工具Swagger2

##1、什么是Swagger? # 官网 https://swagger.io/核心功能 生成接口说明文档生成接口测试工具 2、SpringBoot集成Swagger2 1&#xff09;、添加依赖 <!-- swagger2 --><!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 --><depen…

XGBoost系列1——XGBoost简介与入门

写在开头 XGBoost&#xff08;eXtreme Gradient Boosting&#xff09;是一种被广泛使用的机器学习算法&#xff0c;由陈天奇博士于2014年提出&#xff0c;以其卓越的性能在数据科学竞赛中备受瞩目。本篇博客将深入探讨XGBoost&#xff0c;从其背景和发展、优势和特点开始&…

[WUSTCTF2020]alison_likes_jojo 1

BUUCTF:https://buuoj.cn/challenges 题目描述&#xff1a; 得到的 flag 请包上 flag{} 提交。 感谢 Iven Huang 师傅供题。 比赛平台&#xff1a;https://ctfgame.w-ais.cn/ 密文&#xff1a; 下载附件解压&#xff0c;得到两张jpg图片和一个文本文件。 解题思路&#x…

[DL]深度学习_Feature Pyramid Network

FPN结构详解 目录 一、概念介绍 二、结构详解 1、对比试验 2、特征图融合 3、结构详解 4、不同尺度预测 5、Proposal映射到预测特征层 一、概念介绍 Feature Pyramid Network (FPN)是一种用于目标检测和语义分割的神经网络架构。它的目标是解决在处理不同尺度的图像时…

使用Visual Leak Detector排查内存泄漏

目录 1、VLD工具概述 2、下载、安装VLD 2.1、下载VLD 2.2、安装VLD 3、VLD安装目录及文件说明

【工业物联网】现代企业环境中的DCS(分布式控制系统)和SCADA(站点控制和数据采集)...

快答案&#xff1a; SCADA和DCS作为单独的系统开始&#xff0c;但一起成长。今天的带宽如此广泛&#xff0c;不需要在每个节点进行本地化。 SCADA和DCS&#xff1a;如果您参与管理企业级网络&#xff0c;您可能已经听说过这些术语。本文将阐明两种技术之间的区别。请注意&#…

pycharm管理仓库(Manager Repository)不见了

经常使用pycharm的大佬们都知道&#xff0c;pycharm中内置了很多库和包&#xff0c;很好用 但是下载来用自带的源很麻烦&#xff0c;于是就用国内的源 可以当我们添加管理仓库的时候&#xff0c;却没有了按钮&#xff0c;如何解决呢&#xff1f; 回到pycharm的主界面&#xf…

漏洞复现--Likeshop任意文件上传(CVE-2024-0352)

免责声明&#xff1a; 文章中涉及的漏洞均已修复&#xff0c;敏感信息均已做打码处理&#xff0c;文章仅做经验分享用途&#xff0c;切勿当真&#xff0c;未授权的攻击属于非法行为&#xff01;文章中敏感信息均已做多层打马处理。传播、利用本文章所提供的信息而造成的任何直…

不是人才用不起,而是AI巡检更有性价比!

在许多行业中&#xff0c;如煤炭、电力、化工等&#xff0c;安全生产是至关重要的。这就需要通过巡检&#xff0c;对设备运行状态进行实时监测&#xff0c;及时发现并处理潜在的安全隐患&#xff0c;从而降低事故发生的概率。但是传统的巡检方式通常依赖于人工进行&#xff0c;…

Docker从入门到精通

系列文章目录 docker常见用法之镜像构建1 docker 系列文章目录一、镜像的分层结构二、容器的用法三、镜像的构建3.1docker commit 构建新镜像三部曲3.1.1运行容器并且修改容器3.1.2提交容器3.1.2删除docker镜像 3.2Dockerfile构建镜像 系列文章目录一、 Dockerfile写法详解1.1…

毛细作用是什么意,请举几个生活中常见的例子。

问题描述&#xff1a;毛细作用是什么意&#xff0c;请举几个生活中常见的例子。 问题解答&#xff1a; 毛细作用是一种液体在细小管道或毛细管中上升或下降的现象&#xff0c;其产生主要是由于表面张力和毛细管内外液体的相互作用。 生活中有许多常见的例子涉及到毛细作用&a…

【数据库和表的管理】

数据库和表的管理 一、实验目的 了解MySQL数据库的逻辑结构和物理结构的特点。学会使用SQL语句创建、选择、删除数据库。学会使用SQL语句创建、修改、删除表。学会使用SQL语句对表进行插入、修改和删除数据操作。了解MySQL的常用数据类型。 二、实验内容SQL语句创建、选择、删…

7 种提升 SpringBoot 吞吐量神技!

7 种提升 SpringBoot 吞吐量神技&#xff01; 1、异步执行2、增加内嵌 Tomcat 的最大连接数3、使用 ComponentScan()4、默认 Tomcat 容器改为 Undertow5、使用 BufferedWriter 进行缓冲6、Deferred 方式实现异步调用7、异步调用可以使用 AsyncHandlerInterceptor 进行拦截 1、异…

[shell]实现多个shell脚本之间变量传递

一、需求 需要有一些变量要从一个shell文件向另一个shell文件传递。 二、方案 2.1通过入参形式传递 当A脚本中的变量需要传递到B脚本中时&#xff0c;可以在运行B脚本的基础上&#xff0c;将A脚本中的数据加入到B脚本的入参中&#xff0c;从而达到传递参数的目的。 2.2通过…

C++ 图形界面学习效果及代码

#include <stdio.h> #include<conio.h> #include <stdlib.h> #include<graphics.h> #define WIDTH 800 #define HEIGHT 480 #define SIZE 20 int main() {const char* str "人生就是由欲望不满足而痛苦和满足之后无趣这两者所构成";const …

1.你好, Python!

快速介绍 Python 语法、变量赋值和数字! 这门课程涵盖了你在使用Python进行数据科学时所需的关键Python技能。该课程适合有一些先前编码经验的人,希望将Python添加到他们的技能库中。(如果您是第一次编码,建议您查看我们的编程入门课程,该课程专为完全初学者设计,希望开始…