Maison base de données tutoriel mysql 新手必看:一步到位之InnoDB_MySQL

新手必看:一步到位之InnoDB_MySQL

Jun 01, 2016 pm 01:37 PM
开发者 领域

bitsCN.com

新手必看:一步到位之InnoDB

 

   前言:MySQL发展到今天,InnoDB引擎已经作为绝对的主力,除了像大数据量分析等比较特殊领域需求外,它适用于众多场景。然而,仍有不少开发者还在“执迷不悟”的使用MyISAM引擎,觉得对InnoDB无法把握好,还是MyISAM简单省事,还能支持快速COUNT(*)。本文是由于最近几天帮忙处理discuz论坛有感而发,希望能对广大开发者有帮助。    

 

   1. 快速认识InnoDB

   InnoDB是MySQL下使用最广泛的引擎,它是基于MySQL的高可扩展性和高性能存储引擎,从5.5版本开始,它已经成为了默认引擎。

   InnODB引擎支持众多特性:

a) 支持ACID,简单地说就是支持事务完整性、一致性; 

b) 支持行锁,以及类似ORACLE的一致性读,多用户并发;

c) 独有的聚集索引主键设计方式,可大幅提升并发读写性能;

d) 支持外键;    

e) 支持崩溃数据自修复;

   InnoDB有这么多特性,比MyISAM来的优秀多了,还犹豫什么,果断的切换到InnoDB引擎吧 

   2. 修改InnoDB配置选项

   可以选择官方版本,或者Percona的分支,如果不知道在哪下载,就google吧。

   安装完MySQL后,需要适当修改下my.cnf配置文件,针对InnoDB相关的选项做一些调整,才能较好的运行InnoDB。

   相关的选项有:

#InnoDB存储数据字典、内部数据结构的缓冲池,16MB 已经足够大了。

innodb_additional_mem_pool_size = 16M

 

#InnoDB用于缓存数据、索引、锁、插入缓冲、数据字典等

#如果是专用的DB服务器,且以InnoDB引擎为主的场景,通常可设置物理内存的50%

#如果是非专用DB服务器,可以先尝试设置成内存的1/4,如果有问题再调整

#默认值是8M,非常坑X,这也是导致很多人觉得InnoDB不如MyISAM好用的缘故

innodb_buffer_pool_size = 4G

#InnoDB共享表空间初始化大小,默认是 10MB,也非常坑X,改成 1GB,并且自动扩展

innodb_data_file_path = ibdata1:1G:autoextend

 

#如果不了解本选项,建议设置为1,能较好保护数据可靠性,对性能有一定影响,但可控

innodb_flush_log_at_trx_commit = 1

 

#InnoDB的log buffer,通常设置为 64MB 就足够了

innodb_log_buffer_size = 64M

 

#InnoDB redo log大小,通常设置256MB 就足够了

innodb_log_file_size = 256M

 

#InnoDB redo log文件组,通常设置为 2 就足够了

innodb_log_files_in_group = 2

 

#启用InnoDB的独立表空间模式,便于管理

innodb_file_per_table = 1

 

#启用InnoDB的status file,便于管理员查看以及监控等

innodb_status_file = 1

 

#设置事务隔离级别为 READ-COMMITED,提高事务效率,通常都满足事务一致性要求

transaction_isolation = READ-COMMITTED 

   在这里,其他配置选项也需要注意:

#设置最大并发连接数,如果前端程序是PHP,可适当加大,但不可过大

#如果前端程序采用连接池,可适当调小,避免连接数过大

max_connections = 60

#最大连接错误次数,可适当加大,防止频繁连接错误后,前端host被mysql拒绝掉

max_connect_errors = 100000

 

#设置慢查询阀值,建议设置最小的 1 秒

long_query_time = 1

 

#设置临时表最大值,这是每次连接都会分配,不宜设置过大 max_heap_table_size 和 tmp_table_size 要设置一样大

max_heap_table_size = 96M

tmp_table_size = 96M

 

#每个连接都会分配的一些排序、连接等缓冲,一般设置为 2MB 就足够了

sort_buffer_size = 2M

join_buffer_size = 2M

read_buffer_size = 2M

read_rnd_buffer_size = 2M

 

#建议关闭query cache,有些时候对性能反而是一种损害

query_cache_size = 0

 

#如果是以InnoDB引擎为主的DB,专用于MyISAM引擎的 key_buffer_size 可以设置较小,8MB 已足够

#如果是以MyISAM引擎为主,可设置较大,但不能超过4G

#在这里,强烈建议不使用MyISAM引擎,默认都是用InnoDB引擎

key_buffer_size = 8M

#设置连接超时阀值,如果前端程序采用短连接,建议缩短这2个值

#如果前端程序采用长连接,可直接注释掉这两个选项,是用默认配置(8小时)

interactive_timeout = 120

wait_timeout = 120

   3. 开始使用InnoDB引擎

   修改完配置文件,即可启动MySQL。启动完毕后,在MySQL的datadir目录下,若产生以下几个文件,则表示应该可以使用InnoDB引擎了。

-rw-rw---- 1 mysql mysql 1.0G Sep 21 17:25 ibdata1

-rw-rw---- 1 mysql mysql 256M Sep 21 17:25 ib_logfile0

-rw-rw---- 1 mysql mysql 256M Sep 21 10:50 ib_logfile1

   登录MySQL后,执行命令,确认已启用InnoDB引擎:

(root:imysql.cn:Thu Oct 15 09:16:22 2009)[mysql]> show engines;

+------------+---------+----------------------------------------------------------------+--------------+------+------------+

| Engine     | Support | Comment                                                        | Transactions | XA   | Savepoints |

+------------+---------+----------------------------------------------------------------+--------------+------+------------+

| InnoDB     | YES     | Supports transactions, row-level locking, and foreign keys     | YES          | YES  | YES        |

   接下来创建一个InnoDB表:

(root:imysql.cn:Thu Oct 15 09:16:22 2009)[mysql]> 

CREATE TABLE my_innodb_talbe(

id INT UNSIGNED NOT NULL AUTO_INCREMENT,

name VARCHAR(20) NOT NULL DEFAULT /'/',

passwd VARCHAR(32) NOT NULL DEFAULT /'/',

PRIMARY KEY(id),

UNIQUE KEY `idx_name`(name)

) ENGINE = InnoDB;

   有几个和MySQL(尤其是InnoDB引擎)数据表设计相关的建议,希望开发者朋友能遵循:

a) 所有InnoDB数据表都创建一个和业务无关的自增数字型作为主键,对保证性能很有帮助;

b) 杜绝使用text/blob,确实需要使用的,尽可能拆分出去成一个独立的表;

c) 时间戳建议使用 TIMESTAMP 类型存储;

d) IPV4 地址建议用 INT UNSIGNED 类型存储;

e) 性别等非是即非的逻辑,建议采用 TINYINT 存储,而不是 CHAR(1);

f) 存储较长文本内容时,建议采用JSON/BSON格式存储

 

bitsCN.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quels sont les cinq domaines les plus rentables du self-média ? Quelle est la direction du soutien de Douyin en 2024 ? Quels sont les cinq domaines les plus rentables du self-média ? Quelle est la direction du soutien de Douyin en 2024 ? Mar 22, 2024 am 10:11 AM

Avec le développement rapide d'Internet, l'industrie des médias personnels est devenue le centre d'attention de plus en plus de personnes. Dans cette industrie, certains domaines ont attiré beaucoup d’attention en raison de leurs vastes perspectives de marché et de leur rentabilité. Cet article vous dévoilera les cinq domaines les plus rentables du self-média, et discutera de l'orientation du soutien de Douyin en 2024 pour vous aider à mieux saisir les opportunités de développement du self-média. 1. Quels sont les cinq domaines les plus rentables du self-média ? Avec l’essor de l’éducation en ligne, le domaine de l’éducation et de la formation est devenu de plus en plus populaire. Les gens sont prêts à investir dans l’acquisition de connaissances et de compétences, non seulement dans les cours universitaires, mais également dans la formation professionnelle et l’avancement professionnel. Les créateurs auto-médias peuvent atteindre la rentabilité en créant du contenu éducatif de haute qualité pour inciter les étudiants à payer pour apprendre. Cette tendance montre que les gens sont intéressés par l'apprentissage tout au long de la vie.

Mise à niveau du service d'accès Tmall Elf Cloud : frais de développement gratuits Mise à niveau du service d'accès Tmall Elf Cloud : frais de développement gratuits Jan 09, 2024 pm 10:06 PM

Selon les informations de ce site du 9 janvier, Tmall Elf a récemment annoncé la mise à niveau du service d'accès Yunyun. Le service d'accès Yunyun mis à niveau passera du mode gratuit au mode payant à partir du 1er janvier. Ce site est doté de nouvelles fonctionnalités et optimisations : optimisation du protocole cloud pour améliorer la stabilité des connexions des appareils ; optimisation du contrôle vocal pour les catégories clés de mise à niveau des autorisations de compte : ajout de la fonction d'affichage des applications tierces des développeurs dans Tmall Genie pour aider les utilisateurs à mettre à jour plus rapidement ; C'est pratique pour la liaison de compte. Dans le même temps, l'autorisation de compte d'application tierce pour les développeurs a été ajoutée pour prendre en charge la liaison en un clic des comptes Tmall Elf ; , les utilisateurs peuvent contrôler les appareils et obtenir des informations via l'application et les haut-parleurs de l'écran. L'état de l'équipement ; de nouvelles capacités de liaison de scène intelligentes, de nouveaux attributs et événements de produit, qui peuvent être signalés comme état ou événements pour définir Tmall.

Un article sur la prévision des séries chronologiques sous la vague des modèles à grande échelle Un article sur la prévision des séries chronologiques sous la vague des modèles à grande échelle Nov 06, 2023 am 08:13 AM

Aujourd'hui, je vais vous parler de l'application des grands modèles dans la prévision de séries chronologiques. Avec le développement de grands modèles dans le domaine de la PNL, de plus en plus de travaux tentent d'appliquer de grands modèles au domaine de la prédiction de séries chronologiques. Cet article présente les principales méthodes d'application des grands modèles à la prévision des séries chronologiques et résume certains travaux récents connexes pour aider chacun à comprendre les méthodes de recherche sur la prévision des séries chronologiques à l'ère des grands modèles. 1. Méthodes de prévision de grandes séries chronologiques de modèles. Au cours des trois derniers mois, de nombreux travaux de prévision de grandes séries chronologiques de modèles ont vu le jour, qui peuvent essentiellement être divisés en deux types. Contenu réécrit : une approche consiste à utiliser directement des modèles de PNL à grande échelle pour la prévision de séries chronologiques. Dans cette méthode, des modèles NLP à grande échelle tels que GPT et Llama sont utilisés pour la prédiction de séries chronologiques. La clé réside dans la manière de le faire.

Afin de sauvegarder les souvenirs d'enfance, le développeur a décidé d'utiliser une programmation ancienne : un remake haute définition d'un jeu en Flash Afin de sauvegarder les souvenirs d'enfance, le développeur a décidé d'utiliser une programmation ancienne : un remake haute définition d'un jeu en Flash Apr 11, 2023 pm 10:16 PM

Il y a plus de deux ans, Adobe a annoncé de manière captivante qu'il mettrait fin au support de Flash le 31 décembre 2020, annonçant ainsi la fin d'une époque. Deux ans plus tard, Adobe a déjà supprimé toutes les archives des premières versions de Flash Player de son site officiel et bloqué l'exécution du contenu Flash. Microsoft a également mis fin à la prise en charge d'Adobe Flash Player et a interdit son exécution sur n'importe quel navigateur Microsoft. Le composant Adobe Flash Player a été définitivement supprimé via Windows Update en juillet 2021. Quand Flash

Quel outil est PyCharm ? À quels développeurs convient-il ? Quel outil est PyCharm ? À quels développeurs convient-il ? Feb 20, 2024 am 08:29 AM

PyCharm est un environnement de développement intégré (IDE) Python développé par JetBrains. Il fournit aux développeurs Python des fonctionnalités et des outils riches pour les aider à écrire, déboguer et déployer du code Python plus efficacement. PyCharm possède de nombreuses fonctionnalités puissantes, notamment la complétion intelligente de code, la coloration syntaxique, le débogueur, les outils de tests unitaires, l'intégration du contrôle de version, la refactorisation du code, etc. Ces fonctionnalités permettent aux développeurs de localiser rapidement les problèmes de code, d'améliorer la qualité du code et d'accélérer les cycles de développement.

Webman : le compagnon idéal du développeur Webman : le compagnon idéal du développeur Aug 13, 2023 pm 02:25 PM

Webman : le partenaire idéal du développeur Avec le développement d'Internet, le développement Web est devenu un domaine très important. Dans ce domaine, les développeurs doivent maîtriser une variété de technologies et d'outils pour créer des applications Web efficaces et fiables. En tant que partenaire idéal du développeur, Webman fournit de nombreuses fonctionnalités et outils utiles qui simplifient considérablement le processus de développement et améliorent l'efficacité. Webman est un framework de développement Web basé sur le langage Python. Il combine de nombreux outils et bibliothèques couramment utilisés pour fournir aux développeurs.

PHP 8.3 : mises à jour importantes que les développeurs doivent connaître PHP 8.3 : mises à jour importantes que les développeurs doivent connaître Nov 27, 2023 am 10:19 AM

PHP est un langage de programmation open source côté serveur et l'un des langages les plus populaires pour le développement d'applications Web. À mesure que la technologie continue de se développer, PHP est constamment mis à jour et amélioré. La dernière version de PHP est la 8.3. Cette version apporte des mises à jour et améliorations importantes. Cet article présentera quelques mises à jour importantes que les développeurs doivent connaître. Améliorations des types et des propriétés PHP 8.3 introduit un certain nombre d'améliorations aux types et aux propriétés, la plus populaire étant l'introduction du nouveau type union dans les déclarations de type. Le type Union permet des paramètres pour les fonctions

Golang : le premier choix des développeurs d'IA Golang : le premier choix des développeurs d'IA Sep 09, 2023 pm 12:10 PM

Golang : le premier choix des développeurs d'IA Résumé : L'intelligence artificielle (IA) devient progressivement un élément indispensable de notre vie quotidienne. Le développement rapide de la technologie de l’IA a conduit de plus en plus de développeurs à explorer comment utiliser l’IA pour résoudre divers problèmes. Dans le développement de l’IA, le choix du bon langage de programmation est particulièrement important. Parmi les nombreux langages de programmation, Golang (également connu sous le nom de Go) est devenu le choix de plus en plus de développeurs d'IA en raison de ses avantages uniques.

See all articles