真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么在k8s上部署mysql8.0MGR

本篇內(nèi)容介紹了“怎么在k8s上部署MySQL 8.0 MGR”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)長(zhǎng)期為成百上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為芝罘企業(yè)提供專業(yè)的成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè),芝罘網(wǎng)站改版等技術(shù)服務(wù)。擁有十多年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

一。環(huán)境概述

     k8s環(huán)境:1臺(tái)master節(jié)點(diǎn),3臺(tái)node節(jié)點(diǎn)。

怎么在k8s上部署mysql 8.0 MGR

      在三個(gè)節(jié)點(diǎn)上搭建MGR集群。mysql的數(shù)據(jù)文件是掛載在本地存儲(chǔ),在鏡像制作完成后,需要把初始化后的數(shù)據(jù)文件copy到三個(gè)節(jié)點(diǎn)本地的掛載點(diǎn)/data/mysql/data/,另外需要修改auto.cnf里面的uuid,讓三個(gè)節(jié)點(diǎn)的uuid不同。

二。搭建步驟

  1. 制作mysql 8.0.15鏡像

    此步驟略過,參照mysql官方的二進(jìn)制包安裝步驟, https://dev.mysql.com/doc/refman/8.0/en/binary-installation.html。   安裝完畢后制作成鏡像。

  2. 準(zhǔn)備生成三個(gè)節(jié)點(diǎn)pod的相關(guān)yaml文件。

    ---創(chuàng)建namespace的文件namespace.yaml:

    apiVersion: v1
    kind: Namespace
    metadata:
      name: mysqldb

    ---節(jié)點(diǎn)1的configmap文件mysql-mgr-cnf-0.yaml:

    apiVersion: v1
    data:
      mysql-mgr-0.cnf: |
        [mysqld]
        port = 3306
        character_set_server = utf8
        socket = /tmp/mysql.sock
        basedir = /usr/local/mysql
        log-error = /data/mysql/data/mysql.err
        pid-file = /data/mysql/data/mysql.pid
        datadir = /data/mysql/data
        server_id = 092832
        log_bin = mysql-bin
        relay-log = relay-bin
        #back_log = 500
        #max_connections = 3000
        #wait_timeout = 5022397
        interactive_timeout = 5022397
        max_connect_errors = 1000
        relay-log-recovery=1
        #max_allowed_packet = 32M
        sort_buffer_size = 4M
        read_buffer_size = 4M
        join_buffer_size = 8M
        thread_cache_size = 64
        #tmp_table_size = 256M
        log_slave_updates=1
        long_query_time = 1
        slow_query_log = 1
        slow_query_log_file = /data/mysql/data/slow_sql.log
        skip-name-resolve
        sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
        innodb_buffer_pool_size=700M
        #innodb_data_file_path = ibdata1:1024M:autoextend
        innodb_flush_log_at_trx_commit=1
        innodb_log_buffer_size = 16M
        innodb_log_file_size = 256M
        innodb_log_files_in_group = 2
        innodb_max_dirty_pages_pct = 50
        sync_binlog=1
        master_info_repository=TABLE
        relay_log_info_repository=TABLE
        log_timestamps=SYSTEM
        gtid_mode = ON
        enforce_gtid_consistency = ON
        master_info_repository = TABLE
        relay_log_info_repository = TABLE
        log_slave_updates = ON
        binlog_checksum = NONE
        log_slave_updates = ON
        slave_parallel_type=LOGICAL_CLOCK
        slave_parallel_workers=8
        slave-preserve-commit-order=on
        #group_replication_compression_threshold=200000
        transaction_write_set_extraction = XXHASH64
        loose-group_replication_group_name="01e5fb97-be64-41f7-bafd-3afc7a6ab555"
        loose-group_replication_start_on_boot=off
        loose-group_replication_local_address="mysql-mgr-0.mgrtest.mysqldb.svc.cluster.local.:13306"
        loose-group_replication_group_seeds="mysql-mgr-0.mgrtest.mysqldb.svc.cluster.local.:13306,mysql-mgr-1.mgrtest.mysqldb.svc.cluster.local.:13306,mysql-mgr-2.mgrtest.mysqldb.svc.cluster.local.:13306"
        loose-group_replication_bootstrap_group = off
        loose-group_replication_ip_whitelist='10.244.0.0/16,172.17.0.0/16,10.229.0.0/16,10.228.0.0/16'
        report_host = mysql-mgr-0.mgrtest.mysqldb.svc.cluster.local
        [mysqldump]
        quick
        max_allowed_packet = 32M
    kind: ConfigMap
    metadata:
      name: mysql-mgr-0-cnf
      namespace: mysqldb

    ---節(jié)點(diǎn)2的configmap文件mysql-mgr-cnf-1.yaml:

    apiVersion: v1
    data:
      mysql-mgr-1.cnf: |
        [mysqld]
        port = 3306
        character_set_server = utf8
        socket = /tmp/mysql.sock
        basedir = /usr/local/mysql
        log-error = /data/mysql/data/mysql.err
        pid-file = /data/mysql/data/mysql.pid
        datadir = /data/mysql/data
        server_id = 092231
        log_bin = mysql-bin
        relay-log = relay-bin
        #back_log = 500
        #max_connections = 3000
        #wait_timeout = 5022397
        interactive_timeout = 5022397
        max_connect_errors = 1000
        relay-log-recovery=1
        #max_allowed_packet = 32M
        sort_buffer_size = 4M
        read_buffer_size = 4M
        join_buffer_size = 8M
        thread_cache_size = 64
        #tmp_table_size = 256M
        log_slave_updates=1
        long_query_time = 1
        slow_query_log = 1
        slow_query_log_file = /data/mysql/data/slow_sql.log
        skip-name-resolve
        sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
        innodb_buffer_pool_size=700M
        #innodb_data_file_path = ibdata1:1024M:autoextend
        innodb_flush_log_at_trx_commit=1
        innodb_log_buffer_size = 16M
        innodb_log_file_size = 256M
        innodb_log_files_in_group = 2
        innodb_max_dirty_pages_pct = 50
        sync_binlog=1
        master_info_repository=TABLE
        relay_log_info_repository=TABLE
        log_timestamps=SYSTEM
        gtid_mode = ON
        enforce_gtid_consistency = ON
        master_info_repository = TABLE
        relay_log_info_repository = TABLE
        log_slave_updates = ON
        binlog_checksum = NONE
        log_slave_updates = ON
        slave_parallel_type=LOGICAL_CLOCK
        slave_parallel_workers=8
        slave-preserve-commit-order=on
        #group_replication_compression_threshold=200000
        transaction_write_set_extraction = XXHASH64
        loose-group_replication_group_name="01e5fb97-be64-41f7-bafd-3afc7a6ab555"
        loose-group_replication_start_on_boot=off
        loose-group_replication_local_address="mysql-mgr-1.mgrtest.mysqldb.svc.cluster.local.:13306"
        loose-group_replication_group_seeds="mysql-mgr-0.mgrtest.mysqldb.svc.cluster.local.:13306,mysql-mgr-1.mgrtest.mysqldb.svc.cluster.local.:13306,mysql-mgr-2.mgrtest.mysqldb.svc.cluster.local.:13306"
        loose-group_replication_bootstrap_group = off
        loose-group_replication_ip_whitelist='10.244.0.0/16,172.17.0.0/16,10.229.0.0/16,10.228.0.0/16'
        report_host = mysql-mgr-1.mgrtest.mysqldb.svc.cluster.local
        [mysqldump]
        quick
        max_allowed_packet = 32M
    kind: ConfigMap
    metadata:
      name: mysql-mgr-1-cnf
      namespace: mysqldb

    ---節(jié)點(diǎn)3的configmap文件mysql-mgr-cnf-2.yaml:

    apiVersion: v1
    data:
      mysql-mgr-2.cnf: |
        [mysqld]
        port = 3306
        character_set_server = utf8
        socket = /tmp/mysql.sock
        basedir = /usr/local/mysql
        log-error = /data/mysql/data/mysql.err
        pid-file = /data/mysql/data/mysql.pid
        datadir = /data/mysql/data
        server_id = 092132
        log_bin = mysql-bin
        relay-log = relay-bin
        #back_log = 500
        #max_connections = 3000
        #wait_timeout = 5022397
        interactive_timeout = 5022397
        max_connect_errors = 1000
        relay-log-recovery=1
        #max_allowed_packet = 32M
        sort_buffer_size = 4M
        read_buffer_size = 4M
        join_buffer_size = 8M
        thread_cache_size = 64
        #tmp_table_size = 256M
        log_slave_updates=1
        long_query_time = 1
        slow_query_log = 1
        slow_query_log_file = /data/mysql/data/slow_sql.log
        skip-name-resolve
        sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
        innodb_buffer_pool_size=700M
        #innodb_data_file_path = ibdata1:1024M:autoextend
        innodb_flush_log_at_trx_commit=1
        innodb_log_buffer_size = 16M
        innodb_log_file_size = 256M
        innodb_log_files_in_group = 2
        innodb_max_dirty_pages_pct = 50
        sync_binlog=1
        master_info_repository=TABLE
        relay_log_info_repository=TABLE
        log_timestamps=SYSTEM
        gtid_mode = ON
        enforce_gtid_consistency = ON
        master_info_repository = TABLE
        relay_log_info_repository = TABLE
        log_slave_updates = ON
        binlog_checksum = NONE
        log_slave_updates = ON
        slave_parallel_type=LOGICAL_CLOCK
        slave_parallel_workers=8
        slave-preserve-commit-order=on
        #group_replication_compression_threshold=200000
        transaction_write_set_extraction = XXHASH64
        loose-group_replication_group_name="01e5fb97-be64-41f7-bafd-3afc7a6ab555"
        loose-group_replication_start_on_boot=off
        loose-group_replication_local_address="mysql-mgr-2.mgrtest.mysqldb.svc.cluster.local.:13306"
        loose-group_replication_group_seeds="mysql-mgr-0.mgrtest.mysqldb.svc.cluster.local.:13306,mysql-mgr-1.mgrtest.mysqldb.svc.cluster.local.:13306,mysql-mgr-2.mgrtest.mysqldb.svc.cluster.local.:13306"
        loose-group_replication_bootstrap_group = off
        loose-group_replication_ip_whitelist='10.244.0.0/16,172.17.0.0/16,10.229.0.0/16,10.228.0.0/16'
        report_host = mysql-mgr-2.mgrtest.mysqldb.svc.cluster.local
        [mysqldump]
        quick
        max_allowed_packet = 32M
    kind: ConfigMap
    metadata:
      name: mysql-mgr-2-cnf
      namespace: mysqldb

    ----節(jié)點(diǎn)1的pod的yaml文件:
    apiVersion: v1
    kind: Pod
    metadata:
      name: mysql-mgr-0
      namespace: mysqldb
      labels:
        name: mysql-mgr
    spec:
      affinity:
        nodeAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            nodeSelectorTerms:
              - matchExpressions:
                - key: mysqlrole
                  operator: In
                  values: ["mysql-mgr-0"]
      hostname: mysql-mgr-0
      subdomain: mgrtest
      containers:
      - image: 172.16.110.102:5000/mysql8.0:latest
        name: mysql-mgr-0
        imagePullPolicy: IfNotPresent
        command: [ "/bin/bash", "-ce", "cd /usr/local/mysql && bin/mysqld_safe --defaults-file=/etc/my.cnf && tail -f /dev/null" ]
        #env:
        #- name: MYSQL_ROOT_PASSWORD
        #  value: noc-mysql
        ports:
          - containerPort: 3306
        volumeMounts:
        - name: tz-config
          mountPath: /etc/localtime
        - name: mysql-data
          mountPath: /data/mysql/data/
        - name: mysql-config
          mountPath: /etc/my.cnf
          subPath: my.cnf
        env:
        - name: INNODB_BUFFER_POOL_SIZE
          value: 500M
        #- name: REPORT_HOST
        #  value: mysql-mgr-0.mgrtest.mysqldb.svc.cluster.local
      volumes:
        - name: tz-config
          hostPath:
            path: /etc/localtime
        - name: mysql-data
          hostPath:
            path: /data/mysql/data/
        - name: mysql-config
          configMap:
            name: mysql-mgr-0-cnf
            items:
              - key: mysql-mgr-0.cnf
                path: my.cnf
    ----節(jié)點(diǎn)2的pod的yaml文件:

    apiVersion: v1
    kind: Pod
    metadata:
      name: mysql-mgr-1
      namespace: mysqldb
      labels:
        name: mysql-mgr
    spec:
      affinity:
        nodeAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            nodeSelectorTerms:
              - matchExpressions:
                - key: mysqlrole
                  operator: In
                  values: ["mysql-mgr-1"]
      hostname: mysql-mgr-1
      subdomain: mgrtest
      containers:
      - image: 172.16.110.102:5000/mysql8.0:latest
        name: mysql-mgr-1
        imagePullPolicy: IfNotPresent
        command: [ "/bin/bash", "-ce", "cd /usr/local/mysql && bin/mysqld_safe --defaults-file=/etc/my.cnf && tail -f /dev/null" ]
        #env:
        #- name: MYSQL_ROOT_PASSWORD
        #  value: noc-mysql
        ports:
          - containerPort: 3306
        volumeMounts:
        - name: tz-config
          mountPath: /etc/localtime
        - name: mysql-data
          mountPath: /data/mysql/data
        - name: mysql-config
          mountPath: /etc/my.cnf
          subPath: my.cnf
        env:
        - name: INNODB_BUFFER_POOL_SIZE
          value: 500M
      volumes:
        - name: tz-config
          hostPath:
            path: /etc/localtime
        - name: mysql-data
          hostPath:
            path: /data/mysql/data/
        - name: mysql-config
          configMap:
            name: mysql-mgr-1-cnf
            items:
              - key: mysql-mgr-1.cnf
                path: my.cnf

    ---節(jié)點(diǎn)3的pod的yaml文件:

    apiVersion: v1
    kind: Pod
    metadata:
      name: mysql-mgr-2
      namespace: mysqldb
      labels:
        name: mysql-mgr
    spec:
      affinity:
        nodeAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            nodeSelectorTerms:
              - matchExpressions:
                - key: mysqlrole
                  operator: In
                  values: ["mysql-mgr-2"]
      hostname: mysql-mgr-2
      subdomain: mgrtest
      containers:
      - image: 172.16.110.102:5000/mysql8.0:latest
        name: mysql-mgr-2
        imagePullPolicy: IfNotPresent
        command: [ "/bin/bash", "-ce", "cd /usr/local/mysql && bin/mysqld_safe --defaults-file=/etc/my.cnf && tail -f /dev/null" ]
        #env:
        #- name: MYSQL_ROOT_PASSWORD
        #  value: noc-mysql
        ports:
          - containerPort: 3306
        volumeMounts:
        - name: tz-config
          mountPath: /etc/localtime
        - name: mysql-data
          mountPath: /data/mysql/data
        - name: mysql-config
          mountPath: /etc/my.cnf
          subPath: my.cnf
        env:
        - name: INNODB_BUFFER_POOL_SIZE
          value: 500M
      volumes:
        - name: tz-config
          hostPath:
            path: /etc/localtime
        - name: mysql-data
          hostPath:
            path: /data/mysql/data/
        - name: mysql-config
          configMap:
            name: mysql-mgr-2-cnf
            items:
              - key: mysql-mgr-2.cnf
                path: my.cnf

    ---為三個(gè)pod創(chuàng)建的service的yaml文件

    apiVersion: v1
    kind: Service
    metadata:
      name: mgrtest
      namespace: mysqldb
    spec:
      selector:
        name: mysql-mgr
      clusterIP:   None
      ports:
      - name:   foo
        port:   3306
        targetPort: 3306

  3.  創(chuàng)建namespace,service,configmap,pod

    kubectl create -f namespace.yaml

    kubectl create -f mysql-mgr-svc.yaml

    kubectl create -f mysql-mgr-cnf-0.yaml

    kubectl create -f mysql-mgr-cnf-1.yaml

    kubectl create -f mysql-mgr-cnf-2.yaml

    kubectl create -f mysql-mgr-0-pod.yaml

    kubectl create -f mysql-mgr-1-pod.yaml

    kubectl create -f mysql-mgr-2-pod.yaml

    創(chuàng)建后如下圖所示:

    怎么在k8s上部署mysql 8.0 MGR

  4.  配置節(jié)點(diǎn)1:

    root@dkm:/app/mgr# kubectl exec -it mysql-mgr-0 -n mysqldb /bin/bash

    root@mysql-mgr-0:/# /usr/local/mysql/bin/mysql -uroot -p

    alter user 'root'@'localhost' identified by 'Mysql123!@#';
    set sql_log_bin=0;
    create user rpl_user@'%' identified by 'Rpl_pass@123';
    grant replication slave on *.* to rpl_user@'%';
    flush privileges;
    set sql_log_bin=1;
    change master to master_user='rpl_user',master_password='Rpl_pass@123' for channel 'group_replication_recovery';
    install PLUGIN group_replication SONAME 'group_replication.so';

    reset master;
    set global group_replication_single_primary_mode=FALSE;
    set global group_replication_enforce_update_everywhere_checks=TRUE;
    set global group_replication_bootstrap_group=ON;
    start group_replication;
    set global group_replication_bootstrap_group=OFF;
    select * from performance_schema.replication_group_members;
    怎么在k8s上部署mysql 8.0 MGR

  5. 配置節(jié)點(diǎn)2:

    set sql_log_bin=0;
    create user rpl_user@'%' identified by 'Rpl_pass@123';
    grant replication slave on *.* to rpl_user@'%';
    flush privileges;
    set sql_log_bin=1;
    change master to master_user='rpl_user',master_password='Rpl_pass@123' for channel 'group_replication_recovery';
    install PLUGIN group_replication SONAME 'group_replication.so';

    reset master;
    set global group_replication_single_primary_mode=FALSE;
    set global group_replication_enforce_update_everywhere_checks=TRUE;
    set global group_replication_recovery_get_public_key=on;
    start group_replication;
    select * from performance_schema.replication_group_members;

    怎么在k8s上部署mysql 8.0 MGR

  6.   配置節(jié)點(diǎn)3:

    set sql_log_bin=0;
    create user rpl_user@'%' identified by 'Rpl_pass@123';
    grant replication slave on *.* to rpl_user@'%';
    flush privileges;
    set sql_log_bin=1;
    change master to master_user='rpl_user',master_password='Rpl_pass@123' for channel 'group_replication_recovery';
    install PLUGIN group_replication SONAME 'group_replication.so';

    reset master;
    set global group_replication_single_primary_mode=FALSE;
    set global group_replication_enforce_update_everywhere_checks=TRUE;
    set global group_replication_recovery_get_public_key=on;
    start group_replication;
    select * from performance_schema.replication_group_members;

    怎么在k8s上部署mysql 8.0 MGR

     

  7. 總結(jié):

    (1)節(jié)點(diǎn)之間是通過域名互相通訊,域名的構(gòu)成: hostname.service.namespace.svc.cluster.local.

    (2)注意在每個(gè)節(jié)點(diǎn)的配置文件里配置report_host為該節(jié)點(diǎn)的域名,也就是hostname.service.namespace.svc.cluster.local。否則會(huì)報(bào)錯(cuò):

    2019-04-10T09:16:53.607069+08:00 55 [ERROR] [MY-010584] [Repl] Slave I/O for channel 'group_replication_recovery': error connecting to master 'rpl_user@mysql-mgr-0:3306' - retry-time: 60  retries: 1, Error_code: MY-002005
    ...

    2019-04-10T09:17:53.682099+08:00 24 [ERROR] [MY-011582] [Repl] Plugin group_replication reported: 'There was an error when connecting to the donor server. Please check that group_replication_recovery channel credentials and all MEMBER_HOST column values of performance_schema.replication_group_members table are correct and DNS resolvable.'

“怎么在k8s上部署mysql 8.0 MGR”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!


文章標(biāo)題:怎么在k8s上部署mysql8.0MGR
標(biāo)題來源:http://weahome.cn/article/pppges.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部