Chapter 6 Installing MySQL on OS X

Table of Contents

6.1 General Notes on Installing MySQL on OS X
6.2 Installing MySQL on OS X Using Native Packages
6.3 Installing a MySQL Launch Daemon
6.4 Installing the MySQL Startup Item
6.5 Installing and Using the MySQL Preference Pane
6.6 Using the Bundled MySQL on OS X Server

For a list of OS X versions that the MySQL server supports, see http://www.mysql.com/support/supportedplatforms/database.html.

MySQL for OS X is available in a number of different forms:

For additional information on using MySQL on OS X, see Section 6.1, “General Notes on Installing MySQL on OS X”.

6.1 General Notes on Installing MySQL on OS X

You should keep the following issues and notes in mind:

  • OS X 10.4 deprecated startup items in favor of launchd daemons, and as of OS X 10.10 (Yosemite), startup items do not function. For these reasons, using launchd daemons is preferred over startup items.

  • The default location for the MySQL Unix socket is different on OS X and OS X Server depending on the installation type you chose. The following table shows the default locations by installation type.

    Table 6.1 MySQL Unix Socket Locations on OS X by Installation Type

    Installation TypeSocket Location
    Package Installer from MySQL/tmp/mysql.sock
    Tarball from MySQL/tmp/mysql.sock
    MySQL Bundled with OS X Server/var/mysql/mysql.sock

    To prevent issues, you should either change the configuration of the socket used within your application (for example, changing php.ini), or you should configure the socket location using a MySQL configuration file and the socket option. For more information, see Server Command Options.

  • You may need (or want) to create a specific mysql user to own the MySQL directory and data. You can do this through the Directory Utility, and the mysql user should already exist. For use in single user mode, an entry for _mysql (note the underscore prefix) should already exist within the system /etc/passwd file.

  • If you get an insecure startup item disabled error when MySQL launches, use the following procedure. Adjust the pathnames appropriately for your system.

    1. Modify the mysql.script using this command (enter it on a single line):

      shell> sudo /Applications/TextEdit.app/Contents/MacOS/TextEdit
        /usr/local/mysql/support-files/mysql.server
      
    2. Locate the option file that defines the basedir value and modify it to contain these lines:

      basedir=/usr/local/mysql
      datadir=/usr/local/mysql/data
      

      In the /Library/StartupItems/MySQLCOM/ directory, make the following group ID changes from staff to wheel:

      shell> sudo chgrp wheel MySQLCOM StartupParameters.plist
      
    3. Start the server from System Preferences or Terminal.app.

  • Because the MySQL package installer installs the MySQL contents into a version and platform specific directory, you can use this to upgrade and migrate your database between versions. You will need to either copy the data directory from the old version to the new version, or alternatively specify an alternative datadir value to set location of the data directory.

  • You might want to add aliases to your shell's resource file to make it easier to access commonly used programs such as mysql and mysqladmin from the command line. The syntax for bash is:

    alias mysql=/usr/local/mysql/bin/mysql
    alias mysqladmin=/usr/local/mysql/bin/mysqladmin
    

    For tcsh, use:

    alias mysql /usr/local/mysql/bin/mysql
    alias mysqladmin /usr/local/mysql/bin/mysqladmin
    

    Even better, add /usr/local/mysql/bin to your PATH environment variable. You can do this by modifying the appropriate startup file for your shell. For more information, see Invoking MySQL Programs.

  • After you have copied over the MySQL database files from the previous installation and have successfully started the new server, you should consider removing the old installation files to save disk space. Additionally, you should also remove older versions of the Package Receipt directories located in /Library/Receipts/mysql-VERSION.pkg.

6.2 Installing MySQL on OS X Using Native Packages

The package is located inside a disk image (.dmg) file that you first need to mount by double-clicking its icon in the Finder. It should then mount the image and display its contents.

Note

Before proceeding with the installation, be sure to stop all running MySQL server instances by using either the MySQL Manager Application (on OS X Server) or mysqladmin shutdown on the command line.

When installing from the package version, you should also install the MySQL Preference Pane, which will enable you to control the startup and execution of your MySQL server from System Preferences. For more information, see Section 6.5, “Installing and Using the MySQL Preference Pane”.

When installing using the package installer, the files are installed into a directory within /usr/local matching the name of the installation version and platform. For example, the installer file mysql-5.1-osx10.6-x86_64.dmg installs MySQL into /usr/local/mysql-5.1-osx10.6-x86_64/ . The following table shows the layout of the installation directory.

Table 6.2 MySQL Installation Layout on OS X

DirectoryContents of Directory
bin, scriptsmysqld server, client and utility programs
dataLog files, databases
docsHelper documents, like the Release Notes and build information
includeInclude (header) files
libLibraries
manUnix manual pages
mysql-testMySQL test suite
shareMiscellaneous support files, including error messages, sample configuration files, SQL for database installation
sql-benchBenchmarks
support-filesScripts and sample configuration files
/tmp/mysql.sockLocation of the MySQL Unix socket

During the package installer process, a symbolic link from /usr/local/mysql to the version/platform specific directory created during installation will be created automatically.

  1. Download and open the MySQL package installer, which is provided on a disk image (.dmg) that includes the main MySQL installation package, the MySQLStartupItem.pkg installation package, and the MySQL.prefPane. Double-click the disk image to open it.

    Figure 6.1 MySQL Package Installer: DMG Contents

    MySQL Package Installer: DMG Contents

  2. Double-click the MySQL installer package. It will be named according to the version of MySQL you have downloaded. For example, if you have downloaded MySQL server 5.1.73, double-click mysql-5.1.73-osx-10.6-x86_64.pkg.

  3. You will be presented with the opening installer dialog. Click Continue to begin installation.

    Figure 6.2 MySQL Package Installer: Introduction

    MySQL Package Installer: Introduction

  4. A copy of the installation instructions and other important information relevant to this installation are displayed. Click Continue .

  5. If you have downloaded the community version of MySQL, you will be shown a copy of the relevant GNU General Public License. Click Continue .

  6. Select the drive you want to use to install the MySQL Startup Item. The drive must have a valid, bootable, OS X operating system installed. Click Continue.

    Figure 6.3 MySQL Package Installer: Choose your Hard drive

    MySQL Package Installer: Choose your Hard drive

  7. You will be asked to confirm the details of the installation, including the space required for the installation. To change the drive on which the MySQL server is installed, click either Go Back or Change Install Location.... To install the MySQL server, click Install.

  8. Once the installation has been completed successfully, you will be shown an Install Succeeded message.

For convenience, you may also want to install the startup item and preference pane. See Section 6.4, “Installing the MySQL Startup Item”, and Section 6.5, “Installing and Using the MySQL Preference Pane”.

6.3 Installing a MySQL Launch Daemon

OS X uses launch daemons to automatically start, stop, and manage processes and applications such as MySQL. Using launch daemons is recommended over startup items on OS X.

Note

OS X 10.4 deprecated startup items in favor of launchd daemons, and as of OS X 10.10 (Yosemite), startup items do not function. For these reasons, using launchd daemons is preferred over startup items.

Here is an example launchd file that starts MySQL:


<?xml version="1.0" encoding="UTF-8"?>
<plist version="1.0">
  <dict>
    <key>KeepAlive</key>
    <true/>
    <key>Label</key>
    <string>com.mysql.mysqld</string>
    <key>ProgramArguments</key>
    <array>
    <string>/usr/local/mysql/bin/mysqld_safe</string>
    <string>--user=mysql</string>
    </array>
  </dict>
</plist>

Note

Some users report that adding a plist DOCTYPE declaration causes the launchd operation to fail, despite it passing the lint check. For this reason, we have removed it from the example above.

Adjust the ProgramArguments array according to your system, as for example your path to mysqld_safe might be different. After making the proper adjustments, do the following:

  • Save the XML as a file named /Library/LaunchDaemons/com.mysql.mysql.plist

  • Adjust the file permissions using the Apple recommended owner "root", owning group "wheel", and file permissions "644"

    shell> sudo chown root:wheel /Library/LaunchDaemons/com.mysql.mysql.plist
    shell> sudo chmod 644 /Library/LaunchDaemons/com.mysql.mysql.plist
    
  • Enable this new MySQL service

    shell> sudo launchctl load -w /Library/LaunchDaemons/com.mysql.mysql.plist
    

The MySQL daemon is now running, and automatically starts when your system is rebooted.

6.4 Installing the MySQL Startup Item

The MySQL Installation Package includes a startup item that can be used to automatically start and stop MySQL.

Important

Startup items are deprecated in favor of launchd daemons. For additional information, see Section 6.3, “Installing a MySQL Launch Daemon”.

To install the MySQL Startup Item:

  1. Download and open the MySQL package installer, which is provided on a disk image (.dmg) that includes the main MySQL installation package, the MySQLStartupItem.pkg installation package, and the MySQL.prefPane. Double-click the disk image to open it.

    Figure 6.4 MySQL Package Installer: DMG Contents

    MySQL Package Installer: DMG Contents

  2. Double-click the MySQLStartItem.pkg file to start the installation process.

  3. You will be presented with the Install MySQL Startup Item dialog.

    Figure 6.5 MySQL Startup Item Installer: Introduction

    MySQL Startup Item Installer: Introduction

    Click Continue to continue the installation process.

  4. A copy of the installation instructions and other important information relevant to this installation are displayed. Click Continue .

  5. Select the drive you want to use to install the MySQL Startup Item. The drive must have a valid, bootable, OS X operating system installed. Click Continue.

    Figure 6.6 MySQL Startup Item Installer: Choose Your Hard drive

    MySQL Startup Item Installer: Choose Your Hard drive

  6. You will be asked to confirm the details of the installation. To change the drive on which the startup item is installed, click either Go Back or Change Install Location.... To install the startup item, click Install.

  7. Once the installation has been completed successfully, you will be shown an Install Succeeded message.

    Figure 6.7 MySQL Startup Item Installer: Summary

    MySQL Startup Item Installer: Summary

The Startup Item for MySQL is installed into /Library/StartupItems/MySQLCOM. The Startup Item installation adds a variable MYSQLCOM=-YES- to the system configuration file /etc/hostconfig. If you want to disable the automatic startup of MySQL, change this variable to MYSQLCOM=-NO-.

Note

Deselecting Automatically Start MySQL Server on Startup from the MySQL Preference Pane sets the MYSQLCOM variable to -NO-.

After the installation, you can start and stop the MySQL server from the MySQL Preference Pane (preferred), or by running the following commands in a terminal window. You must have administrator privileges to perform these tasks, and you may be prompted for your password.

If you have installed the Startup Item, use this command to start the server:

shell> sudo /Library/StartupItems/MySQLCOM/MySQLCOM start

If you have installed the Startup Item, use this command to stop the server:

shell> sudo /Library/StartupItems/MySQLCOM/MySQLCOM stop

6.5 Installing and Using the MySQL Preference Pane

The MySQL Package installer disk image also includes a custom MySQL Preference Pane that enables you to start, stop, and control automated startup during boot of your MySQL installation.

To install the MySQL Preference Pane:

  1. Download and open the MySQL package installer package, which is provided on a disk image (.dmg) that includes the main MySQL installation package, the MySQLStartupItem.pkg installation package, and the MySQL.prefPane. Double-click the disk image to open it.

    Figure 6.8 MySQL Package Installer: DMG Contents

    MySQL Package Installer: DMG Contents

  2. Double-click the MySQL.prefPane. The MySQL System Preferences will open.

  3. If this is the first time you have installed the preference pane, you will be asked to confirm installation and whether you want to install the preference pane for all users, or only the current user. To install the preference pane for all users you will need administrator privileges. If necessary, you will be prompted for the username and password for a user with administrator privileges.

  4. If you already have the MySQL Preference Pane installed, you will be asked to confirm whether you want to overwrite the existing MySQL Preference Pane.

Note

The MySQL Preference Pane only starts and stops MySQL installation installed from the MySQL package installation that have been installed in the default location.

Once the MySQL Preference Pane has been installed, you can control your MySQL server instance using the preference pane. To use the preference pane, open the System Preferences... from the Apple menu. Select the MySQL preference pane by clicking the MySQL logo within the Other section of the preference panes list.

Figure 6.9 MySQL Preference Pane: Location

MySQL Preference Pane: Location

The MySQL Preference Pane shows the current status of the MySQL server, showing stopped (in red) if the server is not running and running (in green) if the server has already been started. The preference pane also shows the current setting for whether the MySQL server has been set to start automatically.

  • To start the MySQL server using the preference pane:

    Click Start MySQL Server. You may be prompted for the username and password of a user with administrator privileges to start the MySQL server.

  • To stop the MySQL server using the preference pane:

    Click Stop MySQL Server. You may be prompted for the username and password of a user with administrator privileges to stop the MySQL server.

  • To automatically start the MySQL server when the system boots:

    Check the check box next to Automatically Start MySQL Server on Startup.

  • To disable automatic MySQL server startup when the system boots:

    Uncheck the check box next to Automatically Start MySQL Server on Startup.

You can close the System Preferences... window once you have completed your settings.

6.6 Using the Bundled MySQL on OS X Server

If you are running OS X Server, a version of MySQL should already be installed. The following table shows the versions of MySQL that ship with OS X Server versions.

Table 6.3 MySQL Versions Preinstalled with OS X Server

OS X Server VersionMySQL Version
10.2-10.2.23.23.51
10.2.3-10.2.63.23.53
10.34.0.14
10.3.24.0.16
10.4.04.1.10a
10.5.05.0.45
10.6.05.0.82

The following table shows the installation layout of MySQL on OS X Server.

Table 6.4 MySQL Directory Layout for Preinstalled MySQL Installations on OS X Server

DirectoryContents of Directory
/usr/binClient programs
/var/mysqlLog files, databases
/usr/libexecThe mysqld server
/usr/share/manUnix manual pages
/usr/share/mysql/mysql-testMySQL test suite
/usr/share/mysqlMiscellaneous support files, including error messages, character set files, sample configuration files, SQL for database installation
/var/mysql/mysql.sockLocation of the MySQL Unix socket

Additional Resources