the latest with mysql on openstack trove

28
Doug Shelley, Tesora Matt Lord, Oracle The Latest with MySQL on OpenStack Trove #TroveDay2015

Upload: tesora

Post on 20-Mar-2017

501 views

Category:

Software


0 download

TRANSCRIPT

Page 1: The latest with MySql on OpenStack Trove

Doug Shelley, TesoraMatt Lord, Oracle

The Latest with MySQL on OpenStack Trove

#TroveDay2015

Page 2: The latest with MySql on OpenStack Trove

Community Trove plus: Certified guest images for many databases Regularly tested against popular OpenStack

distros Enterprise features such as Oracle 11g & 12c

support Easy installation and configuration

So what’s new?Let’s focus on our MySQL support

Tesora DBaaS Platform

August 25, 2015 What's New With MySQL

Page 3: The latest with MySql on OpenStack Trove

Since last Trove day: Replication v1

“binlog” based, asynchronous Create a slave from master Detach a slave

Replication v2 GTID based for MySQL 5.6 Start multiple slaves simultaneously Initialize from incremental backup Failover capabilities – promote and eject

What’s new?

August 25, 2015 What's New With MySQL

Page 4: The latest with MySql on OpenStack Trove

Guest log retrieval Initial implementation is for MySQL Includes error, general, slow query and guest-

agent logs “Publishing” of logs can be enabled or disabled

(“log-publish”) Individual logs can be streamed (“log-tail”) or

downloaded (“log-save”)

Let’s look at these features in action!

What’s new?

August 25, 2015 What's New With MySQL

Page 5: The latest with MySql on OpenStack Trove

Safe Harbor StatementThe following is intended to outline our generalproduct direction. It is intended for informationpurposes only, and may not be incorporated intoany contract. It is not a commitment to deliver anymaterial, code, or functionality, and should not berelied upon in making purchasing decisions. Thedevelopment, release, and timing of any featuresor functionality described for Oracle’s productsremains at the sole discretion of OracleCorporation

August 25, 2015 What's New With MySQL

Page 6: The latest with MySql on OpenStack Trove

MySQL 5.7 Release Candidate!

Enhanced InnoDB: faster online & bulk load operations

Replication Improvements (incl. multi-source, multi-threaded

slaves...)

New Optimizer Cost Model: greater user control & better query

performance

Performance Schema Improvements

MySQL SYS Schema

Performance & Scalability Manageability

2 X Faster than MySQL 5.6

Improved Security: safer initialization, setup & management

NEW! JSON Support

And many more new features and enhancements... http://mysqlserverteam.com/the-mysql-5-7-8-release-candidate-is-available/

August 25, 2015 What's New With MySQL

Page 7: The latest with MySql on OpenStack Trove

8 16 32 64 128 256 512 1,0240

100,000200,000300,000400,000500,000600,000700,000

MySQL 5.7: Sysbench Read Only (Point Select)

MySQL 5.7

MySQL 5.6

MySQL 5.5

Connections

Quer

ies

per S

econ

d

MySQL 5.7: Sysbench: Read Only

Intel(R) Xeon(R) CPU E7-4860 x86_644 sockets x 10 cores-HT (80 CPU threads)2.3 GHz, 512 GB RAMOracle Linux 6.5

2x Faster than MySQL 5.63x Faster than MySQL 5.5

645,000 QPS

August 25, 2015 What's New With MySQL

Page 8: The latest with MySql on OpenStack Trove

1 Million QPS

MySQL 5.7: InnoDB, NoSQL With Memcached6x Faster than MySQL 5.6

8 16 32 64 128 256 512 1,0240

200,000

400,000

600,000

800,000

1,000,000

1,200,000MySQL 5.7 vs 5.6 - InnoDB &

MemcachedMySQL 5.7

MySQL 5.6

Connections

Quer

ies

per S

econ

d

Intel(R) Xeon(R) CPU E7-4860 x86_644 sockets x 10 cores-HT (80 CPU threads)2.3 GHz, 512 GB RAMOracle Linux 6.5

August 25, 2015 What's New With MySQL

Page 9: The latest with MySql on OpenStack Trove

MySQL 5.7: Connections/Second1.7x Faster than MySQL 5.62.5x Faster than MySQL 5.5

67,000 Connections/Sec

MySQL 5.5 MySQL 5.6 MySQL 5.70

10,00020,00030,00040,00050,00060,00070,00080,000

Connections Per Second

Connections

Conn

ectio

ns/S

econ

d

Intel(R) Xeon(R) CPU E7-4860 x86_644 sockets x 10 cores-HT (80 CPU threads)2.3 GHz, 512 GB RAMOracle Linux 6.5

August 25, 2015 What's New With MySQL

Page 10: The latest with MySql on OpenStack Trove

Optimizer and Parser refactoring Improves readability,

maintainability and stability Cleanly separate the parsing,

optimizing, and execution stages Allows for easier feature

additions, with lessened risk New hint framework

Easier to manage With support for additional new

hints Improved JSON EXPLAIN EXPLAIN for running thread

New Cost based Optimizer Generated Columns Support for InnoDB based

internal temp tables Better

ONLY_FULL_GROUP_BY mode

Better support for InnoDB & GIS

Many specific new optimizations

Queries execute faster, whi le using less CPU and

disk space!

MySQL 5.7: Optimizer Improvements

August 25, 2015 What's New With MySQL

Page 11: The latest with MySql on OpenStack Trove

New pre and post parse query rewrite APIs Users can write their own plug-ins

Provides a post-parse query plugin Rewrite problematic queries without the need to

make application changes Add hints Modify join order Many more …

Improve problematic queries from ORMs, third party apps, etc

Eliminates many legacy use cases for proxies

MySQL 5.7: Query Rewrite Plugin

August 25, 2015 What's New With MySQL

Page 12: The latest with MySql on OpenStack Trove

MySQL 5.7: Performance SchemaMemory

Instrumentation Aggregates

stat ist ics by Type of memory

used (caches, internal buffers, …)

Thread/account/user/host indirectly performing the memory operation

Attr ibutes include Memory used

(bytes) Operation counts High/Low Water

Marks

Statement Instrumentation

Stored Procedures

Stored Functions

Prepared Statements

Transactions

Addit ional Information

Repl icat ion slave status

MDL lock instrumentat ion

Status and var iables per thread

Server stage tracking

Track long running SQL

Improved configurat ion and ease-of-use

All whi le reducing total footpr int and overhead

August 25, 2015 What's New With MySQL

Page 13: The latest with MySql on OpenStack Trove

MySQL 5.7: SYS Schema

Helps simplify DBA / Ops tasks  Monitor server health, user, host

statistics Spot, diagnose, and tune

performance issues Easy to understand views with

insights into  IO hot spots, Locking, Costly SQL

statements  Schema, table and index statistics 

SYS is similar to Oracle V$ catalog views Microsoft SQL DMVs (Dynamic

Management Views)

Helper objects for DBAs, Developers and Operations staff

August 25, 2015 What's New With MySQL

Page 14: The latest with MySql on OpenStack Trove

Native JSON data type Native internal binary format for efficient processing &

storage Built-in JSON functions

Allowing you to efficiently store, search, update, and manipulate Documents

JSON Comparator Allows for easy integration of Document data within your

SQL queries Indexing of Documents using Generated Columns

InnoDB supports indexes on both stored and virtual Generated Columns

New expression analyzer automatically uses the best “functional” index available

MySQL 5.7: JSON

August 25, 2015 What's New With MySQL

Page 15: The latest with MySql on OpenStack Trove

Replaced custom code with Boost.Geometry For spatial calculations For spatial analysis Enabling full OGC compliance We’re also Boost.Geometry contributors!

InnoDB R-tree based spatial indexes Full ACID, MVCC, & transactional support Index records contain minimum bounding box

GeoHashGeoJSONHelper functions such as ST_Distance_Sphere() and ST_MakeEnvelope()

MySQL 5.7: GIS Improvements

August 25, 2015 What's New With MySQL

Page 16: The latest with MySql on OpenStack Trove

Native Partitioning Eliminates previous

limitations Eliminates resource usage

problems Transportable tablespace

support Native Ful l-Text Search

Including full CJK support! Native Spatial Indexes Transparent page

compression Support for 32K and 64K

pages Use with transparent page

compression for very high compression ratios

General TABLESPACE support Store multiple tables in user

defined shared tablespaces Support for MySQL Group

Replication High priority transactions

Improved support for cache preloading Load your hottest data

loaded at startup Configurable fil l-factor

Allows for improvements in storage footprint

Improved bulk-data load performance

August 25, 2015 What's New With MySQL

MySQL 5.7: InnoDB Improvements

Page 17: The latest with MySql on OpenStack Trove

AES 256 Encryption Default in MySQL 5.7

Password rotation policies Can be set globally, and at the user level

Deployment: enable secure unattended install by default Random password set on install Remove anonymous accounts Deployment without test account, schema, demo files

Easier instance initialization and setup mysqld --initialize

New detection and support for systemd

MySQL 5.7: Security

August 25, 2015 What's New With MySQL

Page 18: The latest with MySql on OpenStack Trove

SSL Enabled by default Auto-detection of existing keys and certs Auto generation of keys and certs when needed New helper utility: mysql_ssl_rsa_setup New --require_secure_transport option to

prevent insecure communications Added SSL support to binary log clients

MySQL 5.7: Security -- SSL

August 25, 2015 What's New With MySQL

Page 19: The latest with MySql on OpenStack Trove

MySQL 5.7: Server-side Statement TimeoutsServer side statement timeouts

Global for server, per session, or for individual SELECT statements

Expanded to Windows and Solaris, restricted by removing USER option

SELECT /*+ MAX_EXECUTION_TIME(1000) */ * FROM my_table;

August 25, 2015 What's New With MySQL

Page 20: The latest with MySql on OpenStack Trove

GTID enhancements On-line, phased deployment of

GTIDs Binary logging on slave now

optional Enhanced Semi-

synchronous repl icat ion Write guaranteed to be

received by slave before being observed by clients of the master

Option to wait on Acks from multiple slaves

Mult i -Source Repl icat ion Consolidate updates from

multiple Masters into one Slave

Dynamic slave filters

8-10x Faster slave throughput Often removes slave

as a bottleneck; keep pace with master with 8+ slave threads

Option to preserve Commit order

Automatic slave transaction retries

MySQL 5.7: Replication Improvements

August 25, 2015 What's New With MySQL

Page 21: The latest with MySql on OpenStack Trove

MySQL 5.7: Enabling GTIDs

Check Compatibili

ty• Server reports any incompatible operations

Generate GTIDs

• All servers generate GTIDs but don’t depend on them

Brief wait

• Allow all legacy events to work through all servers

GTIDs Enabled

• All Servers generate and expect GTIDs only

• Full benefits of GTIDs available

Phased, On-line Introduction

August 25, 2015 What's New With MySQL

Page 22: The latest with MySql on OpenStack Trove

Multi-Source Replication Consolidate updates from

multiple Masters into one Slave Consolidated view of all

shards More flexible topologies Centralized point for backups

Compatible with Semi-Sync Replication & enhanced MTS

Performance Schema tables for monitoring slave

Online Operations: Dynamic Replication Filters, switch master

MySQL 5.7: Replication Improvements

August 25, 2015 What's New With MySQL

Page 23: The latest with MySql on OpenStack Trove

Support for tracking session transaction state This offers better support for load balancing across

nodes Server Version Tokens

This offers better support for caching in distributed systems

New data migration tool : mysqlpump Improves data migration and sharding operations

between nodes Improved Replication options in HA groups

Improved slave performance with clock based parallelization

Loss-less Semi-Sync Replication plugin supporting multi-node acks

Synchronous replication (Group Replication plugin now in Labs)

MySQL 5.7: HA Improvements

August 25, 2015 What's New With MySQL

Page 24: The latest with MySql on OpenStack Trove

Mult i -master update anywhere Conflict detection and

resolution (transaction rollback) Optimistic State Machine

Replication Automatic group

membership management and fai lure detection No need for server fail-over Elastic scale out/in No single point of failure Automatic reconfiguration

Well integrated InnoDB GTID-based replication PERFORMANCE_SCHEMA

MySQL Group Replicationlabs.mysql.com

August 25, 2015 What's New With MySQL

Page 25: The latest with MySql on OpenStack Trove

HTTP Plugin for MySQLServer Plugin adds HTTP(S) endpoints to

MySQLResults are serialized to JSON format

encoded as UTF8Provides 3 choices of User Endpoint Types

SQL CRUD - Key-Value JSON - Document

labs.mysql.com

August 25, 2015 What's New With MySQL

Page 26: The latest with MySql on OpenStack Trove

MySQL Fabric 1.5

High Availabi l i ty Server monitoring with auto-

promotion and transparent application failover

Optionally scale-out through sharding Application provides shard key Range or Hash Tools for resharding Global updates & tables

Fabric-aware connectors rather than proxy: Python, Java, PHP, .NET, C (labs) Lower latency, bottleneck-free

Server provisioning using OpenStack etc.

High Availability + Sharding-Based Scale-out

August 25, 2015 What's New With MySQL

Page 27: The latest with MySql on OpenStack Trove

MySQL Repos

Distr ibut ions Oracle, Red Hat, CentOS Fedora Ubuntu, Debian SUSE

Official MySQL Docker Image from Oracle

Coming Soon Preconfigured Containers Improved support for popular

DevOps deployment tools

https://dev.mysql.com/downloads/repo

MySQL on GitHub

Git for MySQL Engineering Fast, flexible and great for a

distributed team Great tooling Large and vibrant community

GitHub for MySQL Community Easy and fast code

availability to the community and to downstream projects

New Pull Requests

https://github.com/mysql

August 25, 2015 What's New With MySQL

Page 28: The latest with MySql on OpenStack Trove

MySQL 5.7: Additional Info http://mysqlserverteam.com/the-mysql-5-7-8-

release-candidate-is-available/ http://mysqlserverteam.com/category/json/ http://mysqlserverteam.com/category/perfor

mance/optimizer/ http://mysqlserverteam.com/category/innodb

/ http://mysqlserverteam.com/category/mysql/

performance-schema/ http://mysqlserverteam.com/category/gis/ http://mysqlserverteam.com/category/full-tex

t-search/ http://mysqlserverteam.com/category/diction

ary/ https://dev.mysql.com/doc/relnotes/mysql/5.7

/en/ http://dev.mysql.com/doc/refman/5.7/en/

August 25, 2015 What's New With MySQL