【云原生】3.3 Kubernetes 中间件部署实战

67 篇文章 0 订阅
63 篇文章 0 订阅

哈喽~大家好呀,这篇继续上篇的实战讲解——开始我们的中间件部署实战

??个人主页:个人主页???

??系列专栏:【云原生系列】

??与这篇相关的文章:

【云原生】2.5 Kubernetes 核心实战(下)

【云原生】2.5 Kubernetes 核心实战(下)_的博客-CSDN博客

【云原生】3.1 Kubernetes平台安装KubeSpher

【云原生】3.1 Kubernetes平台安装KubeSpher_的博客-CSDN博客

【云原生】3.2 Kubernetes 实战之多租户系统实战

【云原生】3.2 Kubernetes 实战之多租户系统实战_的博客-CSDN博客

目录

一、前言

二、部署MySQL有状态副本集

三、部署MySQL负载均衡网络

四、部置Redis设置网络

1、redis容器启动

五、部署 ElasticSearch

1、es容器启动


一、前言

在前面呢,我们做了一个多租户系统,这次用上次的一个普通用户登入进去系统。

我们如何在云上部署一个应用?是以什么样的方式?该应用又是什么样子?

在KubeSphere 里面有个叫工作负载里面有部署、有状态副本集、守护进程集,对应的就是以前的部署(Deployment)、有状态副本集(StatefulSet)、守护进程集(DaemonSet)

一个项目总会有数据吧?数据存那里呢?在前面我们讲过,很明显直接存在数据卷里面(PVC),例如 MySQL的数据。比如 MySQL有自己的配置文件、Redis 有自己的配置文件、微服务也有自己的配置文件,将它们挂在到配置集里面(ConfigMap),服务采用的是 ClusterlP 与
NodePort。

二、部署MySQL有状态副本集

无论部署一个中间件,都要执行第一步——在 docker hub 里面在到中间件的镜像。

在配置中心——>配置里面创建一个配置(名称,描述信息),添加数据(Key 与 value)

??配置一下值

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

再创建一个存储的地方(存储卷)使用单个节点读写(ReadWriteOnce(RW0))

设置下容器镜像(记得勾选同步主机时区)、挂在存储(配置文件一般为只读的方式)、高级设置等设置

在这里我们的 MySQL 有状态副本集就创建好了,到此时应用还不能访问

??mysql配置示例

[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

三、部署MySQL负载均衡网络

我们在上面创建好的有状态副本集只能在集群里面访问,在集群内部,直接通过应用的 【服务名.项目名】 直接访问

mysql -uroot -hhis-mysql-glgf.his -p

在应用负载——>服务里面设置基本信息(设置名称,描述信息)、服务设置(设置访问类型,添加一个端口)、高级设置(设置访问方式,像外网访问一样)

**??**启动 MySQL 添加连接名字,IP 地址等信息

??这里我们部署的项目在 MySQL 也能访问了

四、部置Redis设置网络

??同样的,先找到Redis 官方镜像,然后进行设置

1、redis容器启动

??创建配置文件,准备redis配置文件内容

mkdir -p /mydata/redis/conf && vim /mydata/redis/conf/redis.conf

??配置示例

appendonly yes
port 6379
bind 0.0.0.0

??docker启动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

??配置中心——>配置里面配置一对 KV 。

??应用负载——>工作负载里面再创建一个有状态副本集(redis 的)

五、部署 ElasticSearch

1、es容器启动

??创建数据目录

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

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

(求关注)持续更新中……

先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
云原生Kubernetes全栈架构师实战下载是指提供一个具有云原生架构设计和Kubernetes技术实践的全栈架构师学习材料的下载资源。 Kubernetes作为一个开源的容器编排引擎,在云原生架构中扮演着重要的角色。全栈架构师需要了解Kubernetes的核心概念、架构原理以及其在实践中的应用。 该资源的下载内容主要包括以下方面: 1. 云原生架构设计:介绍云原生架构的核心思想、原则和设计模式,帮助全栈架构师理解如何构建弹性、灵活和可扩展的应用架构。 2. Kubernetes基础知识:详细介绍Kubernetes的核心组件、架构、工作原理和常用功能,包括Pod、Deployment、Service等概念的讲解和实践。 3. Kubernetes部署和管理:指导全栈架构师在实践中如何部署和管理Kubernetes集群,包括安装配置、网络设置、存储管理等内容。 4. 云原生应用开发:介绍云原生应用的开发模式和最佳实践,帮助全栈架构师了解如何使用Kubernetes进行应用的容器化并进行弹性伸缩和自动部署等操作。 5. 持续集成和持续交付:介绍使用Kubernetes进行持续集成和持续交付的方法和工具,帮助全栈架构师实现应用的自动化构建、测试和部署。 通过下载并学习这个资源,全栈架构师可以进一步提升对云原生架构和Kubernetes的理解和实践能力,为企业的应用容器化和云原生转型提供支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值