SQL Server 2014: In-Memory OLTP Overview

Slides:



Advertisements
Similar presentations
new database engine component fully integrated into SQL Server 2014 optimized for OLTP workloads accessing memory resident data achive improvements.
Advertisements

6 SQL Server Integration Same manageability, administration & development experience Integrated queries & transactions Integrated HA and backup/restore.
Dandy Weyn Sr. Technical Product Mkt.
Dos and don’ts of Columnstore indexes The basis of xVelocity in-memory technology What’s it all about The compression methods (RLE / Dictionary encoding)
Meanwhile RAM cost continues to drop Moore’s Law on total CPU processing power holds but in parallel processing… CPU clock rate stalled… Because.
Training Workshop Windows Azure Platform. Presentation Outline (hidden slide): Technical Level: 200 Intended Audience: Developers Objectives (what do.
SQL Server 2014: In In-memory OLTP for Database Developers.
SQL Server 2014: Overview Phil ssistalk.com.
Meet Kevin Liu Principal Lead Program Manager Kevin Liu has been with Microsoft and the SQL Server engine team for 7 years, working on key projects like.
Moore’s Law means more transistors and therefore cores, but… CPU clock rate stalled… Meanwhile RAM cost continues to drop.
Introducing Hekaton The next step in SQL Server OLTP performance Mladen Prajdić
Azure.
Enable Operational Analytics (HTAP) in SQL Server 2016 and Azure SQL Database Sunil Agarwal Principal Program Manager, SQL Server Product Tiger Team
Microsoft Connect /6/ :05 AM
Dev and Test Solution reference architecture.
Data Platform and Analytics Foundational Training
Data Platform Modernization
Business Continuity & Disaster Recovery
In-Memory Capabilities
Architectures and Case Studies with In-Memory OLTP in SQL
Data Platform and Analytics Foundational Training
Microsoft Virtual Academy
Dev and Test Solution reference architecture.
System Center Marketing
Dev and Test Solution reference architecture.
Operational Analytics in SQL Server 2016 and Azure SQL Database
System Center Marketing
Business Critical Application Platform
In-Memory Optimization (OLTP) enhancements overview
SQL 2016 new Hosting Offers Secure Database Hybrid HyperScale
Enable the Hybrid Data Platform
UFC #1433 In-Memory tables 2014 vs 2016
What’s New in SQL Server 2016 Master Data Services
Dev and Test Solution reference architecture.
7/17/2018 © 2014 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks.
Taking your application to memory
Dev and Test Solution reference architecture.
Installation and database instance essentials
9/11/2018 © 2014 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks.
9/13/2018 © 2014 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks.
SQL Server 2014 In-Memory OLTP
Introduction to SQL Server Management for the Non-DBA
Business Critical Application Platform
Azure.
Required 9s and data protection: introduction to sql server 2012 alwayson, new high availability solution Santosh Balasubramanian Senior Program Manager.
SQL Server 2014 In-Memory Overview
Cloud Database Based on SQL Server 2012 Technologies
Business Continuity & Disaster Recovery
මොඩියුල විශ්ලේෂණය Buffer Pool Extension භාවිතය.
Taking your application to memory
Data Platform Modernization
SQL 2014 In-Memory OLTP What, Why, and How
TechEd /23/ :44 AM © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered.
TechEd /28/ :51 PM © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered.
Microsoft Virtual Academy
Microsoft Virtual Academy
Accelerate Your Data Insights with SQL Server 2014
Microsoft Virtual Academy
Dev and Test Solution reference architecture.
Microsoft SQL Server 2014 for Oracle DBAs Module 7
Microsoft Ignite /1/ :19 PM
Statistics for beginners – In-Memory OLTP
In-Memory OLTP for Database Developers
Sunil Agarwal | Principal Program Manager
Microsoft Virtual Academy
TechEd /28/2019 7:27 AM © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks.
04 | Performance and the Premium SKU
Windows Azure Hybrid Architectures and Patterns
Microsoft Virtual Academy
Microsoft Virtual Academy
Presentation transcript:

SQL Server 2014: In-Memory OLTP Overview Jos de Bruijn Senior Program Manager jodebrui@microsoft.com

SQL Server 2014 Investments 7/1/2019 SQL Server 2014 Investments In-Memory Technologies Enhanced High Availability New Hybrid Scenarios Other investments In-Memory OLTP 5-25x performance gain for OLTP integrated into SQL Server In-Memory DW 5-25x performance gain and high data compression Updatable and clustered SSD Bufferpool Extension 4-10X of RAM and up to 3X performance gain transparently for apps Always On Enhancements Increased availability and improved manageability of active secondaries Online Database Operations Increased availability for index/partition maintenance Backup to Azure Easy to implement and cost effective Disaster Recovery solution to Azure Storage HA to Azure VM Easy to implement and cost effective high availability solution with Windows Azure VM Deploy to Azure Deployment wizard to migrate database Better together with Windows Server WS2012 ReFS support Online resizing VHDx Hyper-V replica Windows “Blue” support Extending Power View Enable Power View on existing analytic models and support new multi- dimensional models. © 2012 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

SQL Server 2014 In-Memory Technology 7/1/2019 SQL Server 2014 In-Memory Technology In-Memory Technologies Applicable to Transactional workloads: Concurrent data entry, processing and retrieval In-Memory OLTP 5-20X performance gain for OLTP integrated into SQL Server In-Memory DW 5-25X performance gain and high data compression Updatable and clustered SSD Bufferpool Extension 4-10X of RAM and up to 3X performance gain transparently for apps Applicable to Decision support workloads: Large scans and aggregates Applicable to Disk-based transactional workloads: Large working (data)set © 2012 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Outline Motivating trends – hardware, software, apps In-memory OLTP architecture & integration into SQL Server Performance and customer results Review and References

Why In-Memory OLTP (aka Hekaton) Customer demand for ever higher throughput and predictable lower latency OLTP at a lower cost Hardware trends demand architectural changes on RDBMS to meet those demands In-Memory OLTP is: High performance, Memory-optimized OLTP engine, Integrated into SQL Server and Architected for modern hardware http://www.extremetech.com/extreme/176551-new-laser-network-between-nyse-and-nasdaq-will-allow-high- frequency-traders-to-make-even-more-money Last year, Anova completed a laser network link between the London and Frankfurt stock exchanges, and now, it seems the company is nearing completion on a similar laser network between the NYSE and NASDAQ data centers in Mahwah and Carteret, New Jersey. In the case of both networks, Anova is using equipment provided by AOptix, an American company that is contracted by the US military to produce similar laser-based systems for ground-to-aircraft communications. Each AOptix base station is capable of “carrier-grade” availability (five nines, 99.999%) over a distance of 10 kilometers (6.2 miles). The route, which is about 35 miles as the crow flies and skirts the center of Newark, will probably feature around six or seven base stations, each of which will have a direct line of sight with its two nearest neighbors. The link speed, according to the AOptix tech specs, will be around 2Gbps — not exactly massive by fiber-optic standards, but more than enough for a few thousand trades per second.

Hardware Trends New CPU won’t run a short transaction much faster Moore’s Law on total CPU processing power holds but in parallel processing… New CPU won’t run a short transaction much faster CPU clock rate stalled… Because processors would melt… Meanwhile RAM cost continues to drop Actually while some of these are increasing the key point is that they are not increasing exponentially any longer.

Outline Motivating trends – hardware, software, apps In-memory OLTP architecture & integration into SQL Server Performance and customer results Review and References

In-Memory OLTP – Architectural Pillars Customer Benefits High performance data operations Efficient business-logic processing Frictionless scale-up Hybrid engine and integrated experience Architectural Pillars Main-Memory Optimized T-SQL Compiled to Machine Code High Concurrency SQL Server Integration Optimized for in-memory data Indexes (hash and range) exist only in memory No buffer pool, B-trees Stream-based storage T-SQL compiled to machine code via C code generator and VC Invoking a procedure is just a DLL entry-point Aggressive optimizations @ compile-time Multi-version optimistic concurrency control with full ACID support Core engine uses lock-free algorithms No lock manager, latches or spinlocks Same manageability, administration & development experience Integrated queries & transactions Integrated HA and backup/restore First pillar With boxes with huge amount of physical memory, enables entire database, in many cases, to fit in- memory. So your database is indeed in-memory but is it memory optimized? Answer is no. Talk about historical perspective and then walk thru an example of searching for a row through NCI. With Hekaton, the access to in-memory data is very efficient (talk about hash index) Stalled Clock-speed – imagine you have a single threaded application and you want it run faster? There are two choices. (a) get a faster CPU or (b) reduce the number of instructions to execute the app. if you go back few years, most applications were running on machines with < 8 Cores/CPUs. Fast forward today and you see mahcines with 256 Cores within reasonable price-range. SQL Server http://channel9.msdn.com/Events/TechEd/Australia/2010/DAT208 but there are some application patterns that don’t scale as well. For example, last page insert or when many concurrent transactions hit the same page. Drivers Hardware trends Business Steadily declining memory price, NVRAM Stalling CPU clock rate Many-core processors TCO

In-Memory OLTP Integration and Application Migration Client App TDS Handler and Session Management Key SQL Server.exe Parser, Catalog, Optimizer Existing SQL Component T-SQL Query Execution Natively Compiled SPs and Schema Native Compiler In-mem OLTP Component Non-durable table Query Interop Memory Optimized Tables & Indexes Buffer Pool for Tables & Indexes T1 T2 Generated .dll T3 Tables Indexes Talking points: This is a representation of the SQL Server engine you all know and love. At the top are the components for client connectivity, query parsing and optimization, and query execution. At the bottom is a representation of the table and index data, which lives in the data filegroup, operations on tables and indexes are recorded in the transaction log, and data and index pages that are frequently used are in memory, in the buffer pool Hekaton engine lives inside the SQL Server process, and hosts the memory optimized tables and indexes. The memory optimized filegroup is used for recovery of durable tables T1 and T2 are migrated to Hekaton by dropping them, and recreating as memory optimized tables. As you can see, indexes exist only in memory, they are not written to disk and index operations are not logged Interop: The SQL Server query execution engine can access memory optimized tables. Using this feature, any T-SQL query or stored procedure can reference memory optimized tables – no changes needed in the T-SQL. The same query can access both memory optimized and disk-based tables. Native procs: Most efficient access to memory optimized tables is through natively compiled stored procedures. Native procs are just like regular stored procedures, but with an additional compilation step: after the optimizer creates the optimized query plans, the Hekaton compiler takes the query plans and compiles them to machine code as DLLs NDTs: Finally, Hekaton supports also non-durable tables, which are not logged. They do not require any IO operations during transaction processing, but the data is only in memory, so on server crash or AlwaysOn failover the data is lost. Useful, for example, for staging tables in ETL scenarios and Web server session state Memory Optimized Data Filegroup Transaction Log Data Filegroup T1 T2 T3 T1 T2 T3

Create Table DDL CREATE TABLE [Customer]( [CustomerID] INT NOT NULL Hash Index BUCKET_COUNT 1-2X nr of unique index key values CREATE TABLE [Customer]( [CustomerID] INT NOT NULL PRIMARY KEY NONCLUSTERED HASH WITH (BUCKET_COUNT = 1000000), [Name] NVARCHAR(250) NOT NULL, [CustomerSince] DATETIME NULL INDEX [ICustomerSince] NONCLUSTERED ) WITH (MEMORY_OPTIMIZED = ON, DURABILITY = SCHEMA_AND_DATA); Indexes are specified inline NONCLUSTERED indexes are supported This table is memory optimized This table is durable Non-durable tables: DURABILITY=SCHEMA_ONLY

Create Table Type CREATE TYPE [Sales].[SalesOrderDetailType_inmem] AS TABLE ( [OrderQty] [smallint] NOT NULL, [ProductID] [int] NOT NULL, [SpecialOfferID] [int] NOT NULL, [LocalID] [int] NOT NULL, INDEX [IX_ProductID] HASH ([ProductID]) WITH ( BUCKET_COUNT = 8), INDEX [IX_SpecialOfferID] HASH ([SpecialOfferID]) WITH ( BUCKET_COUNT = 8) ) WITH ( MEMORY_OPTIMIZED = ON )

Create Procedure DDL CREATE PROCEDURE [dbo].[InsertOrder] @id INT, @date DATETIME WITH NATIVE_COMPILATION, SCHEMABINDING, EXECUTE AS OWNER AS BEGIN ATOMIC (TRANSACTION ISOLATION LEVEL = SNAPSHOT, LANGUAGE = N'us_english') -- insert T-SQL here END This proc is natively compiled Native procs must be schema-bound Execution context is required Atomic blocks Create a transaction if there is none Otherwise, create a savepoint Session settings are fixed at create time

Procedure Creation CREATE PROC DDL Query optimization Code generation and compilation Procedure DLL produced Procedure DLL loaded

Durability and Availability Operations are logged in database transaction log Full durability is default Option to use delayed durability or non-durable tables New type of data files Append-only data and delta files Uses FILESTREAM under the covers Integrated backup/restore New memory-optimized filegroup part of database backup Supported: full, differential, and log backup Failover clustering supported Note: failover requires database recovery, which loads tables in memory AlwaysOn supported Sync and async secondaries Readable secondaries

Limitations in SQL Server 2014 Tables Triggers: no DDL/DML triggers Data types: no LOBs, no XML and no CLR data types Constraints: no FOREIGN KEY and no CHECK constraints No schema changes (ALTER TABLE) – need to drop/recreate table No add/remove index – need to drop/recreate table Natively Compiled Stored Procedures No OUTER JOIN, no DISTINCT no OR, no subqueries, no CASE Limited built-in functions [core math, date/time, and string functions are supported]

Outline Motivating trends – hardware, software, apps In-memory OLTP architecture & integration into SQL Server Performance and customer results Review and References

Customer Experiences Customer Workload Results Edgenet – SaaS provider for retailers and product delivery for end consumers Provide real-time insight into product price/availability for retailers and end-consumers. Used by retailers in-stores and to end-consumers via search engines. 8x-11x in performance gains for ingestion of data Consolidated from multi-tenant, multi-server to single database/server. Removed application caching layer (additional latency) from client tier. Case Study BWin.party - Largest regulated online gaming site Running ASP.NET session state using SQL Server for repository     Critical to end-user performance and interaction with the site Increase 15,000 batch requests/sec per to over 250,000 in case study Lab testing achieved over 450,000 batch requests/sec Consolidate 18 SQL Servers -> 1. Case Study SBI Liquidity Market - Japanese foreign currency exchange trading platform. Includes high volume and low latency trading. Expecting 10x volume increase 2x throughput (get over 3x in testing) with goal to reduce latency from 4 seconds to 1 per business transaction. Case study

Early Customer Performance Gains Apps that take full advantage: e.g. web app session state Apps with periodic bulk updates & heavy random reads Existing apps typically see 4-7x improvement Despite 20 years of optimizing for OLTP benchmarks – we still get 2x on a workload derived from TPC-C

Micro-benchmark: lookups Transaction size in #lookups CPU cycles (in millions) Speedup Regular Memory-Opt   1 0.73 0.040 10.8x 10 0.93 0.051 18.4x 100 2.72 0.150 18.1x 1,000 20.10 1.063 18.9x 10,000 201.00 9.850 20.4x Random lookups in a table with 10M rows All data in memory for “regular” and “memory optimized” Intel Xeon W3520 2.67 GHz Performance: 2.7M lookups/sec/core

Micro-benchmark: updates Transaction size in #updates CPU cycles (in millions) Speedup Regular Memory-Opt 1 0.91 0.045 20.2x 10 1.38 0.059 23.4x 100 8.17 0.260 31.4x 1,000 41.90 1.500 27.9x 10,000 439.00 14.400 30.5x Random updates, 10M rows, one index, snapshot isolation Log IO disabled (disk became bottleneck) Intel Xeon W3520 2.67 GHz Performance: 1.9M updates/sec/core

In-Memory OLTP Demo Jos de Bruijn

Outline Motivating trends – hardware, software, apps In-memory OLTP architecture & integration into SQL Server Performance and customer results Review and References

Towards Seamless Integration in SQL 2014 SQL Server RDBMS Column-Store Engine for DW Disk-based, row-store engine Memory-optimized OLTP engine Available only in one engine Batch Query Operators Blobs Native-Compiled Procedures Work across two engines with limitations Range + Column secondary indexes Readable Secondaries This slide is not comprehensive. The ovals show only representative examples. Work across all engines but with limitations Transactions, Queries, Stored Procedures AlwaysOn, Backup/Restore, Security, Admin, Deployment Nearly seamless across all engines Not comprehensive - only representative examples.

Key Take Aways Database systems need deep architectural changes To meet latency & throughput expectations To take advantage of hardware trends SQL 2014’s in-memory OLTP architecture is aligned with these trends As is In-memory data warehouse (columnstores) Applications can incrementally take advantage of in-memory OLTP capabilities AMR tool guides adoption Memory-optimized tables Native-compiled stored procedures Typical performance gains range from 2-25x

Related Content Online SIGMOD 2013 paper David DeWitt’s SQL PASS 2013 keynote: Video (starts 26 minutes from beginning), Slides Microsoft Virtual Academy talks In-Memory OLTP Common Workloads and Migration Considerations In-Memory OLTP Internals Overview In-Memory OLTP Sample Database and Workload (based on AdventureWorks) http://msdn.microsoft.com/en-us/library/dn511655(v=sql.120).aspx In-Memory OLTP Blog Series Books Online: In-Memory OLTP

7/1/2019 © 2014 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION. © 2014 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.