准备
macOS
下载idea\eclipse等IDE
配置好Java环境
配置好mvn环境
下载oracle客户端
为什么要下载客户端?
虽然测试的时候可以连接测试服务器的oracle,但是oracle的连接方式和mysql等不一样,不可以直接通过ip、port、username、password来连接;而是要在客户端里面配置好服务器端的网络名等参数,才可以连接,所以本地一定要下载一个客户端。
并且tnsnames.ora里面的连接方式一定要书写正确,否则会报类似以下错误:ora-12154无法解析指定连接标识符
XXXXX=
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = XXXX)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = orcl)
(SERVER = DEDICATED)
)
)
XXXX=
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = XXXX)(PORT = 1522))
)
(CONNECT_DATA =
(SERVICE_NAME = dev)
(SERVER = DEDICATED)
)
)
配置oracle环境变量
启动过程中的问题
- 此时,mac中启动项目可能会报空指针异常,见下图。此时是因为程序读取不到系统的环境变量,如果在确定配置环境变量的情况下,那么一般是mac系统的GUI 获取不到环境变量,有以下几种解决办法:
![`0ND[2~H6867UJUVW70VT5.jpg
① 使用终端打开IDE,
open /Application/XXX.app
保证IDE读取的环境变量和终端读取的环境变量相同
②使用github上开源的osx-env-sync修复GUI的问题
- 环境变量可以读取之后,往下执行代码,会报 no ocijdbcXX in java.library.path的错误,这个错误主要是因为找不到ocijdbcXX的资源,如果是win的话,直接将.dll文件放入c盘System32下面,就可以加载读取到。但是在mac下,是.dylib文件。有以下几种办法解决:
① 拷贝你的libxxx到java.library.path指向的某个目录下面,使用以下命令获取path路径
System.out.println(System.getProperty("java.library.path"));
②利用环境变量,设置LD_LIBRARY_PATH来添加Java path
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME export LD_LIBRARY_PATH
还有一些其他的办法,因为没有尝试就没有列出来,这样,就可以找到正确的资源依赖,可以成功连接数据库
其他参考:
https://stackoverflow.com/questions/11838219/java-system-getenv
https://www.jb51.net/article/126947.htm
https://www.cnblogs.com/huhu0013/p/4506013.html
https://blogs.sap.com/2015/10/27/mac-os-x-environment-variables-and-sap-gui-for-java/
网友评论