JIRA连接PostgreSQL数据库的详细步骤

本文主要介绍如何连接JIRA到Postgresql数据库

首先

  • 检查是否支持你的Postgresql版本。请参见支持的平台

  • 如果是转移JIRA到另一台服务器,先导出数据为XML备份,然后将旧数据库中的数据传输到新的数据库

  • 在开始前关闭JIRA,除非你正在运行Setup Wizard。

1.创建并配置Postgresql数据库

  1. 创建与JIRA连接的数据库用户登录角色)例如:jiradbuser。

  2. 使用Unicode排序规则创建一个存储JIRA问题的数据库,如:jiradb。

    CREATE DATABASE jiradb WITH ENCODING 'UNICODE' LC_COLLATE 'C' LC_CTYPE 'C' TEMPLATE template0;
       或通过命令行:
       $ createdb -E UNICODE -l C -T template0 jiradb
  3. 确保该用户拥有连接数据库以及创建和编辑表的权限。

2.将Postgresql JDBC驱动程序复制到你的应用服务器(仅供JIRA WAR)

如果你安装了包含Postgresql JDBC 驱动的JIRA'Recommended'分布可跳过此步。JIRA WAR分布不包含该驱动。

  1. http://jdbc.postgresql.org/download.html下载Postgresql JDBC驱动。

  2. 添加Postgresql JDBC驱动程序jar到应用服务器的lib/目录下。

3.配置JIRA服务器来连接到Postgresql数据库

三种配置JIRA服务器链接到Postgresql数据库方法

  • 使用JIRA安装向导(不适用于JIRA WAR)——如果你已经安装JIRA并且是第一次设置,设置将被保存到JIRA主目录的dbconfig.xml文件里。

  • 使用JIRA配置工具(不适用于JIRA WAR)——如果有已存在的JIRA实例,设置将被保存到JIRA主目录的dbconfig.xml文件里。

  • 手动配置——只有当你有JIRA WAR实例或控制台时使用这种方法链接到JIRA服务器。需要手动更新JIRA主目录里的dbconfig.xml文件

每种配置方法的说明:

JIRA setup wizard
当你首次在浏览器上访问JIRA时,JIRA setup wizard才会显示

  1. 在最开始页面的'Configure Language and Database'设置Database Connection为My own
    database。

  2. 设置Database Type为Postgresql

  3. 按照下面介绍的数据库连接字段部分描述填写字段。

  4. 测试连接并保存。

JIRA configuration tool

  1. 按如下指示运行JIRA配置工具:

    Windows:打开命令提示符,运行JIRA安装目录的bin子目录文件config.bat。
               Linux/Unix:打开控制台,运行JIRA安装目录的bin子目录文件config.sh。
           可能会出现失败的错误,参照文末的解决方案一进行解决
  2. 导航到Database选项卡,设置Database type为Postgresql

  3. 按下面描述的数据库连接字段填写字段。

  4. 测试连接并保存。

  5. 重启JIRA。

Manually

  1. 找到JIRA主目录根目录下的dbconfig.xml文件

    如果该文件不存在,创建该文件,将XML示例代码(如下)复制粘贴到该文件
  2. 根据下面数据库连接字段描述更新该文件。通过在每一个末端添加'amp;'转义所有'&'字符。

    注意:元素必须指定数据库类型。例:如果你正在使用Postgresql 9.2。如果你忘记指定数据库类型就启动JIRA,那么数据库表将不会被正确创建。若遇到类似问题,参见文末的解决方案二进行参考解决
  3. 保存文件并重启JIRA。

数据库连接字段:

Hostname
位于< url>标记(例如下面加*的文字):
< url>jdbc:postgresql://*dbserver*:5432/jiradb< /url>
安装Postgresql服务器的机器名称或IP地址。

Port
位于< url>标记(例如下面加*的文字):
< url>jdbc:postgresql://dbserver:*5432*/jiradb< /url>
Postgresql服务器正在监听的TCP/IP端口。也可以留空来使用认端口。

Database
位于< url>标记(例如下面加*的文字):
< url>jdbc:postgresql://dbserver:5432/*jiradb*< /url>
Postgresql数据库(JIRA数据将保存的数据库)的名称。应该在上面第一步时创建。

Username
位于< username>标记(例如下面加*的文字):
< username>*jiradbuser*< /username>
JIRA用于连接Postgresql服务器的用户。应在上面第一步时创建。

Password
位于< password>标记(例如下面加*的文字):
< password>*jiradbuser*< /password>
用于与Postgresql服务器身份验证的用户密码。

Schema
位于< schema-name>标记(例如下面加*的文字):
< schema-name>*public*< /schema-name>
Postgresql数据库使用的模式名称
Postgresql 7.2及以后的版本要求在中指定模式。如果你的Postgresql使用认'public'模式,这需要在元素中指定。
确保你的数据库模式名称是小写,因为JIRA不支持Postgresql数据库中的模式名称包含大写字符。

dbconfig.xml文件示例

4.启动JIRA

现在JIRA连接到Postgresql数据库就配置好了。下一步就是启动JIRA。

  • 如果正在使用JIRA的'recommended'分配,启动它,并观察日志中是否存在错误

  • 如果使用的是JIRA WAR分配,重建并重新部署在应用服务器的Web应用程序。

点击查看>>更多JIRA中文教程
解决方案一:https://confluence.atlassian.com/display/JIRAKB/Unable+to+Start+JIRA+Config+Tool+due+to+No+X11+DISPLAY+variable+was+set+error
解决方案二:https://confluence.atlassian.com/display/JIRAKB/Incorrect+database+type+specified

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...