Documentation for JIRA 4.0. Documentation for other versions of JIRA is available too.
These instructions will help you connect JIRA to a MySQL 5.1.x database.
Note: A Linux-specific version of these instructions is available.
On this page:
If you are already using JIRA, create an export of your data as an XML backup. You will then be able to transfer data from your old database to your new database, as described in Switching databases.
If you are using a MySQL database with any of the following:
you may experience problems with your connections dropping out (see http://jira.atlassian.com/browse/JRA-15731 for details). Please read Surviving Connection Closures for information on the changes required to your application server to address this.
jirauser
).jiradb
). The database must have a character set of UTF8. Enter the following command from within the MySQL command client:
create database jiradb character set utf8;
jiradb
にした場合)。
A user has reported encountering problems using the Resin JDBC driver for MySQL. However, the Connector/J driver from MySQL works correctly
mysql-connector-java-5.x.x-bin.jar
) to the common/lib/
directory.conf/server.xml
(if you are using JIRA Standalone) and customise the username
, password
, driverClassName
and url
parameters for the Datasource. (If you are using JIRA WAR/EAR, edit the appropriate file on your application server; e.g. for Tomcat, edit conf/Catalina/localhost/jira.xml
).
The URL in the XML below assumes a UTF-8 database — i.e. created with create database jiradb character set utf8;
. If you don't specify character set utf8
you risk getting 'Data truncation: Data too long for column
' errors when importing data or corruption of non-supported characters. See storing non-ASCII characters in MySQL for details.
&
' by adding 'amp;
' to the end of it, as follows:
<Server port="8005" shutdown="SHUTDOWN"> <Service name="Catalina"> <Connector port="8080" maxHttpHeaderSize="8192" maxThreads="150" minSpareThreads="25" maxSpareThreads="75" enableLookups="false" redirectPort="8443" acceptCount="100" connectionTimeout="20000" disableUploadTimeout="true" /> <Engine name="Catalina" defaultHost="localhost"> <Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true"> <Context path="" docBase="${catalina.home}/atlassian-jira" reloadable="false"> <Resource name="jdbc/JiraDS" auth="Container" type="javax.sql.DataSource" username="[enter db username]" password="[enter db password]" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost/jiradb?useUnicode=true&characterEncoding=UTF8" [ delete the minEvictableIdleTimeMillis and timeBetweenEvictionRunsMillis params here ] maxActive="20" validationQuery="select 1"/> <Resource name="UserTransaction" auth="Container" type="javax.transaction.UserTransaction" factory="org.objectweb.jotm.UserTransactionFactory" jotm.timeout="60"/> <Manager pathname=""/> </Context> </Host> </Engine> </Service> </Server>
conf/server.xml
, and delete the minEvictableIdleTimeMillis
and timeBetweenEvictionRunsMillis
attributes (which are only needed for HSQL, and degrade performance otherwise).validationQuery
parameter to the Datasource and set it to "select 1". See the XML above for an example of this.atlassian-jira/WEB-INF/classes/entityengine.xml
(if you are using JIRA Standalone) or edit-webapp/WEB-INF/classes/entityengine.xml
(JIRA WAR/EAR), and change the field-type-name
attribute to mysql
. (If you forget to do this and start JIRA, it may create database tables incorrectly. See this page if this happens to you). Also delete the schema-name="PUBLIC"
attribute, if it exists:
<!-- DATASOURCE - You will need to update this tag for your installation. --> <datasource name="defaultDS" field-type-name="mysql"[ delete this, if it exists: schema-name="PUBLIC" ] helper-class="org.ofbiz.core.entity.GenericHelperDAO" check-on-start="true" use-foreign-keys="false" ...
If you are using JIRA WAR/EAR, your application server may require other changes to entityengine.xml
(e.g. to customise the jndi-jdbc
tag).
You should now have an application server configured to connect to a database, and JIRA configured to use the correct database type. If you are using JIRA Standalone, start it up and watch the logs for any errors. If you are using the JIRA WAR/EAR distribution, rebuild and redeploy the webapp in your application server.
Have experiences to share with MYSQL and JIRA? We welcome your thoughts. Please see the user-contributed MYSQL notes.