zoukankan      html  css  js  c++  java
  • MySQL运维---多实例

    一、基本概述

    查看最新文章更新:请点击这里

      多实例:

        1)多套后台进程+线程+内存结构

        2)多个配置文件 

         a.多个端口
         b.多个socket文件
         c.多个日志文件
         d.多个server_id

        3)多套数据

    二、多实例实战

      1、二进制安装得位置

      

       2、创建另外三个实例的数据存放目录

      

       3、创建配置文件

    [root@controller 3307]# cat my.cnf 
    [mysqld]
    basedir = /application/mysql
    datadir = /data/3307/data
    socket = /data/3307/mysql.sock
    log_error = /data/3307/mysql.log
    log_bin = /data/3307/mysql-bin
    port = 3307
    server_id = 7
    [client]
    socket = /data/3307/mysql.sock

      剩下两个配置文件复制+替换

      

       4、查看配置文件目录结构

      

       5、授权

    chown -R mysql.mysql /data

      6、分别初始化三个实例

    [root@controller scripts]# ./mysql_install_db --defaults-file=/data/3308/my.cnf --user=mysql --basedir=/application/mysql --datadir=/data/3308/data
    Installing MySQL system tables...2020-09-11 16:30:10 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. 
    Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2020-09-11 16:30:10 0 [Note] Ignoring --secure-file-priv value as server is running with --bootstrap. 2020-09-11 16:30:10 0 [Note] /application/mysql/bin/mysqld (mysqld 5.6.40-log) starting as process 1633 ... OK Filling help tables...2020-09-11 16:30:13 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated.
    Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2020-09-11 16:30:13 0 [Note] Ignoring --secure-file-priv value as server is running with --bootstrap. 2020-09-11 16:30:13 0 [Note] /application/mysql/bin/mysqld (mysqld 5.6.40-log) starting as process 1655 ... OK To start mysqld at boot time you have to copy support-files/mysql.server to the right place for your system PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER ! To do so, start the server, then issue the following commands: /application/mysql/bin/mysqladmin -u root password 'new-password' /application/mysql/bin/mysqladmin -u root -h controller password 'new-password' Alternatively you can run: /application/mysql/bin/mysql_secure_installation

      7、分别启动三个实例

    [root@controller scripts]# mysqld_safe --defaults-file=/data/3308/my.cnf &
    [2] 1678
    [root@controller scripts]# 200911 16:31:20 mysqld_safe Logging to '/data/3308/mysql.log'.
    200911 16:31:20 mysqld_safe Starting mysqld daemon with databases from /data/3308/data

      8、查看端口验证

      

     二、登录多实例

      1、登录

    [root@controller scripts]# mysql -uroot -p -S /data/3308/mysql.sock 
    Enter password: 
    Welcome to the MySQL monitor.  Commands end with ; or g.
    Your MySQL connection id is 2
    Server version: 5.6.40-log MySQL Community Server (GPL)
    
    Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
    
    Oracle is a registered trademark of Oracle Corporation and/or its
    affiliates. Other names may be trademarks of their respective
    owners.
    
    Type 'help;' or 'h' for help. Type 'c' to clear the current input statement.
    
    mysql> 

      2、设置密码

    [root@controller scripts]# mysqladmin -uroot -p -S /data/3307/mysql.sock password 123456
    Enter password: 
    Warning: Using a password on the command line interface can be insecure.

      3、验证

    [root@controller scripts]# mysql -uroot -p -S /data/3308/mysql.sock 
    Enter password: 
    Welcome to the MySQL monitor.  Commands end with ; or g.
    Your MySQL connection id is 7
    Server version: 5.6.40-log MySQL Community Server (GPL)
    
    Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
    
    Oracle is a registered trademark of Oracle Corporation and/or its
    affiliates. Other names may be trademarks of their respective
    owners.
    
    Type 'help;' or 'h' for help. Type 'c' to clear the current input statement.
    
    mysql> show variables like 'server_id';
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | server_id     | 8     |
    +---------------+-------+
    1 row in set (0.00 sec)
    
    mysql> 

      4、脚本

    [root@controller scripts]# vim /usr/sbin/mysql3307
    mysql -uroot -p3307 -S /data/3307/mysql.sock

      5、授权

    [root@controller scripts]# chmod +x /usr/sbin/mysql*
    [root@controller scripts]# chmod 700 /usr/sbin/mysql* 推荐用这个,只能root执行

       6、登录

    [root@controller scripts]# mysql3307
    Warning: Using a password on the command line interface can be insecure.
    Welcome to the MySQL monitor.  Commands end with ; or g.
    Your MySQL connection id is 2
    Server version: 5.6.40-log MySQL Community Server (GPL)
    
    Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
    
    Oracle is a registered trademark of Oracle Corporation and/or its
    affiliates. Other names may be trademarks of their respective
    owners.
    
    Type 'help;' or 'h' for help. Type 'c' to clear the current input statement.
    
    mysql> 

     三、误删除mysql里面所有用户

      1、误删所有用户

    mysql> truncate mysql.user;                            删除user表的所有用户

      

       2、登录

    [root@controller tmp]# mysqld_safe --skip-grant-tables &                     这种方式启动mysql,跳过权限验证,远程,本地,都可以免密登录,生产环境不建议使用

      

       3、登录

    [root@controller tmp]# mysqld_safe --skip-grant-tables --skip-networking &    这种方式启动mysql,允许本地,免密登录

      

       4、创建用户

        方法一:

      

        方法二:

     insert into mysql.user values ('localhost','root',PASSWORD('123456'),
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    'Y',
    '',
    '',
    '',
    '',0,0,0,0,'mysql_native_password','','N');

       5、授权

        查看用户,没有任何权限

      

        

       6、赋予超级权限

      

       7、查看用户权限

      

       8、退出mysql,再以正常方式启动mysql。就可以了。

       

        

      

  • 相关阅读:
    第一章 管理程序流(In .net4.5) 之 实现多线程和异步处理
    第十三章 接口
    第十二章 泛型
    第十一章 事件
    SqlServer杀死所有正在使用中的进程
    SqlServer数据库一直显示“正在还原”问题
    大叔学Spring Boot笔记(二)基本概念
    大叔学Spring Boot笔记(一)初识Sprint Boot
    SqlServer中的对象类型代码
    SqlServer将Json串转成表结果
  • 原文地址:https://www.cnblogs.com/aqicheng/p/13652474.html
Copyright © 2011-2022 走看看