MacOS之Oracle问题

准备

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环境变量

启动过程中的问题

  1. 此时,mac中启动项目可能会报空指针异常,见下图。此时是因为程序读取不到系统的环境变量,如果在确定配置环境变量的情况下,那么一般是mac系统的GUI 获取不到环境变量,有以下几种解决办法:
    ![`0ND[2~H6867UJUVW70VT5.jpg

① 使用终端打开IDE,

open /Application/XXX.app

保证IDE读取的环境变量和终端读取的环境变量相同

②使用github上开源的osx-env-sync修复GUI的问题

  1. 环境变量可以读取之后,往下执行代码,会报 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/

你可能感兴趣的:(MacOS之Oracle问题)