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

2024-05-01 00:04

本文主要是介绍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.0USER 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.0container_name: jira_containerports:- "9000:8080"depends_on:- mysqlenvironment:- MYSQL_HOST=mysql_container- MYSQL_PORT=3306- MYSQL_DATABASE=jiradb- MYSQL_USER=jira- MYSQL_PASSWORD=123456networks:- bridgevolumes:- ./dbconfig.xml:/var/atlassian/application-data/jira/dbconfig.xml- ./lib/:/var/atlassian/jira/lib/mysql:image: mysql:5.7container_name: mysql_containerports:- "3306:3306"environment:MYSQL_ROOT_HOST: '%'MYSQL_ROOT_PASSWORD: 123456MYSQL_USER: jiraMYSQL_PASSWORD: 123456MYSQL_DATABASE: jiradbvolumes:- ./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:- bridgenetworks: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即可.

这篇关于linux docker 部署破解版本jira:8.4.0——测试体验(非商用)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/950260

相关文章

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

Ubuntu如何升级Python版本

《Ubuntu如何升级Python版本》Ubuntu22.04Docker中,安装Python3.11后,使用update-alternatives设置为默认版本,最后用python3-V验证... 目China编程录问题描述前提环境解决方法总结问题描述Ubuntu22.04系统自带python3.10,想升级

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4: