One of the Monday tutorials at Oracle Open World was MySQL Operations in Docker. A 2 hour tutorial by Giuseppe Maxia . This tutorial showed what you can do with MySQL on Docker which is specifically good for testing. Some key points from the tutorial included:
- Differences between containers and Virtual Machines (VM)
- VM are mutable architecture, you start then modify
- containers are an immutable architecture
- Containers are not micro-services
- Understanding about the “official” MySQL docker image. (Hint: Use mysql/mysql-server, not mysql)
- The issues of specifying a required password to install MySQL on a container
- Understanding how to use volumes, for a file (e.g. /etc/my.cnf), or a directory (e.g. /var/lib/mysql)
- How to produce a more secure MySQL installation using files
- How to get MySQL 5.0,5.1,5.5,5.6,5.7 and 8.0 on #CentOS, #Ubuntu and #debian for #docker using his own minimal MySQL docker images. (NOTE: MySQL images by Oracle, Percona and MariaDB are only the current version)
-
MySQL Group replication demo (mysql/mysql-gr)
In summary, Giuseppe talked about how wonderful Docker is for development and testing but not advisable for production. Some of the questions regarding production concerns included the inability working with orchestrators, stability with volumes and overall container user security. In addition, a tough audience question “How do you upgrade MySQL in production using containers?” highlighted that this technology is evolving, and while becoming ideal for stateless applications, it is not ready for primetime for databases that require state to operate.
Get the Code Examples on GitHub .
Docker has become a popular technology for containers starting in 2013. It did not invent containers, A Brief History of Container Technology gives a timeline of technologies that have got us to where we are today.
-
- How to get MySQL 5.0,5.1,5.5,5.6,5.7 and 8.0 on #CentOS, #Ubuntu and #debian for #docker using his own minimal MySQL docker images. (NOTE: MySQL images by Oracle, Percona and MariaDB are only the current version)
- How to produce a more secure MySQL installation using files
- Understanding how to use volumes, for a file (e.g. /etc/my.cnf), or a directory (e.g. /var/lib/mysql)
- The issues of specifying a required password to install MySQL on a container
- VM are mutable architecture, you start then modify