데이터 베이스 MySQL 튜토리얼 浅谈MySQL学习及思考

浅谈MySQL学习及思考

Jun 07, 2016 pm 05:40 PM
MySQL 최적화 MySQL 디자인 raid

本博文旨在结合自己看书理解,并借此图进行说明,如有谬误,望大家指正,以共同探讨为目的,交流学习。首先介绍一下架构图的由来:最近看关于mysql方面书籍的一点

 本博文旨在结合自己看书理解,并借此图进行说明,如有谬误,望大家指正,以共同探讨为目的,交流学习。

首先介绍一下架构图的由来:最近看关于mysql方面书籍的一点心得,把文字转化成图片而得,方便理解。

 

我主要从读、写、底层磁盘三方面进行阐述:

1、读操作:

  我们知道数据在读取的时候,需要从磁盘读到内存中,然后再做相应的操作,而在优化读操作的时候,主要想buffer,cache这些进行优化:

  以上是读操作的一些介绍,接下来是写操作方面的。

2、写操作:

  写操作分为热门数据和普通数据,简而言之就是按照频繁程度进行划分的。然频繁修改的数据可以和非频繁的数据进行分开。

举个例子:

  • 比如我网站每天PV 1000w,而在PV统计的表中,我每次访问就会插入一条数据,一天下来1000w,当然这还不可能是分摊在24小时,就按照10个小时的中高峰期来说,每个小时也是100w条数据,如果我的网站其他表中的跟新的数据每天2w条,相对1000w来说,就是太少了,但是这2w条数据有事比较重要的数据,如果是用户注册、客户购买商品下的订单,他可比记录PV信息更重要吧,这时候问题就出现了:我的热门数据究竟是什么?是PV统计还是订单、注册用户,不言而喻,当然其中一个还是重点数据了,所以为了不让记录PV的数据来影响更重要的数据的更新,我们可以把他分开,如果后面还有主从同步的话,分开后,同步的负载也会降低很多,这样就可以只同步2w条数据,香港空间,而不用考虑那1000w条数据了,服务器空间,进而主数据库的负载也会降低。 
  •   现在是把热门数据和普通数据分开了,但是对于高并发的数据库服务器来说,如何抗并发,这到成了一个重要的问题,当然高配服务器,集群用上,包括Nosql也用上可一解决这样的问题,如果在设计的时候能使用队列机制,这样不就更好了嘛!(地铁上看到一句广告语:有序方能通畅!)

      当然你可能有更好的方法,香港虚拟主机,可以共同交流。

    3、底层磁盘规划:

     

     

     

  • RAID6: 
  • RADI6技术是在RAID5基础上,为了进一步加强数据保护而设计的一种RAID方式,实际上是一种扩展RAID5等级。与RAID5的不同之处于除了每个硬盘上都有同级数据XOR校验区外,还有一个针对每个数据块的XOR校验区。当然,当前盘数据块的校验数据不可能存在当前盘而是交错存储的,具体形式见图。这样一来,等于每个数据块有了两个校验保护屏障(一个分层校验,一个是总体校验),因此RAID6的数据冗余性能相当好。但是,由于增加了一个校验,所以写入的效率较RAID5还差,而且控制系统的设计也更为复杂,第二块的校验区也减少了有效存储空间。 
  •  

      而对于热门数据可以使用RAID10,这样他的性能和安全性会提高很多;而普通数据可以采用RAID5,主要提供安全性,像临时表这样的使用RAID0,在性能上发挥巨大的优势。

    以上均个人见解,如有疑问,可共同交流学习!

     

    本文出自 “Ro の博客” 博客,请务必保留此出处

    본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

    핫 AI 도구

    Undresser.AI Undress

    Undresser.AI Undress

    사실적인 누드 사진을 만들기 위한 AI 기반 앱

    AI Clothes Remover

    AI Clothes Remover

    사진에서 옷을 제거하는 온라인 AI 도구입니다.

    Undress AI Tool

    Undress AI Tool

    무료로 이미지를 벗다

    Clothoff.io

    Clothoff.io

    AI 옷 제거제

    Video Face Swap

    Video Face Swap

    완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

    뜨거운 도구

    메모장++7.3.1

    메모장++7.3.1

    사용하기 쉬운 무료 코드 편집기

    SublimeText3 중국어 버전

    SublimeText3 중국어 버전

    중국어 버전, 사용하기 매우 쉽습니다.

    스튜디오 13.0.1 보내기

    스튜디오 13.0.1 보내기

    강력한 PHP 통합 개발 환경

    드림위버 CS6

    드림위버 CS6

    시각적 웹 개발 도구

    SublimeText3 Mac 버전

    SublimeText3 Mac 버전

    신 수준의 코드 편집 소프트웨어(SublimeText3)

    Windows 11에서 RAID 1을 구성하는 단계 Windows 11에서 RAID 1을 구성하는 단계 Sep 22, 2023 pm 03:05 PM

    Windows 11에는 엄격한 요구 사항이 있으므로 해당 저장소를 확보하는 데 어려움을 겪은 후에 하드 드라이브와 데이터를 잃는 것은 부끄러운 일입니다. 하드 드라이브 오류에 대비하는 데 도움이 될 수 있는 좋은 소식이 있습니다. 내장된 Windows 도구를 사용하면 한 드라이브에서 다른 드라이브로 모든 데이터를 복사할 수 있습니다. 이렇게 하면 드라이브 하나에 오류가 발생하면 교체 드라이브에 원본 ​​데이터를 미러링하고 재구축할 수 있습니다. Windows 11에서 RAID를 사용할 수 있나요? Windows 저장소 공간 기능을 사용하면 Windows 11에서 RAID를 수행할 수 있습니다. 이 기능을 사용하면 성능 저하 없이 컴퓨터에 직접 연결된 하드 드라이브를 사용하여 여러 개의 가상 디스크를 생성할 수 있습니다. Raid의 장점: 디스크 비용 절감

    Windows 11에서 외장 하드 드라이브를 RAID하는 방법 Windows 11에서 외장 하드 드라이브를 RAID하는 방법 Sep 16, 2023 pm 10:05 PM

    RAID(Redundant Array of Independent Disks)는 여러 외부 드라이브를 하나로 결합하는 데이터 저장 기술입니다. 대용량 하드 드라이브의 가격이 비쌀 때 널리 사용되었지만 여전히 많은 사람들이 RAID 외장 드라이브 방식을 선호합니다. RAID에는 여러 수준이 있으며 각 수준은 특정 목적을 수행합니다. 일반 사용자는 복잡함을 깊이 파고들 필요가 없으며 RAID0 또는 RAID1의 간단한 설정만으로도 제대로 작동한다는 점을 명심하십시오. 외장 드라이브 RAID를 고려해야 하는 이유: 향상된 PC 성능 구성이 쉽고 기존 대안보다 저렴함 더 빠른 데이터 읽기 및 쓰기 미러링을 통한 효율적인 백업 솔루션 Windows 11에서 외장 드라이브를 RAID하는 방법은 무엇입니까? RAID 외장 하드 드라이브를 사용하기 전에 먼저 다음 사항에 주의해야 합니다.

    Linux에서 Raid 디스크 배열 정보를 확인하는 방법 Linux에서 Raid 디스크 배열 정보를 확인하는 방법 May 16, 2023 pm 09:46 PM

    Linux에서 소프트 및 하드 RAID 정보를 보는 방법. 소프트웨어 raid: Linux 시스템 자체를 통해서만 cat/proc/mdstat를 볼 수 있으며 raid 수준, 상태 및 기타 정보를 볼 수 있습니다. 하드웨어 RAID: cmdline, 그래픽 인터페이스 등 설치된 RAID 제조사의 관리 도구를 통해 확인하는 것이 가장 좋습니다. 예를 들어, Adapterc의 하드웨어 카드는 다음 명령을 통해 볼 수 있습니다: #/usr/dpt/raidutil-lall 매우 자세한 정보를 볼 수 있습니다. 물론, 해당 관리 도구가 설치되지 않는 경우가 많습니다. Linux 자체에만 의존할 수 있다면 일반적으로 #dmesg|grep-irai 두 가지 방법을 알고 있습니다.

    성능을 향상시키기 위해 MySQL을 통해 AVG 기능을 최적화하는 방법 성능을 향상시키기 위해 MySQL을 통해 AVG 기능을 최적화하는 방법 May 11, 2023 am 08:00 AM

    MySQL에서 AVG 기능을 최적화하여 성능을 향상시키는 방법 MySQL은 많은 강력한 기능을 포함하는 널리 사용되는 관계형 데이터베이스 관리 시스템입니다. AVG 함수는 평균을 계산하는 데 널리 사용되지만 이 함수는 전체 데이터 세트를 순회해야 하기 때문에 대규모 데이터의 경우 성능 문제가 발생합니다. 이 글에서는 MySQL을 통해 AVG 기능을 최적화하여 성능을 향상시키는 방법을 자세히 소개합니다. 1. 인덱스 사용 인덱스는 MySQL 최적화에서 가장 중요한 부분입니다.

    TokuDB 엔진 기반 MySQL 최적화: 쓰기 및 압축 성능 향상 TokuDB 엔진 기반 MySQL 최적화: 쓰기 및 압축 성능 향상 Jul 25, 2023 pm 11:45 PM

    TokuDB 엔진 기반 MySQL 최적화: 쓰기 및 압축 성능 향상 소개: 일반적으로 사용되는 관계형 데이터베이스 관리 시스템인 MySQL은 빅 데이터 시대의 맥락에서 증가하는 쓰기 압력과 스토리지 요구 사항에 직면해 있습니다. 이러한 과제를 해결하기 위해 TokuDB 엔진이 탄생했습니다. 이 기사에서는 TokuDB 엔진을 사용하여 MySQL의 쓰기 성능 및 압축 성능을 향상시키는 방법을 소개합니다. 1. TokuDB 엔진이란 무엇입니까? TokuDB 엔진은 높은 쓰기를 처리하도록 설계된 빅데이터 중심 엔진입니다.

    MySQL의 낮은 수준 최적화를 달성하는 방법: SQL 문의 고급 최적화를 위한 팁 및 모범 사례 MySQL의 낮은 수준 최적화를 달성하는 방법: SQL 문의 고급 최적화를 위한 팁 및 모범 사례 Nov 08, 2023 pm 04:32 PM

    MySQL은 웹 애플리케이션 개발 및 데이터 저장에 일반적으로 사용되는 널리 사용되는 관계형 데이터베이스 관리 시스템입니다. 실제 애플리케이션에서는 MySQL의 기본 최적화가 특히 중요하며, 그 중 SQL 문의 고급 최적화는 데이터베이스 성능을 향상시키는 핵심입니다. 이 기사에서는 MySQL의 기본 최적화 구현을 위한 몇 가지 팁과 모범 사례는 물론 특정 코드 예제를 소개합니다. 쿼리 조건 결정 SQL 문을 작성할 때 먼저 쿼리 조건을 명확하게 정의하고 무제한 와일드카드 쿼리 사용을 피해야 합니다. 즉, 쿼리를 열 때 "%"를 사용하지 마십시오.

    전자상거래 애플리케이션의 MySQL 최적화 및 보안 프로젝트 경험 분석 전자상거래 애플리케이션의 MySQL 최적화 및 보안 프로젝트 경험 분석 Nov 03, 2023 am 10:42 AM

    MySQL은 전자상거래 분야에서 널리 사용되는 관계형 데이터베이스 관리 시스템입니다. 전자상거래 애플리케이션에서는 MySQL을 최적화하고 보호하는 것이 중요합니다. 이 기사에서는 전자 상거래 애플리케이션에서 MySQL의 최적화 및 보안 프로젝트 경험을 분석합니다. 1. 성능 최적화 데이터베이스 아키텍처 설계: 전자상거래 애플리케이션에서는 데이터베이스 설계가 핵심입니다. 합리적인 테이블 구조 설계와 인덱스 설계로 데이터베이스의 쿼리 성능을 향상시킬 수 있습니다. 동시에 테이블 분할 및 파티셔닝 기술을 사용하면 단일 테이블의 데이터 양을 줄이고 쿼리 효율성을 높일 수 있습니다.

    MySQL 연결 번호 관리를 최적화하는 방법 MySQL 연결 번호 관리를 최적화하는 방법 Mar 16, 2024 am 08:12 AM

    MySQL 연결 번호 관리를 최적화하는 방법 MySQL은 다양한 웹사이트와 애플리케이션에서 널리 사용되는 인기 있는 관계형 데이터베이스 관리 시스템입니다. 실제 애플리케이션 프로세스에서 MySQL 연결 수 관리는 매우 중요한 문제이며, 특히 동시성이 높은 상황에서는 연결 수를 합리적으로 관리하면 시스템의 성능과 안정성을 향상시킬 수 있습니다. 이 기사에서는 자세한 코드 예제를 포함하여 MySQL 연결 번호 관리를 최적화하는 방법을 소개합니다. 1. 연결 수 관리 이해 MySQL에서 연결 수는 시스템이 동시에 연결할 수 있는 연결 수를 의미합니다.

    See all articles