linux docker 部署破解版本jira:8.4.0——测试体验(非商用)

由于jira是非开源的,所以自己测试用的是破解版本。仅限于自己测试使用,非商用。

本文参考文章,做了一些整理。
 

一、拉取镜像

jira:需要根据这个官网的jira版本构建一个破解版的jira镜像

docker pull atlassian/jira-software:8.4.0

jira 8.4.0适配的mysql数据库是5.7.x。

mysql:

docker pull mysql:5.7

二、构建pojie版的jira镜像

1.下载pojie程序包

参考文章中有:通过Docker安装JIRA8.4.0与Confluence7.0.2(破解版) - 简书

解压后将jar放到一个指定的目录,待会和Dockerfile同级目录。

2.构建Dockerfile

内容:

#截至2019年9月11日,最新版本为8.4.0,后期出现新版本可指定8.4.0进行安装。
FROM atlassian/jira-software:8.4.0

USER root

# 创建目录 /opt/jira/bin/
RUN mkdir -p /opt/atlassian/jira/bin/

# 将代理破解包加入容器
COPY "atlassian-agent.jar" /opt/atlassian/jira/

# 替换为自定义的配置文件
COPY custom-config.xml /var/atlassian/application-data/jira/dbconfig.xml

# 如果 setenv.sh 文件不存在,则创建一个空文件
RUN touch /opt/atlassian/jira/bin/setenv.sh

# 设置启动加载代理包
RUN echo 'export CATALINA_OPTS="-javaagent:/opt/atlassian/jira/atlassian-agent.jar ${CATALINA_OPTS}"' >> /opt/atlassian/jira/bin/setenv.sh

#暴露端口
EXPOSE 9000

3.构建镜像,执行命令

docker build -t jira/jira:8.4.0 .

4.查看构建好的镜像

docker images ls

三、运行容器_dockercompose的方式

0.构建docker-compose.yml

仍然和jar一个目录就行。

内容:

version: '3'
services:
  jira:
    image: jira:8.4.0
    container_name: jira_container
    ports:
      - "9000:8080"
    depends_on:
      - mysql
    environment:
      - MYSQL_HOST=mysql_container
      - MYSQL_PORT=3306
      - MYSQL_DATABASE=jiradb
      - MYSQL_USER=jira
      - MYSQL_PASSWORD=123456
    networks:
      - bridge
    volumes:
      - ./dbconfig.xml:/var/atlassian/application-data/jira/dbconfig.xml
      - ./lib/:/var/atlassian/jira/lib/

  mysql:
    image: mysql:5.7
    container_name: mysql_container
    ports:
      - "3306:3306"
    environment:
      MYSQL_ROOT_HOST: '%'
      MYSQL_ROOT_PASSWORD: 123456
      MYSQL_USER: jira
      MYSQL_PASSWORD: 123456
      MYSQL_DATABASE: jiradb
    volumes:
      - ./mysql_custom.cnf:/etc/mysql/mysql.conf.d/mysql_custom.cnf
      - ./mysqld.cnf:/etc/mysql/conf.d/mysql.cnf
      - ./init.sql:/docker-entrypoint-initdb.d/init.sql   
    networks:
      - bridge

networks:
  bridge:
    driver: bridge

一些小解释:

  • 绑定./lib是为了能够将破解程序包让jira正确加载,这样子就可以实现破解了。
    • jira的驱动程序在 /opt/atlassian/jira/lib下。
  • networks这俩个必须绑定同一个网络才可能互相通信访问。
  • 这里jira绑定容器内8080是由于jira默认的端口是8080。

对于mysql的一些小细节

这里mysql配置中的 mysql_custom.cnf 内容,为了跳过ssl,但是貌似没有效果,可以不用管,不影响。

0. mysql_custom.cnf 内容:
[mysqld]
skip_ssl

这里的 mysqld.cnf 对mysql进行一个基础的设置:

1. mysqld.cnf内容:
[mysqld]
# 基本设置
user = jira
pid-file = /var/run/mysqld/mysqld.pid
socket = /var/run/mysqld/mysqld.sock
port = 3306
basedir = /usr
datadir = /var/lib/mysql
tmpdir = /tmp
skip-host-cache
skip-name-resolve

# Jira
default-storage-engine=INNODB
character_set_server=utf8mb4
innodb_default_row_format=DYNAMIC
innodb_large_prefix=ON
innodb_file_format=Barracuda
innodb_log_file_size=2G


# 字符集设置
#character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci

# 日志设置
log_error = /var/log/mysql/error.log
log_queries_not_using_indexes = 1

# InnoDB 存储引擎设置
innodb_file_per_table = 1
innodb_buffer_pool_size = 128M
innodb_log_file_size = 256M
innodb_flush_log_at_trx_commit = 1

# 安全设置
bind-address = 0.0.0.0
 

这里的init.sql是初始化数据库做的一些操作,比如新建一个数据库,用户之类的。

2. init.sql 内容:
GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP,REFERENCES,ALTER,INDEX ON jira.* TO 'jira'@'%' IDENTIFIED BY 'jira';
GRANT ALL PRIVILEGES ON jira.* TO 'jira'@'%' IDENTIFIED BY 'jira';
SET PASSWORD FOR 'jira'@'%' = PASSWORD('123456');

对于jira的一些小细节
0. dbconfig.xml

内容:

<jira-database-config>
  <name>defaultDS</name>
  <delegator-name>default</delegator-name>
  <database-type>mysql</database-type>
  <jdbc-datasource>
    <url>jdbc:mysql://mysql_container:3306/jiradb?useUnicode=true&amp;characterEncoding=UTF8&amp;useSSL=false&amp;sessionVariables=default_storage_engine=InnoDB</url>
    <driver-class>com.mysql.jdbc.Driver</driver-class>
    <username>jira</username>
    <password>123456</password>
    <pool-min-size>20</pool-min-size>
    <pool-max-size>20</pool-max-size>
    <pool-max-wait>30000</pool-max-wait>
    <pool-max-idle>20</pool-max-idle>
    <pool-remove-abandoned>true</pool-remove-abandoned>
    <pool-remove-abandoned-timeout>300</pool-remove-abandoned-timeout>
 
    <validation-query>select 1</validation-query>
    <min-evictable-idle-time-millis>60000</min-evictable-idle-time-millis>
    <time-between-eviction-runs-millis>300000</time-between-eviction-runs-millis>
  
    <pool-test-while-idle>true</pool-test-while-idle>
    <pool-test-on-borrow>false</pool-test-on-borrow>
    <validation-query-timeout>3</validation-query-timeout>
  </jdbc-datasource>
</jira-database-config>

因为是要用docker-compose去部署这两个容器,并且在同一个网络中,所以就可以通过容器名称去访问,所以这里是mysql的容器名称:mysql_container

这个 dbconfig.xml 也可以在 jira官网中找到。

1. /lib/文件夹
将 atlassian-agent.jar (破解包)放到新建的lib文件夹下。

现在的目录大致是这样子:

2. 执行命令

在当前这个目录执行:

docker-compose up -d

1.访问

部署的ip+9000即可.

  • 17
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
好的,我可以为您提供一些关于 Linux 安装 Docker部署软件测试环境的指导。 以下是一些基本步骤: 1. 安装 DockerLinux 上安装 Docker,可以使用以下命令: ``` curl -fsSL https://get.docker.com -o get-docker.sh sudo sh get-docker.sh ``` 2. 启动 Docker 安装完成后,启动 Docker 服务,可以使用以下命令: ``` sudo systemctl start docker ``` 3. 部署软件测试环境 使用 Docker 部署软件测试环境,可以使用 Docker Compose 工具。Docker Compose 是一个用于定义和运行多个 Docker 容器应用的工具。 首先,创建一个名为 docker-compose.yml 的文件,用于定义需要部署容器应用。 例如,以下是一个简单的 docker-compose.yml 文件,用于部署一个 Node.js 应用和一个 MongoDB 数据库: ``` version: '3' services: app: build: . ports: - "3000:3000" depends_on: - db db: image: mongo:latest ``` 在以上示例中,app 服务使用 Dockerfile 构建应用程序镜像,并将应用程序的端口映射到主机的 3000 端口。db 服务使用 mongo:latest 镜像启动 MongoDB 数据库。 构建和启动容器应用程序,可以使用以下命令: ``` docker-compose up -d ``` 以上命令将在后台构建和启动应用程序容器。在部署完成后,可以使用以下命令查看容器运行状态: ``` docker ps ``` 这就是一些基本的步骤,用于在 Linux 上安装 Docker部署软件测试环境。希望对您有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Chao_nengli

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值