首页 > 数据库 >资源清单编写MySQL,wordpress

资源清单编写MySQL,wordpress

时间:2023-10-08 15:49:05浏览次数:47  
标签:name app MySQL value 3306 wordpress mysql 清单

目录

http://k8s.driverzeng.com/v1.19/

mysql

[root@master-1 mysql]# cat mysql.yaml 
apiVersion: "v1"
kind: "Pod"
metadata:
  name: mysql57                          // 资源清单叫mysql57
spec:
  nodeName: node-1                       // 指定启动到node-1节点
  volumes:
  - name: mysql-data                     // 挂载点名称
    hostPath:
      path: /data/mysql                   // 挂载点宿主机上的位置
  containers:
  - name: mysql-container                 // 容器名称
    image: mysql:5.7                      // 容器使用的镜像
    imagePullPolicy: IfNotPresent         // 拉取镜像规则,有就不拉取,没有择拉取
    env:                                  // 环境变量
    - name: MYSQL_ROOT_PASSWORD
      value: '123'
    - name: MYSQL_DATABASE
      value: 'wordpress'
    - name: MYSQL_USER
      value: 'wp_user'
    - name: MYSQL_PASSWORD
      value: '123'
    args:                                   // 传参
    - --character-set-server=utf8mb4
    - --collation-server=utf8mb4_unicode_ci
    volumeMounts:
    - name: mysql-data                      // 使用哪个挂载点
      mountPath: /var/lib/mysql             // 容器内的目录位置
     
# 启动
[root@master-1 mysql]# kubectl apply -f mysql.yaml 
    ports:
      - containerPort: 3306
        hostPort: 3306
        
根据你提供的信息,这是一个 Kubernetes YAML 文件中定义的端口映射部分,用于将容器内的端口映射到主机上。

在这个例子中:
containerPort: 3306 定义了容器内的端口号为 3306,这通常是 MySQL 数据库服务器的默认端口。
hostPort: 3306 定义了主机上映射的端口号也为 3306,这意味着通过主机上的该端口可以访问到容器内的 MySQL 服务。

## 通过这样的端口映射配置,你可以将主机上的请求转发到容器内运行的 MySQL 服务进行处理。这样,你可以通过主机的 3306 端口来连接和访问 MySQL 数据库。

请注意,在使用端口映射时要确保主机上的对应端口未被占用,并且允许访问该端口的网络规则已正确配置。

wordpress

[root@master-1 wordpress]# cat mysql.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:
  name: mysql
  namespace: wordpress
  labels:
    app: mysql
spec:
  replicas: 1
  selector:
    matchLabels:
      app: mysql
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: mysql
    spec:
      containers:
      - image: mysql:5.6
        name: mysql
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 3306
          name: dbport
        env:
        - name: MYSQL_ROOT_PASSWORD
          value: "123"
        - name: MYSQL_DATABASE
          value: wordpress
        - name: MYSQL_USER
          value: wordpress
        - name: MYSQL_PASSWORD
          value: wordpress
        volumeMounts:
        - name: db
          mountPath: /var/lib/mysql
        resources: {}
      volumes:
      - name: db
        hostPath:
          path: /var/lib/mysql
status: {}
---
apiVersion: v1
kind: Service
metadata:
  name: mysql
  namespace: wordpress
spec:
  selector:
    app: mysql
  ports:
  - name: mysqlport
    protocol: TCP
    port: 3306
    targetPort: dbport

# 启动
kubectl apply -f mysql.yaml
# 查看数据库的ip
[root@master-1 wordpress]# kubectl get pod -n wordpress -o wide
NAME                        READY   STATUS    RESTARTS   AGE   IP          NODE     NOMINATED NODE   READINESS GATES
mysql-d45bfb8c4-vlqpj       1/1     Running   0          20m   10.2.1.22   node-1   <none>           <none>

[root@master-1 wordpress]# cat wordpress.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:
  name: wordpress
  namespace: wordpress
  labels:
    app: wordpress
spec:
  replicas: 1
  selector:
    matchLabels:
      app: wordpress
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: wordpress
    spec:
      containers:
      - name: wordpress
        image: wordpress
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 80
          name: wdport
        env:
        - name: WORDPRESS_DB_HOST
          value:  10.2.1.22:3306               // 这个换成自己的数据库的ip
        - name: WORDPRESS_DB_USER
          value: wordpress
        - name: WORDPRESS_DB_PASSWORD
          value: wordpress
status: {}
---
apiVersion: v1
kind: Service
metadata:
  name: wordpress
  namespace: wordpress
spec:
  type: NodePort
  selector:
    app: wordpress
  ports:
  - name: wordpressport
    protocol: TCP
    port: 80
    targetPort: wdport

# 启动
kubectl apply -f wordpress.yaml

# 查看端口
[root@master-1 wordpress]# kubectl get svc -n wordpress 
NAME        TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)        AGE
mysql       ClusterIP   10.1.111.44    <none>        3306/TCP       26m
wordpress   NodePort    10.1.234.121   <none>        80:32727/TCP   22m

# 访问10.0.0.110:32727
用node节点ip

标签:name,app,MySQL,value,3306,wordpress,mysql,清单
From: https://www.cnblogs.com/xiutai/p/17749234.html

相关文章

  • 资源清单创建
    目录不同资源清单用---进行隔离命名空间peployment资源限制serviceingresshpa健康探针就绪探针http://k8s.driverzeng.com/v1.19/不同资源清单用---进行隔离---命名空间#资源清单创建apiVersion:"v1"kind:"Namespace"metadata:name:zls......
  • wordpress
    目录压测wordpress才分3个网络资源in压测[root@master-1ai]#catwordpress.yamlapiVersion:apps/v1kind:Deploymentmetadata:name:mysqlspec:replicas:1selector:matchLabels:app:mysql01template:metadata:labels:ap......
  • dokcer命令安装wordpress
    目录##1.镜像准备[root@docker01~]#dockerimagesREPOSITORYTAGIMAGEIDCREATEDSIZEcentos7eeb6ee3f44bd24monthsago204MB##2.创建容器[root@docker01~]#dockerrun-p80:80-dcentos:7/bin/bash-c"while......
  • DockerFile部署wordpress并制作成镜像实践
    目录DockerFile部署wordpress实践部署wordpress准备Dockerfile所需文件开始制作成镜像访问网页将wordpress打包成镜像DockerFile部署wordpress实践部署wordpress#创建dockerfile目录[root@docker02~]#mkdir/Dockerfile#进入dockerfile目录[root@docker02......
  • MySQL MHA
    MySQLMHA1.什么是MHAMHA(MasterHighAvailability)是一套优秀的MySQL高可用环境下故障切换和主从复制的软件。MHA的出现就是解决MySQL单点的问题。MySQL故障切换过程中,MHA能做到0-30秒内自动完成故障切换操作。MHA能在故障切换的过程中最大程度上保证数据的一致性,以达到真正......
  • MySQL专题面试题-二叉树、红黑树、B 树、B+树
    演示网址:https://www.cs.usfca.edu/~galles/visualization/Algorithms.html所谓的索引,就是帮助MySQL高效获取数据的排好序的数据结构,基本都是按照k-v形式存储。1.二叉树 二叉树的每个节点至多只有2个叶子节点,且左边的叶子节点键值比根节点小,右边的叶子节点键值比根节点大。这......
  • mysqldump 导出来的文件,使用 source还原时报错“ASCII '\0' appeared in the stateme
    导出语句:mysqldump-uroot-pword--databasesdb1--tablestable1>./sqldumps/archive-table1-`date+"%Y%m%d_%H%M%S"`.sql导出后,使用source还原报错:ASCII'\0'appearedinthestatement,butthisisnotallowedunlessoption我开始以为是我导出的编码格式有问题,......
  • mysql中limit后面不能使用运算符
    mysql中limit后面不能使用运算符进行分页查询的时候,如果写成以下sql,语句执行会报错:select*fromuserwhereid=123456andcode=111andcreate_date>=20190101andcreate_date<=20190202limit(1-1)*1,20因为mysql中limit后面不能带运算符,只能是常量。解决方法使......
  • MYSQL中 find_in_set() 函数用法详解(匹配部门id或父id为100的数据)
    https://blog.csdn.net/carefree31441/article/details/119563685   ......
  • Centos系统安装MySQL数据库时,要以不安全的方式连接至 dev.mysql.com,使用“--no-check-
    解决:要以不安全的方式连接至dev.mysql.com,使用“--no-check-certificate” 问题:[root@192桌面]#wgethttps://dev.mysql.com/get/mysql80-community-release-el7-5.noarch.rpm--2023-10-0812:44:16--https://dev.mysql.com/get/mysql80-community-release-el7-5.noarch.......