zoukankan      html  css  js  c++  java
  • mysql架构解析

    • 架构

      mysql是cs架构,在服务端可以启动该mysqld服务,mysqld进程默认监听在tcp:3306。在客户端使用命令行工具mysql或者图形化工具navicat for mysql进行远程连接,连接信息包括user,password,host,连接池组件会到mysql.user表中验证用户和密码是否ok,登录host时候匹配。通过则登录成功。

      在服务端,最外层是connector组件,用于外部应用程序访问数据。

      下一层是连接池组件,用于验证等。管理服务和工具,SQL接口组件,

      下面是插件式存储引擎,文件系统。

      查看mysql在磁盘上的存储:

    MariaDB [(none)]> show variables like 'datadir';
    +---------------+-----------------+
    | Variable_name | Value           |
    +---------------+-----------------+
    | datadir       | /var/lib/mysql/ |
    +---------------+-----------------+
    1 row in set (0.00 sec)
    [root@sqlm mysql]# ll -h
    total 47M
    -rw-rw---- 1 mysql mysql  16K Mar  3 10:03 aria_log.00000001
    -rw-rw---- 1 mysql mysql   52 Mar  3 10:03 aria_log_control
    -rw-rw---- 1 mysql mysql  26M Mar 20 19:58 ibdata1
    -rw-rw---- 1 mysql mysql 5.0M Mar 20 19:58 ib_logfile0
    -rw-rw---- 1 mysql mysql 5.0M Mar 20 19:58 ib_logfile1
    -rw-rw---- 1 mysql mysql 1.5K Feb  8 15:46 master1-bin.000001
    -rw-rw---- 1 mysql mysql 1.8M Feb 11 14:35 master1-bin.000002
    -rw-rw---- 1 mysql mysql  264 Mar  3 10:03 master1-bin.000003
    -rw-rw---- 1 mysql mysql 8.8M Mar  6 17:09 master1-bin.000004
    -rw-rw---- 1 mysql mysql 1.8K Mar 19 21:04 master1-bin.000005
    -rw-rw---- 1 mysql mysql  245 Mar 20 19:41 master1-bin.000006
    -rw-rw---- 1 mysql mysql  126 Mar 20 19:41 master1-bin.index
    

      

    • 插件式存储引擎

       存储引擎是mysql区别于其他数据库的一个最重要特性。存储引擎是表级别的,可以针对不同功能的表,设定不同的存储引擎(每个存储引擎的特点不一样),以达到最优性能。我们应该深刻的意识到,存储引擎是mysql的核心。

       mysql提供了存储引擎接口,使我们可以编写自己的存储引擎。在大兴企业中,会有人员开发更加适合于自己业务的存储引擎。

     show engines命令显示mysql支持的存储引擎。innodb为默认引擎。

    MariaDB [(none)]> show engines;
    +--------------------+---------+----------------------------------------------------------------------------+--------------+------+------------+
    | Engine             | Support | Comment                                                                    | Transactions | XA   | Savepoints |
    +--------------------+---------+----------------------------------------------------------------------------+--------------+------+------------+
    | CSV                | YES     | CSV storage engine                                                         | NO           | NO   | NO         |
    | MRG_MYISAM         | YES     | Collection of identical MyISAM tables                                      | NO           | NO   | NO         |
    | MEMORY             | YES     | Hash based, stored in memory, useful for temporary tables                  | NO           | NO   | NO         |
    | BLACKHOLE          | YES     | /dev/null storage engine (anything you write to it disappears)             | NO           | NO   | NO         |
    | MyISAM             | YES     | MyISAM storage engine                                                      | NO           | NO   | NO         |
    | InnoDB             | DEFAULT | Percona-XtraDB, Supports transactions, row-level locking, and foreign keys | YES          | YES  | YES        |
    | ARCHIVE            | YES     | Archive storage engine                                                     | NO           | NO   | NO         |
    | FEDERATED          | YES     | FederatedX pluggable storage engine                                        | YES          | NO   | YES        |
    | PERFORMANCE_SCHEMA | YES     | Performance Schema                                                         | NO           | NO   | NO         |
    | Aria               | YES     | Crash-safe tables with MyISAM heritage                                     | NO           | NO   | NO         |
    +--------------------+---------+----------------------------------------------------------------------------+--------------+------+------------+
    10 rows in set (0.00 sec)
    
    • 配置文件

      mysql的配置文件以参数集的方式体现,每个参数集下有很多parameter=value的形式体现。[mysqld]为daemon service,[mysqld_safe]为线程安全。这些配置在3大点中有所体现。

    [root@sqlm ~]# cat /etc/my.cnf
    [mysqld]
    datadir=/var/lib/mysql
    socket=/var/lib/mysql/mysql.sock
    log-bin
    server_id=1
    log-basename=master1
    # Disabling symbolic-links is recommended to prevent assorted security risks
    symbolic-links=0
    # Settings user and group are ignored when systemd is used.
    # If you need to run mysqld under a different user or group,
    # customize your systemd unit file for mariadb according to the
    # instructions in http://fedoraproject.org/wiki/Systemd
    
    [mysqld_safe]
    log-error=/var/log/mariadb/mariadb.log
    pid-file=/var/run/mariadb/mariadb.pid
    
    #
    # include all files from the config directory
    #
    !includedir /etc/my.cnf.d
    
    log-bin=mysql-bin
    
  • 相关阅读:
    el-input 标签中密码的显示和隐藏
    java 使用RedisTemplate实现Redis事务
    mac 安装 Java 环境
    Snowflake 分布式UUID
    lsof 查看端口使用时刻
    nginx.pid" failed (2: No such file or directory)
    解决Redis之MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist
    Linux环境下 Jna 解决so依赖文件not found
    Ubuntu mysql 在线安装
    Linux中为什么执行自己的程序要在前面加./
  • 原文地址:https://www.cnblogs.com/jabbok/p/8605136.html
Copyright © 2011-2022 走看看