TKEStack容器管理平台实战之部署wordpress应用

news2024/12/23 10:03:49

TKEStack容器管理平台实战之部署wordpress应用

  • 一、TKEStack介绍
    • 1.1 TKEStack简介
    • 1.2 TKEStack特点
    • 1.3 TKEStack架构图
  • 二、kubernetes集群介绍
    • 2.1 k8s简介
    • 2.2 k8s架构图
  • 三、本次实践介绍
    • 3.1 实践环境要求
    • 3.2 本次实践环境规划
    • 3.3 本次实践简介
  • 四、安装容器管理平台
    • 4.1 安装TKEStack
    • 4.2 TKEStack基本设置
    • 4.3 集群设置
    • 4.4 认证设置
    • 4.5 镜像仓库设置
    • 4.6 业务设置
    • 4.7 监控设置
    • 4.8 控制台设置
    • 4.9 配置预览
    • 4.10 开始安装
  • 五、访问TKEStack容器平台
    • 5.1 访问TKEStack首页
    • 5.2 添加Global集群工作节点
    • 5.3 查看Global集群工作节点
    • 5.4 查看TKEStack首页概览
  • 六、导入本地k8s集群
    • 6.1 检查本地k8s集群状态
    • 6.2 下载本地k8s集群kubeconfig文件
    • 6.3 上传kubeconfig文件
    • 6.4 查看导入集群状态
    • 6.5 查看首页概览页面
  • 七、部署wordpress应用
    • 7.1 yaml创建资源
    • 7.2 编写yaml部署文件
    • 7.3 部署wordpress应用
    • 7.4 检查工作负载状态
    • 7.5 检查service状态
  • 八、wordpress的初始化
    • 8.1 进入wordpress的初始安装界面
    • 8.2 设置网站信息
  • 九、访问wordpress
    • 9.1 访问wordpress首页
    • 9.2 访问wordpress后台管理

一、TKEStack介绍

1.1 TKEStack简介

TKEStack是一个开源项目,为在生产中部署容器的组织提供容器管理平台。TKEStack让您可以轻松地在任何地方运行Kubernetes、满足 IT 要求并为DevOps团队提供支持。

1.2 TKEStack特点

  • 统一集群管理
    用于集中管理多个 Kubernetes 集群的 Web 控制台和命令行客户端。
    与现有身份验证机制集成,包括LDAP、OIDC、前端代理和公共 OAuth 提供商(例如 GitHub)。
    统一的授权管理,不仅是集群管理层面,甚至是Kubernetes资源层面。
    多租户支持,包括容器、构建和网络通信的团队和用户隔离。
  • 应用程序工作负载管理
    提供直观的 UI 界面来支持可视化和 YAML 导入以及其他资源创建和编辑方法,使用户无需预先学习所有 Kubernetes 概念即可运行容器。
    抽象的项目级资源容器,支持跨多个集群的多个命名空间管理和部署应用程序。
  • 运维管理
    集成系统监控和应用程序监控。
    持久的 Kubernetes 事件和审核日志。
    限制、跟踪和管理平台上的开发人员和团队。
  • 插件支持和管理
    身份验证身份提供者插件。
    授权提供商插件。
    事件持久存储插件。
    系统和应用程序日志持久存储插件。
    Galaxy(网络)、TApp(工作负载)、GPUManage(GPU)、CronHPA(HPA)、LBCF(负载平衡)

1.3 TKEStack架构图

请在此添加图片描述

二、kubernetes集群介绍

2.1 k8s简介

kubernetes,简称K8s,是用8代替名字中间的8个字符“ubernete”而成的缩写。Kubernetes是一种开源的容器编排和管理平台,它可以帮助我们在分布式的环境中管理容器化的应用。Kubernetes可以让开发者和运维人员通过定义和管理Pod、Service、Deployment等资源来部署和管理应用程序,使得应用程序更易于部署、扩展和管理。

2.2 k8s架构图

kubernetes集群架构示意图

在这里插入图片描述

三、本次实践介绍

3.1 实践环境要求

TKEStack容器管理平台部署环境要求需按如下准备,由于是测试环境,本次部署节点的硬件配置略低于官方要求。

TKEStack部署环境要求如下:

  • 硬件
    8 个虚拟CPU
    16 GB 内存
    100 GB 磁盘空间
  • 操作系统
    ≥ Ubuntu 16.04/18.04 LTS(64 位)
    ≥ CentOS Linux 7.6(64 位)
    ≥Tencent Linux 2.2

3.2 本次实践环境规划

  • TKEStack的Global集群
hostnameIP地址操作系统版本k8s版本角色
master192.168.3.141centos7.91.21.4-tke.3master节点/TKEStack安装节点
node01192.168.3.142centos7.91.21.4-tke.3worker节点
node02192.168.3.143centos7.91.21.4-tke.3worker节点
  • 本地k8s集群
hostnameIP地址操作系统版本k8s版本角色
k8s-master192.168.3.201centos7.6v1.27.4master节点
k8s-node01192.168.3.202centos7.6v1.27.4worker节点
k8s-node02192.168.3.203centos7.6v1.27.4worker节点

3.3 本次实践简介

1.部署TKEStack容器管理平台;
2.在TKEStack容器管理平台部署wordpress应用。

四、安装容器管理平台

4.1 安装TKEStack

在master安装节点上,执行以下命令,Web GUI 将引导初始化并安装TKEStack 的Global集群和控制台。

# Choose installation package according to your installation node CPU architecture [amd64, arm64]
arch=amd64 version=v1.9.0 && wget https://tke-release-1251707795.cos.ap-guangzhou.myqcloud.com/tke-installer-linux-$arch-$version.run{,.sha256} && sha256sum --check --status tke-installer-linux-$arch-$version.run.sha256 && chmod +x tke-installer-linux-$arch-$version.run && ./tke-installer-linux-$arch-$version.run

在安装过程中需要耐心等待一段时间,出现以下提示时,表示TKEStack已经初步安装成功。

请在此添加图片描述

4.2 TKEStack基本设置

访问地址:http://192.168.3.141:8080/,进入TKEStack初始配置页面。在账户设置中,设置用户名和密码,高可用这里选择不设置。

请在此添加图片描述

4.3 集群设置

网卡名称:eth0
GPU类型:不使用
容器网络CIDR:10.0.0.0/14
master节点:192.168.3.141/ssh端口22/密码认证
其余默认,下一步即可。

请在此添加图片描述

4.4 认证设置

使用TKE提供的用户认证功能

请在此添加图片描述

4.5 镜像仓库设置

选择默认的TKE提供

请在此添加图片描述

4.6 业务设置

选择开启业务模块,默认是开启状态。

请在此添加图片描述

4.7 监控设置

监控存储类型:TKE提供。

请在此添加图片描述

4.8 控制台设置

默认设置即可。

请在此添加图片描述

4.9 配置预览

检查所有配置是否正确,点击安装。

请在此添加图片描述

4.10 开始安装

TKEStack初始化安装过程有点长,需要耐心等待安装完成即可。

请在此添加图片描述

出现以下界面,表示TKEStack容器管理平台安装完毕,

请在此添加图片描述

五、访问TKEStack容器平台

5.1 访问TKEStack首页

访问地址:https://192.168.3.141/,将IP替换为自己安装节点的IP地址。输入账号密码,进入TKEStack首页。

请在此添加图片描述

请在此添加图片描述

5.2 添加Global集群工作节点

在集群管理——global集群,点击进入global集群管理页面。

请在此添加图片描述

请在此添加图片描述

在global集群管理页面,点击节点管理——节点,选择添加节点。

请在此添加图片描述

填写目标机器信息:
目标机器:192.168.3.142
SSH端口:22
认证方式:密码认证
填写node01工作节点的root账号和密码,其余默认,保存即可。

请在此添加图片描述

按照以上配置,添加第二台工作节点node02,添加即可。

请在此添加图片描述

5.3 查看Global集群工作节点

等待节点初始化完成,看到各节点状态为正常Running状态即可。

请在此添加图片描述

5.4 查看TKEStack首页概览

查看TKEStack首页概览,可以看到当前资源概览和集群状态

请在此添加图片描述

六、导入本地k8s集群

6.1 检查本地k8s集群状态

检查本地k8s集群的工作节点状态

[root@k8s-master ~]# kubectl get nodes
NAME         STATUS   ROLES           AGE    VERSION
k8s-master   Ready    control-plane   120d   v1.27.4
k8s-node01   Ready    <none>          120d   v1.27.4
k8s-node02   Ready    <none>          120d   v1.27.4

检查本地k8s集群的系统pod状态

[root@k8s-master ~]# kubectl get pods -n kube-system
NAME                                       READY   STATUS    RESTARTS      AGE
calico-kube-controllers-85578c44bf-gw2km   1/1     Running   3 (88m ago)   120d
calico-node-8tts7                          1/1     Running   3 (88m ago)   120d
calico-node-fx8mv                          1/1     Running   3 (88m ago)   120d
calico-node-n8rt4                          1/1     Running   3 (88m ago)   120d
coredns-7bdc4cb885-5vgx8                   1/1     Running   3 (88m ago)   120d
coredns-7bdc4cb885-l22fj                   1/1     Running   3 (88m ago)   120d
etcd-k8s-master                            1/1     Running   4 (88m ago)   120d
kube-apiserver-k8s-master                  1/1     Running   4 (88m ago)   120d
kube-controller-manager-k8s-master         1/1     Running   4 (88m ago)   120d
kube-proxy-6vvw5                           1/1     Running   3 (88m ago)   120d
kube-proxy-867jg                           1/1     Running   3 (88m ago)   120d
kube-proxy-lgsc8                           1/1     Running   3 (88m ago)   120d
kube-scheduler-k8s-master                  1/1     Running   4 (88m ago)   120d

6.2 下载本地k8s集群kubeconfig文件

下载本地k8s集群kubeconfig文件,一般默认位置在~/.kube/config。

root@k8s-master ~# ls -l ~/.kube/config

-rw------- 1 root root 5649 Aug  2 09:56 /root/.kube/config

6.3 上传kubeconfig文件

上传kubeconfig文件,提交即可。

请在此添加图片描述

6.4 查看导入集群状态

查看导入集群状态

请在此添加图片描述

6.5 查看首页概览页面

重新访问TKEStack首页概览页面,已经成功识别到导入的k8s集群及相关信息。

请在此添加图片描述

七、部署wordpress应用

7.1 yaml创建资源

在新导入的k8s集群my-k8s管理页面,点击yaml创建资源。

请在此添加图片描述

请在此添加图片描述

7.2 编写yaml部署文件

编写wordpress的yaml部署文件

---
apiVersion: v1
kind: Namespace
metadata:
  name: wordpress
---
apiVersion: v1
kind: Service
metadata:
  name: wordpress
  namespace: wordpress
  labels:
    app: wordpress
spec:
  ports:
    - protocol: TCP
      targetPort: 80
      port: 80
      nodePort: 30020
  selector:
    app: wordpress
  type: NodePort


---

apiVersion: apps/v1
kind: Deployment
metadata:
  name: wordpress
  namespace: wordpress
  labels:
    app: wordpress
spec:
  replicas: 2
  selector:
    matchLabels:
      app: wordpress
  template:
    metadata:
      labels:
        app: wordpress
    spec:
      containers:
        - name: wordpress
          image: wordpress
          ports:
            - containerPort: 80
          env:
            - name: WORDPRESS_DB_HOST
              value:  wordpress-mysql.wordpress.svc.cluster.local
            - name: WORDPRESS_DB_USER
              value: wordpress
            - name:  WORDPRESS_DB_PASSWORD
              value:  wordpress
          volumeMounts:
            - mountPath: "/var/www/html"
              name: wordpress-data
      volumes:
        - name: wordpress-data
          hostPath:
            path: /data/wordpress/data

---

apiVersion: v1
kind: Service
metadata:
  name: wordpress-mysql
  namespace: wordpress
  labels:
    app: wordpress
spec:
  ports:
    - port: 3306
  type: ClusterIP
  selector:
    app: wordpress
    tier: mysql

---

apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: wordpress-mysql
  namespace: wordpress
  labels:
    app: wordpress
spec:
  replicas: 1
  selector:
    matchLabels:
      app: wordpress
      tier: mysql
  serviceName: "wordpress-mysql"
  template:
    metadata:
      labels:
        app: wordpress
        tier: mysql
    spec:
#      nodeSelector:
#        kubernetes.io/hostname: node01
      containers:
        - name: mysql
          image: mysql:5.7
          env:
            - name: MYSQL_ROOT_PASSWORD
              value: wordpress
            - name: MYSQL_DATABASE
              value: wordpress
            - name: MYSQL_USER
              value:  wordpress
            - name: MYSQL_PASSWORD
              value:  wordpress


          ports:
            - containerPort: 3306
              name: mysql
          volumeMounts:
            - mountPath: /var/lib/mysql
              name: mysql-storage
      volumes:
        - name: mysql-storage
          hostPath:
            path: /var/lib/mysql

7.3 部署wordpress应用

将yaml部署文件复制到编辑栏中,点击“完成”

请在此添加图片描述

7.4 检查工作负载状态

在TKEStack容器管理平台,查看wordpress命名空间下的Deployment资源状态。

请在此添加图片描述

请在此添加图片描述

7.5 检查service状态

在TKEStack容器管理平台,查看wordpress命名空间下的service状态。

请在此添加图片描述

可以看到wordpress应用的映射主机端口为30020

请在此添加图片描述

八、wordpress的初始化

8.1 进入wordpress的初始安装界面

访问地址:http://192.168.3.202:30020/wp-admin/install.php, 可以选择系统中文语言或者英语,这里是选择英语。

在这里插入图片描述

8.2 设置网站信息

自定义网站信息,设置网站名及网站管理员密码等信息。

在这里插入图片描述

在这里插入图片描述

九、访问wordpress

9.1 访问wordpress首页

访问地址:http://192.168.3.202:30020/

在这里插入图片描述

9.2 访问wordpress后台管理

后台管理地址:http://192.168.3.202:30020/wp-admin/
输入之前设置的管理员和密码,进入wordpress后台管理。

在这里插入图片描述

在这里插入图片描述

我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖!

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

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

相关文章

python基础-检测字符串是否含有中文的方法

1. 正则表达式 代码示例如下&#xff1a; import re def contains_chinese(text):pattern re.compile(r[\u4e00-\u9fff]) # 匹配中文字符的正则表达式范围return bool(pattern.search(text))2.unicodedata模块 import unicodedata def contains_chinese(text):for char in…

Codeforces Round 638 (Div. 2)B. Phoenix and Beauty(思维构造)

B. Phoenix and Beauty 这道题目学到的东西&#xff1a; 从给出的数据范围观察&#xff0c;得到一些有用信息&#xff08;峰哥教的&#xff09;考虑无解的情况‘ 其实这题考虑怎么操作是比较难的&#xff0c;如果能想出来满足条件的结果就比较好了&#xff08;我在说什么我自…

力扣题:高精度运算-1.1

力扣题-1.1 [力扣刷题攻略] Re&#xff1a;从零开始的力扣刷题生活 力扣题1&#xff1a;67. 二进制求和 解题思想&#xff1a;将数组进行遍历相加即可 class Solution(object):def addBinary(self, a, b):""":type a: str:type b: str:rtype: str""…

java开发面试:常见业务场景之单点登录SSO(JWT)、权限认证、上传数据的安全性的控制、项目中遇到的问题、日志采集(ELK)、快速定位系统的瓶颈

单点登录&#xff08;SSO&#xff09; 单点登录&#xff0c;Single Sign On&#xff08;简称SSO&#xff09;,只需要登录一次&#xff0c;就可以访问所有信任的应用系统。 如果是单个tomcat服务&#xff0c;session可以共享&#xff0c;如果是多个tomcat&#xff0c;那么服务s…

count(*)、count(1)、count(column)的区别

count(*)、count(1)、count(column)的区别 count(*)&#xff1a; 返回检索到的行数&#xff0c;无论是否含有NULL值&#xff0c;在InnoDB下&#xff0c;仅计算当前事务可见的行&#xff0c;通过遍历最小的可用二级索引来处理count(*)&#xff0c;除非索引或优化器指示优化器使…

阿里云林立翔:基于阿里云 GPU 的 AIGC 小规模训练优化方案

云布道师 本篇文章围绕生成式 AI 技术栈、生成式 AI 微调训练和性能分析、ECS GPU 实例为生成式 AI 提供算力保障、应用场景案例等相关话题展开。 生成式 AI 技术栈介绍 1、生成式 AI 爆发的历程 在 2022 年的下半年&#xff0c;业界迎来了生成式 AI 的全面爆发&#xff0c…

深信服技术认证“SCSA-S”划重点:命令执行漏洞

为帮助大家更加系统化地学习网络安全知识&#xff0c;以及更高效地通过深信服安全服务认证工程师考核&#xff0c;深信服特别推出“SCSA-S认证备考秘笈”共十期内容&#xff0c;“考试重点”内容框架&#xff0c;帮助大家快速get重点知识~ 划重点来啦 *点击图片放大展示 深信服…

持续集成交付CICD:基于ArgoCD 的GitOps 自动化完成前端项目应用发布与回滚

目录 一、实验 1. 环境 2. K8S master节点部署Argo CD 3.基于ArgoCD 实现GitOps &#xff08;同步部署文件&#xff09; 4.基于ArgoCD 实现GitOps &#xff08;同步HELM文件&#xff09; 二、问题 1. ArgoCD 连接K8S集群状态为 Unknown 2.ArgoCD 创建application失败 …

华为全屋wifi6蜂鸟套装标准

华为政企42 华为政企 目录 上一篇华为安防监控摄像头下一篇华为企业级无线路由器

Layui 2.9.2 列表商品展示页 用模板引擎 laytpl Ajax 读取json 数据 筛选数组 filter css 限制文体显示过长用。。。代替

全代码&#xff1a; <!DOCTYPE html> <html><head><meta charset"utf-8"><title>软件管理器</title><meta name"renderer" content"webkit"><meta http-equiv"X-UA-Compatible" conten…

文献速递:生成对抗网络医学影像中的应用—— CG-3DSRGAN:用于从低剂量PET图像恢复图像质量的分类指导的3D生成对抗网络

文献速递&#xff1a;生成对抗网络医学影像中的应用—— CG-3DSRGAN&#xff1a;用于从低剂量PET图像恢复图像质量的分类指导的3D生成对抗网络 本周给大家分享文献的主题是生成对抗网络&#xff08;Generative adversarial networks, GANs&#xff09;在医学影像中的应用。文献…

大数据技术基础-读书笔记

大数据技术基础-读书笔记 一、大数据概述 大数据是指在一定时间内无法用常规软件工具对其内容进行抓取、处理、分析和管理的数据集合。 大数据一般会涉及两种以上的数据形式&#xff0c;数据量通常是100TB以上的高速、实时数据流&#xff0c;或者从每年增长速度快的小数据开…

Java小案例-Java实现人事管理系统

前言 《人事管理系统》该项目采用技术jsp、Struts2、Mybatis、dwr、tomcat服务器、mysql数据库 开发工具eclipse/idea。 【项目使用技术】 Struts2Mybatisdwrjqueryjscss等技术 前端使用技术&#xff1a;JSP, dwr、jquery、js、css等 后端使用技术&#xff1a;Struts2Myba…

Leetcode—73.矩阵置零【中等】

2023每日刷题&#xff08;六十六&#xff09; Leetcode—73.矩阵置零 空间复杂度为O(mn)版实现代码 class Solution { public:void setZeroes(vector<vector<int>>& matrix) {int rowLen matrix.size();int colLen matrix[0].size();vector<int> row…

使用 ElementUI 组件构建无边框 Window 桌面应用(WinForm/WPF)

生活不可能像你想象得那么好&#xff0c;但也不会像你想象得那么糟。 我觉得人的脆弱和坚强都超乎自己的想象。 有时&#xff0c;我可能脆弱得一句话就泪流满面&#xff1b;有时&#xff0c;也发现自己咬着牙走了很长的路。 ——莫泊桑 《一生》 一、技术栈 Vite Vue3 TS E…

Linux环境安装Hadoop

&#xff08;1&#xff09;下载Hadoop安装包并上传 下载Hadoop安装包到本地&#xff0c;并导入到Linux服务器的/opt/software路径下 &#xff08;2&#xff09;解压安装包 解压安装文件并放到/opt/module下面 [roothadoop100 ~]$ cd /opt/software [roothadoop100 software…

Spring Boot集成RocketMQ之消息对象序列化

以下源码基于rocketmq-spring-boot-start 2.1.1版本&#xff0c;其它版本可能会有差异 一. 前言 当我们在Spring Boot项目中集成RocketMQ后&#xff0c;只需要在配置文件(application.yml)中添加rocketmq的相关配置&#xff0c;即可使用rocketMQTemplate发送对象消息。登录Ro…

PDF文件如何设置限制打印?

想要限制PDF文件的打印功能&#xff0c;想要限制PDF文件打印清晰度&#xff0c;都可以通过设置限制编辑来达到目的。 打开PDF编辑器&#xff0c;找到设置限制编辑的界面&#xff0c;切换到加密状态&#xff0c;然后我们就看到 有印刷许可。勾选【权限密码】输入一个PDF密码&am…

Debian在升级过程中报错

当我们在升级的过程中出现如下报错信息 报错信息如下所示&#xff1a; The following signatures couldnt be verified because the public key is not available: NO_PUBKEY ED444FF07D8D0BF6 W: GPG error: http://mirrors.jevincanders.net/kali kali-rolling InRelease: …

EasyRecovery易恢复2024免费硬盘、光盘、U盘/移动硬盘数据恢复软件

EasyRecovery TM &#xff08;易恢复2024&#xff09;是由著名数据厂商Kroll Ontrack 出品的一款数据文件恢复软件。支持恢复不同存储介质数据&#xff1a;硬盘、光盘、U盘/移动硬盘、数码相机、手机、Raid文件恢复等&#xff0c;能恢复包括文档、表格、图片、音视频等各种文件…