前言 出現(xiàn)有需要打包 Java 應用和 Mysql數據庫成一個安裝包給出去的需求,這里我把整個打包的流程整理一下。 環(huán)境 JDK17; MySQL 5.7; 流程 Jpackage打包EXE Jpackage是JDK14后加入的一個用于獨立打包的工具,能夠將應用打包成exe,有了Jpackage就不
出現(xiàn)有需要打包 Java 應用和 Mysql數據庫成一個安裝包給出去的需求,這里我把整個打包的流程整理一下。
JDK17;
MySQL 5.7;
Jpackage是JDK14后加入的一個用于獨立打包的工具,能夠將應用打包成exe,有了Jpackage就不需要用exe4j這種打包工具,省去打包的繁瑣流程。
首先在idea里面打好Jar包,記下jar包的名字,比如是application.jar。打完后Jar包的目錄一般是在target文件夾下,進到項目的目錄,在上方的輸入欄里輸入打包命令,回車。
打包命令:
jpackage --type app-image --name application --input target --main-jar application.jar --win-console --dest dist
打包完成后可以在dist文件夾里面看到對應的項目,雙擊exe就可以運行起項目。
jpackage命令詳情:
--type
:指定要創(chuàng)建的安裝程序的類型,如
exe
、
msi
(僅限 Windows)、
pkg
(僅限 macOS)、
deb
、
rpm
等。
--input
:指定要打包的輸入文件或目錄的路徑。
--dest
:指定生成安裝程序的目標目錄。
--name
:指定應用程序的名稱。
--app-version
:指定應用程序的版本號。
--main-jar
:指定應用程序的主 JAR 文件。
--main-class
:指定應用程序的主類。
--icon
:指定應用程序的圖標文件。
--vendor
:指定應用程序的供應商名稱。
--runtime-image
:指定自定義的運行時鏡像目錄--runtime-image
--java-options "-D..."
:指定自定義VM運行參數。
進入MySQL官網,MySQL :: Download MySQL Community Server (Archived Versions),選擇合適的打包,下載Zip版本。
下載完成后解壓,打開解壓的文件夾,這里我采用將設置好賬戶和創(chuàng)建好相應表的數據庫對應的data文件夾復制到剛剛解壓的MySQL根目錄下,這樣子我只需要用命令行初始化MySQL,不需要去執(zhí)行其他創(chuàng)建表和賬戶權限的語句,即可實現(xiàn)數據庫的開箱即用。也可以是在初始化的bat文件里執(zhí)行相關的sql語句,對應下面的myinit_admin.bat文件。
在根目錄下創(chuàng)建my.ini,輸入以下內容:
[client]
port=3306
[mysql]
default-character-set=utf8
[mysqld]
port=3306
character-set-server=utf8
default-storage-engine=INNODB
max_connections=100
table_open_cache=256
tmp_table_size=35M
thread_cache_size=8
myisam_max_sort_file_size=100G
myisam_sort_buffer_size=69M
key_buffer_size=50M
read_buffer_size=64K
read_rnd_buffer_size=256K
sort_buffer_size=256K
innodb_flush_log_at_trx_commit=1
innodb_log_buffer_size=1M
innodb_buffer_pool_size=96M
innodb_log_file_size=20M
innodb_thread_concurrency=18
創(chuàng)建兩個bat文件, 并且在執(zhí)行bat的時候獲取系統(tǒng)的管理員權限 ,如果沒有管理員權限會無法初始化。
創(chuàng)建myinit_admin.bat文件,流程是先往my.ini里面寫入mysql的路徑和data文件對應的路徑,獲取管理員的權限進行MySQL初始化命令的執(zhí)行。 這個文件是在安裝的時候執(zhí)行。
echo
set CURRENT_DIR=%~dp0
set CURRENT_DIR=%CURRENT_DIR:\=/%
echo basedir="%CURRENT_DIR%">%CURRENT_DIR%my.ini
echo datadir="%CURRENT_DIR%data/">%CURRENT_DIR%my.ini
@echo off
:: 開始獲取管理員權限
setlocal
set uac=~uac_permission_tmp_%random%
md "%SystemRoot%\system32\%uac%" 2>nul
if %errorlevel%==0 ( rd "%SystemRoot%\system32\%uac%" >nul 2>nul ) else (
echo set uac = CreateObject^("Shell.Application"^)>"%temp%\%uac%.vbs"
echo uac.ShellExecute "%~s0","","","runas",1 >>"%temp%\%uac%.vbs"
echo WScript.Quit >>"%temp%\%uac%.vbs"
"%temp%\%uac%.vbs" /f
del /f /q "%temp%\%uac%.vbs" & exit )
endlocal
echo
cd /d %~dp0
cd bin
"%cd%\mysqld.exe" --initialize-insecure --user=mysql --console
echo -----mysql init succee-----
mysqld install mysql
echo -----mysql service install succee-----
net start mysql
sc config mysql start=auto
net stop mysql
net start mysql
echo Installation complete
timeout /nobreak /t 10
exit
創(chuàng)建mystop_admin.bat文件,同樣需要獲取管理員權限。 這個文件是在MySQL卸載的時候執(zhí)行。
@echo off
:: 開始獲取管理員權限
setlocal
set uac=~uac_permission_tmp_%random%
md "%SystemRoot%\system32\%uac%" 2>nul
if %errorlevel%==0 ( rd "%SystemRoot%\system32\%uac%" >nul 2>nul ) else (
echo set uac = CreateObject^("Shell.Application"^)>"%temp%\%uac%.vbs"
echo uac.ShellExecute "%~s0","","","runas",1 >>"%temp%\%uac%.vbs"
echo WScript.Quit >>"%temp%\%uac%.vbs"
"%temp%\%uac%.vbs" /f
del /f /q "%temp%\%uac%.vbs" & exit )
endlocal
@echo off
cd /d %~dp0
echo ----1.[Mysql] start uninstalling Mysql ---->>../log.txt
sc stop mysql
sc delete mysql
echo ----2. [Mysql] uninstall finished---- >>../log.txt
exit
進入Inno Setup Downloads (jrsoftware.org),進行下載安裝。
創(chuàng)建一個文件夾,將MySQL和打包后的Java應用文件夾都放到一起,Java程序放在project文件夾下。
創(chuàng)建Inno.iss文件,用inno Setup打開,在里面輸入:
; Script generated by the Inno Setup Script Wizard.
; SEE THE DOCUMENTATION FOR DETAILS ON CREATING INNO SETUP SCRIPT FILES!
[Setup]
; 腳本由 Inno Setup 腳本向導 生成!
; 有關創(chuàng)建 Inno Setup 腳本文件的詳細資料請查閱幫助文檔!
#define MyAppName "Application"
#define MyAppVersion "1.0"
#define MyAppPublisher "zh"
#define MyAppExeName "application.exe"
[Setup]
; 注: AppId的值為單獨標識該應用程序。
; 不要為其他安裝程序使用相同的AppId值。
; (生成新的GUID,點擊 工具|在IDE中生成GUID。)
AppId={{6CEE70A6-5DBD-43FF-9449-466A574C65E1}
AppName={#MyAppName}
AppVersion={#MyAppVersion}
;AppVerName={#MyAppName} {#MyAppVersion}
AppPublisher={#MyAppPublisher}
DefaultDirName={pf}\{#MyAppName}
DefaultGroupName={#MyAppName}
; 輸入你要生成exe安裝包的路徑
OutputDir=E:\xxxx
; 輸入程序安裝后的文件名
OutputBaseFilename=Application
Compression=lzma
SolidCompression=yes
;AlwaysRestart=yes
;PrivilegesRequired=admin
[Languages]
Name: "chinesesimp"; MessagesFile: "compiler:Default.isl"
[Tasks]
Name: "desktopicon"; Description: "{cm:CreateDesktopIcon}"; GroupDescription: "{cm:AdditionalIcons}"; Flags: unchecked; OnlyBelowVersion: 0,6.1
[Files]
Source: "E:\xxx\mysql-5.7.41-winx64\*"; DestDir: "{app}\mysql-5.7.41-winx64"; Flags: ignoreversion recursesubdirs createallsubdirs
Source: "E:\xxx\project\*"; DestDir: "{app}\project"; Flags: ignoreversion recursesubdirs createallsubdirs
; 注意: 不要在任何共享系統(tǒng)文件上使用“Flags: ignoreversion”
; Java exe對應的目錄
[Icons]
Name: "{commondesktop}\Application";Filename: "{app}\project\applicaiton.exe"; WorkingDir: "{app}\project"
[INI]
;修改數據庫配置文件(注意這個步驟,在上面的myinit_admin.bat已經獲得了數據庫和data的路徑,但是不知道為什么我獲取的路徑會有點問題,在這個步驟也可以寫入相應的路徑。
;Filename:"{app}\mysql-5.7.41-winx64\my.ini";Section:"mysqld";Key:"basedir"; String:"{app}\mysql-5.7.41-winx64"
;Filename:"{app}\mysql-5.7.41-winx64\my.ini";Section:"mysqld";Key:"datadir"; String:"{app}\mysql-5.7.41-winx64\data"
; 安裝的時候會執(zhí)行
[Run]
Filename: "{app}\mysql-5.7.41-winx64\myinit_admin.bat";
; 卸載的時候會執(zhí)行
[UninstallRun]
Filename: "{app}\mysql-5.7.41-winx64\mystop_admin.bat";
[UninstallDelete]
Type:filesandordirs;Name:"{app}"
在軟件左上方點擊run
執(zhí)行完成生成了一個exe安裝包,雙擊這個安裝包選擇相應路徑進行安裝。只要Java程序已經配置好了相應的數據庫連接,則安裝后軟件即可進行使用。
小編推薦閱讀