How to configure multiple mysql instance in Ubuntu
In this tutorial we will learn,how to configure multiple mysql instance in Ubuntu.Here multiple mysql instance means we can run multiple mysql server in single machine.We expect you have already install mysql-server in your system(if not then run the command apt-get install mysql-server).

To configure multiple mysql instance in Ubuntu,follow the given below steps

Login as a root or superuser(See given below command)

sudo su -

or 

su -

Step 1: Create a new mysql configuration directory for new mysql instance

cp -prvf /etc/mysql/ /etc/mysql2

Step 2: Create new data directory for new instance and give permission and ownership to new directory.

mkdir -p /var/lib/mysql2
chown --reference /var/lib/mysql /var/lib/mysql2
chmod --reference /var/lib/mysql /var/lib/mysql2

Step 3: Create new log directory for new instance

mkdir -p /var/log/mysql2
chown --reference /var/log/mysql /var/log/mysql2
chmod --reference /var/log/mysql /var/log/mysql2

Step 4: Now edit the /etc/mysql2/my.cnf file as given below.
Note: Here we are changing the port no. to 3337.
Either You can paste this configuration after making blank /etc/mysql2/my.cnf file

vi /etc/mysql2/my.cnf

[client]
port		= 3337
socket		= /var/run/mysqld/mysqld2.sock
[mysqld_safe]
socket		= /var/run/mysqld/mysqld2.sock
nice		= 0
[mysqld]
user		= mysql
pid-file	= /var/run/mysqld/mysqld2.pid
socket		= /var/run/mysqld/mysqld2.sock
port		= 3337
basedir		= /usr
datadir		= /var/lib/mysql2
tmpdir		= /tmp
lc-messages-dir	= /usr/share/mysql
skip-external-locking
bind-address		= 127.0.0.1
key_buffer		= 16M
max_allowed_packet	= 16M
thread_stack		= 192K
thread_cache_size       = 8
myisam-recover         = BACKUP
query_cache_limit	= 1M
query_cache_size        = 16M
log_error = /var/log/mysql2/error.log
expire_logs_days	= 10
max_binlog_size         = 100M
[mysqldump]
quick
quote-names
max_allowed_packet	= 16M
[mysql]
[isamchk]
key_buffer		= 16M
!includedir /etc/mysql2/conf.d/

Step 5: Now edit /etc/mysql2/debian.cnf file. You have to only change the value of socket paramter in two section.Apart of it there is no changes in /etc/mysql2/debian.cnf file.


In section [client]

socket   = /var/run/mysqld/mysqld2.sock

In section [mysql_upgrade]

socket   = /var/run/mysqld/mysqld2.sock

Below given is reference of my debian.conf file.It is just an example.

[client]
host = localhost
user = debian-sys-maint
password = s5ozLSHeoO4cRaDi
socket = /var/run/mysqld/mysqld2.sock
[mysql_upgrade]
host = localhost
user = debian-sys-maint
password = s5ozLSHeoO4cRaDi
socket = /var/run/mysqld/mysqld2.sock
basedir = /usr

Step 6: Now edit the apparmor file for mysql. This is important step. Paste the given below configuration in /etc/apparmor.d/usr.sbin.mysqld file

Using vi editor for editing

vi /etc/apparmor.d/usr.sbin.mysqld

Paste the given below code in /etc/apparmor.d/usr.sbin.mysqld

### secondary a.k.a mysql2 ####

  /etc/mysql2/*.pem r,
  /etc/mysql2/conf.d/ r,
  /etc/mysql2/conf.d/* r,
  /etc/mysql2/*.cnf r,
  /var/lib/mysql2/ r,
  /var/lib/mysql2/** rwk,
  /var/log/mysql2/ r,
  /var/log/mysql2/* rw,
  /{,var/}run/mysqld/mysqld2.pid w,
  /{,var/}run/mysqld/mysqld2.sock w,

########################

Given below is reference of my apparmor.d mysql file. Check your apparmor’s mysql file with the given below reference.This step is very important.If there is any mistake the mysql instance will not run and you can see the error in /var/log/syslog file

root@ubuntu:~# cat /etc/apparmor.d/usr.sbin.mysqld # vim:syntax=apparmor # Last Modified: Tue Jun 19 17:37:30 2007 #include /usr/sbin/mysqld { #include #include #include #include #include capability dac_override, capability sys_resource, capability setgid, capability setuid, network tcp, /etc/hosts.allow r, /etc/hosts.deny r, /etc/mysql/*.pem r, /etc/mysql/conf.d/ r, /etc/mysql/conf.d/* r, /etc/mysql/*.cnf r, /usr/lib/mysql/plugin/ r, /usr/lib/mysql/plugin/*.so* mr, /usr/sbin/mysqld mr, /usr/share/mysql/** r, /var/log/mysql.log rw, /var/log/mysql.err rw, /var/lib/mysql/ r, /var/lib/mysql/** rwk, /var/log/mysql/ r, /var/log/mysql/* rw, /var/run/mysqld/mysqld.pid rw, /var/run/mysqld/mysqld.sock w, /run/mysqld/mysqld.pid rw, /run/mysqld/mysqld.sock w, ### Pasted this content –### secondary aka mysql2 ## /etc/mysql2/*.pem r, /etc/mysql2/conf.d/ r, /etc/mysql2/conf.d/* r, /etc/mysql2/*.cnf r, /var/lib/mysql2/ r, /var/lib/mysql2/** rwk, /var/log/mysql2/ r, /var/log/mysql2/* rw, /{,var/}run/mysqld/mysqld2.pid w, /{,var/}run/mysqld/mysqld2.sock w, #################### End of configuration for mysql2 ###################### /sys/devices/system/cpu/ r, # Site-specific additions and overrides. See local/README for details. #include }

Step 7: Now restart the apparmor service

/etc/init.d/apparmor restart

Step 8: Now initiate new databases in new mysql data directory

mysql_install_db --user=mysql --datadir=/var/lib/mysql2

Before going to next step, see the given below output come when I first run the above command. We can see two WARNINGS hence we will solve this warning also for new instance as per the output.
First have a look on output

root@ubuntu:~# mysql_install_db --user=mysql --datadir=/var/lib/mysql2
Installing MySQL system tables...
131204 21:07:39 [Warning] Using unique option prefix key_buffer instead of key_buffer_size is deprecated and will be removed in a future release. Please use the full name instead.
OK
Filling help tables...
131204 21:07:39 [Warning] Using unique option prefix key_buffer instead of key_buffer_size is deprecated and will be removed in a future release. Please use the full name instead.
OK

To start mysqld at boot time you have to copy
support-files/mysql.server to the right place for your system

PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !
To do so, start the server, then issue the following commands:

/usr/bin/mysqladmin -u root password 'new-password'
/usr/bin/mysqladmin -u root -h ubuntu password 'new-password'

Alternatively you can run:
/usr/bin/mysql_secure_installation

which will also give you the option of removing the test
databases and anonymous user created by default.  This is
strongly recommended for production servers.

See the manual for more instructions.

You can start the MySQL daemon with:
cd /usr ; /usr/bin/mysqld_safe &

You can test the MySQL daemon with mysql-test-run.pl
cd /usr/mysql-test ; perl mysql-test-run.pl

Please report any problems with the /usr/scripts/mysqlbug script!

root@ubuntu:~# 

Step 9: You can observe two warnings here.Hence we will solve this warning first.

sed -i 's/key_buffer/key_buffer_size/' /etc/mysql2/my.cnf

As per warning,hence we changed the key_buffer to key_buffer_size in /etc/mysql2/my.cnf

131204 21:07:39 [Warning] Using unique option prefix key_buffer instead of key_buffer_size is deprecated and will be removed in a future release. Please use the full name instead.
OK
Filling help tables…
131204 21:07:39 [Warning] Using unique option prefix key_buffer instead of key_buffer_size is deprecated and will be removed in a future release. Please use the full name instead.
OK

Step 10: Now all are set, we will start the new mysql instance by given below command.

To start the new mysql instance


nohup mysqld_safe --defaults-file=/etc/mysql2/my.cnf &

Press two time enter.

You can check the port for new mysql instance is listening or not.You can see in port no. 3337 mysql is listening

netstat -tanp|grep mysql

Here is my system reference

root@ubuntu:~# netstat -tanp|grep mysql
tcp        0      0 127.0.0.1:3337          0.0.0.0:*               LISTEN      4257/mysqld     
tcp        0      0 127.0.0.1:3306          0.0.0.0:*               LISTEN      3151/mysqld     
root@ubuntu:~#

Step 11: Now connecting to new mysql instance.
Here,
-u = user
-P = port no. (In our case we are using 3337,check the mysql2/my.cnf file for reference)
-h = host

mysql -u root -P 3337 -h 127.0.0.1

Step 12: It is new data structure hence there is no password for mysql user roor. Now you can see the mysql prompt like this mysql >
We will now reset the root password because of security reason. Replace NEW-PASSWORD with your password

mysql > update mysql.user set password=PASSWORD("NEW-PASSWORD") where User='root';
mysql > flush privileges;
mysql > exit

Step 13: You already now in above steps how to start the mysql instance. Now we will use the command to stop the new mysql instance.

Here,
-p = password
-S = Path of MySQL socket file

To stop the new mysql instance

mysqladmin -S /var/lib/mysql/mysql2.sock shutdown -p

Because you have already set root password, give that password here.

With the same method you can create other MySQL instances in same server but only you have to replace the mysql2 to mysql3 or mysql4 or so on …. mysqlN

Read Some More Articles

18 Comments

  1. I follow your step until step 5 but my connection dropped in the middle execution can we restore it to previous state? because mysql instance error with this eror

    Feb 16 09:46:23 simpeg1 systemd[1]: Stopped MySQL Community Server.
    Feb 16 09:46:23 simpeg1 systemd[1]: Starting MySQL Community Server…
    Feb 16 09:46:23 simpeg1 mysql-systemd-start[11116]: my_print_defaults: Can’t read dir of ‘/etc/mysql2/conf.d/’ (Errcode: 2 – No such file or directory)
    Feb 16 09:46:23 simpeg1 mysql-systemd-start[11116]: my_print_defaults: [ERROR] Fatal error in defaults handling. Program aborted!
    Feb 16 09:46:23 simpeg1 systemd[1]: mysql.service: Main process exited, code=exited, status=1/FAILURE
    Feb 16 09:46:47 simpeg1 systemd[1]: Stopped MySQL Community Server.
    Feb 16 09:46:47 simpeg1 systemd[1]: mysql.service: Unit entered failed state.
    Feb 16 09:46:47 simpeg1 systemd[1]: mysql.service: Failed with result ‘exit-code’.
    Feb 16 09:47:13 simpeg1 systemd[1]: Stopped MySQL Community Server.

    it seems its read as its config etc/mysql2/conf.d/’

    please urgent

    1. Hi Daniel,

      In error find this line – “my_print_defaults: Can’t read dir of ‘/etc/mysql2/conf.d/’ (Errcode: 2 – No such file or directory)”.
      Seems either directory /etc/mysql2/conf.d/ not present or may have permission issue. Check your main my.cnf file and read its config .

      Regards
      Sharad

  2. mysql_install_db –user=mysql –datadir=/var/lib/mysql2

    I am getting below error in the above step

    170803 15:30:40 [Warning] Can’t create test file /var/lib/mysql2/sowmya-Latitude-E7440.lower-test
    170803 15:30:40 [Warning] Can’t create test file /var/lib/mysql2/sowmya-Latitude-E7440.lower-test

    Installation of system tables failed! Examine the logs in
    /var/lib/mysql2 for more information.

    You can try to start the mysqld daemon with:

    shell> /usr/sbin/mysqld –skip-grant &

    and use the command line tool /usr/bin/mysql
    to connect to the mysql database and look at the grant tables:

    shell> /usr/bin/mysql -u root mysql
    mysql> show tables

    Try ‘mysqld –help’ if you have problems with paths. Using –log
    gives you a log in /var/lib/mysql2 that may be helpful.

    Please consult the MySQL manual section
    ‘Problems running mysql_install_db’, and the manual section that
    describes problems on your OS. Another information source are the
    MySQL email archives available at http://lists.mysql.com/.

    Please check all of the above before submitting a bug report
    at http://bugs.mysql.com/

    Anyone please advise

  3. Hello,

    Thank you very much for your tutorial!

    I stopped on the step 10: nohup mysqld_safe –defaults-file=/etc/mysql2/my.cnf &
    Everything is OK, but when I run this command the instance from mysql don´t start…

    Any ideia?
    Im using a ubuntu;

    thanks!

    1. Hi, I am facing same issue. The server is not starting and getting below message. May I know what you fixed?

      root@ip-172-31-60-135:/var/lib/mysqldev# nohup mysqld_safe –defaults-file=/etc/mysqldev/my.cnf &
      [1] 3796
      root@ip-172-31-60-135:/var/lib/mysqldev# nohup: ignoring input and appending output to ‘nohup.out’

  4. hi, i started new instance of mysql successufully after following your steps . But how to stop this instance? i tried some ways as kill command, mysqladmin to shutdown the instance but not succeed. please help me :(. Thanks

      1. Hello Thai,

        Check the correct socket you are using in mysqladmin command.
        I hope you are not running mysql with monit or any mysql entry in /etc/inittab file.

        Regards
        Sharad

  5. Hi, Please add a detail easy to use post on creating multiple mongodb instances on CentOS/RHEL/Fedora and Ubuntu/Debian/Mint

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.