9.0 KiB
odbc-win32编译指导
1、下载并配置环境变量
odbc编译windows32位软件包,需要下面的依赖
1.1下载下面的软件包
1.2配置环境变量

注意:
- 安装完msys2和mingw32,将mingw32目录覆盖msys2目录下的mingw32目录,并将覆盖后的mingw32/bin目录下mingw32-make.exe重命名make.exe
- 修改msys2的镜像源,可以参考华为镜像源

- 配置完镜像源,打开msys2控制台,下载一些必要的环境依赖
# 更新软件包数据
pacman -Syu
# 下载一些必要的软件
pacman -S --needed base-devel
1.3验证环境变量
验证perl -v,make -v, cmake -version, gcc -v, g++ -v, sed是否存在
2、准备源代码
odbc编译windows32需要的代码有,openssl,安全函数,openGauss-connector-odbc,openGauss-server;其中openssl和安全函数都在社区的三方库中
3、编译odbc
首先先将上面的源代码,统一放到一个文件夹下,这样是为了方便规划,比如我这边是将上面4个源代码,放到window_odbc/win32/open_source路径下
脚本介绍
在openGauss-connector-odbc\windows\build路径下有两个脚本,一个是openssl.bat编译openssl,一个是odbc.bat编译odbc
odbc.bat脚本的最开始,是一些环境变量和代码的路径,需要根据自己实际路径配置下
set WD=%__CD__%
set LIB_SECURITY_DIR=D:\windows_odbc\win32\open_source\Huawei_Secure_C_V100R001C01SPC010B002
set LIB_GAUSSDB_DIR=D:\windows_odbc\win32\open_source\openGauss-server
set LIB_ODBC_DIR=D:\windows_odbc\win32\open_source\openGauss-connector-odbc
set MINGW_DIR=D:\buildtools\mingw-8.1.0\msys64\mingw32
set CMAKE_DIR=D:\env\cmake-3.26
REM openss compiled direction
set OPENSSL_DIR=D:\windows_odbc\win32\open_source\output\openssl-win32
set p7zip=D:\install\7-Zip
set OUTPUT_DIR=%LIB_ODBC_DIR%/odbc_output
3.1编译openssl
在odbc.bat脚本中调用openssl.bat编译openssl
if not exist %OPENSSL_DIR%/libcrypto-1_1.dll (
cd %WD%
REM Build openssl
call openssl.bat
)
openssl.bat脚本的内容
cd %WD%
REM build openssl
cd %OPENSSL_DIR%
REM openssl config
%MSYS_SHELL% -defterm -mingw32 -no-start -full-path -here -c './Configure ^
--prefix=$PWD/openssl-win32 ^
shared mingw no-tests; make -j20; make install -j20; ^
cp $PWD/openssl-win32/bin/libssl-1_1.dll $PWD/openssl-win32; ^
cp $PWD/openssl-win32/bin/libcrypto-1_1.dll $PWD/openssl-win32; ^
rm -rf $PWD/../../output; ^
mkdir -p $PWD/../../output; mv $PWD/openssl-win32 $PWD/../../output/.' ^
编译结果
同时在window_odbc/win32/open_source/output路径中也会生成openssl-win32的文件夹
3.2编译libsecurec.lib
cd %WD%
REM Build libsecurec.lib
cp win32/libpq/CMakeLists-huawei-securec.txt %LIB_SECURITY_DIR%/CMakeLists.txt
cd %LIB_SECURITY_DIR%
rm -rf build
mkdir build
cd build
cmake -DMINGW_DIR="%MINGW_DIR%" -D"CMAKE_MAKE_PROGRAM:PATH=%MINGW_DIR%/bin/make.exe" -G "MinGW Makefiles" ..
make
编译结果
安全函数编译出的libsecurec.lib会在安全函数的output目录下
3.3编译libpq.lib
cd %WD%
REM Build libpq.lib
rm -rf %LIB_GAUSSDB_DIR%/libpq-win32
cp -r win32/libpq %LIB_GAUSSDB_DIR%/libpq-win32
cd %LIB_GAUSSDB_DIR%/libpq-win32
cp -r %LIB_SECURITY_DIR%/output ./lib
bash %LIB_GAUSSDB_DIR%/libpq-win32/project.sh
rm -rf build
mkdir build
cd build
cmake -DMINGW_DIR="%MINGW_DIR%" -DOPENSSL_DIR="%OPENSSL_DIR%" -D"CMAKE_MAKE_PROGRAM:PATH=%MINGW_DIR%/bin/make.exe" -G "MinGW Makefiles" ..
make
注意:
- 在编译libpq.lib的时候,要确保project.sh执行成功,sh可以在git控制台执行
- 修改dirmod.cpp
第45行注释掉 // #include "storage/file/fio_device.h"
在87行增加
bool is_file_delete(int err)
{
return (err == ENOENT);
}
- 修改gs_readdir.cpp
第31行注释掉 // #include "storage/file/fio_device.h"
编译结果
如果遇到下面的问题,说明是openssl没有找到
解决方法:手动修改D:\windows_odbc\win32\open_source\openGauss-server\libpq-win32\build目录下的CMakeCache.txt文件
修改LIB_CRYPTO和LIB_SSL的环境依赖
重新make
3.4编译psqlodbc35w.lib
cd %WD%
REM Build psqlodbc35w.lib
cd %LIB_ODBC_DIR%
rm -rf libpq
cp -r %LIB_GAUSSDB_DIR%/libpq-win32/libpq-export ./libpq
cp -r %LIB_GAUSSDB_DIR%/libpq-win32/lib/* ./libpq/lib
cp -r %LIB_GAUSSDB_DIR%/libpq-win32/output/libpq.lib ./libpq/lib
rm -rf build
mkdir build
cd build
cmake -DMINGW_DIR="%MINGW_DIR%" -DOPENSSL_DIR="%OPENSSL_DIR%" -D"CMAKE_MAKE_PROGRAM:PATH=%MINGW_DIR%/bin/make.exe" -G "MinGW Makefiles" ..
make
编译结果
如果遇到下面的问题,这说明还是环境依赖找不到的原因,和编译libpq.lib问题一样的,只需要修改CMakeCache.txt文件对应的环境依赖,参考libpq.lib的修改
输出正常结果
3.5制作odbc安装包
cd %WD%
REM Build psqlodbc.exe
cd psqlodbc-installer
rm -rf win32_dll
mkdir win32_dll
cp %LIB_ODBC_DIR%/output/psqlodbc35w.dll ./win32_dll
cp "%OPENSSL_DIR%"/libssl-1_1.dll ./win32_dll
cp "%OPENSSL_DIR%"/libcrypto-1_1.dll ./win32_dll
makensis odbc-installer.nsi
编译结果
3.6将odbc打包成tar.gz
cd %WD%
rm -rf odbc_output
mkdir odbc_output
cp psqlodbc-installer/psqlodbc.exe odbc_output
rm -rf psqlodbc-installer/psqlodbc.exe
cd odbc_output
%p7zip%\7z.exe a -tgzip openGauss-5.0.0-ODBC-windows.tar.gz ./*
rm -rf "%OUTPUT_DIR%"
mkdir "%OUTPUT_DIR%"
cp -r openGauss-5.0.0-ODBC-windows.tar.gz %OUTPUT_DIR%
编译结果