平时Oracle数据库都安装在本地或者WindowsServer上进行使用,但因为工作需要,领导要求在虚拟机中安装Ubuntu来连接Windows本地安装的数据库,先将操作过程和遇到的问题进行梳理总结

1.先下载oracle的linux版的客户端连接程序包(下载需注册Oracle账户,免费注册下载)

oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm      基本的动态库(oci,bocci,jdbc-oci)
oracle-instantclient11.2-sqlplus-11.2.0.4.0-1.x86_64.rpm    客户端sqlplus安装包

(至于sdk,jdbc,devel根据需求按安装)

2.安装下载的rpm包(在这里踩很多坑,很无语啊!!!)

坑1.正常使用rpm命令进行安装

    rpm -i  oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm

   直接报错:

      error:Failed dependencies:

            libaio is needed by rpm -i  oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm

     直译:安装rpm -i  oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm需要libaio的依赖,就是缺少libaio依赖,无法安装

   一波操作走你:

    坑1.1  没有libaio依赖,那就装一呗,

          命令:sudo apt-get install libaio

     直接报错: Unable to locate package libaio

    坑1.2  无法定位libaio的程序包,百度一下:需要换一个repository,源不好,更换完源,需要sudo apt-get update

       update完之后,再进行安装sudo apt-get install libaio依然报错:E: Unable to locate package libaio

       (期间在/etc/apt/source.list 添加过ununtu官方源,aliyun的源,中国科技大的源,163的源)

    !!!!深呼吸,电脑没错,再次尝试rmp安装:rpm -i  oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm

    理所当然报错:但这次完整的信息都读了一遍:

    报错信息:

    rpm:RPM should not be used directly install RPM packages.use Alien instead!

    rpm:However assuming you know what are you doing .....  

    error:Failed dependencies:

       libaio is needed by rpm -ivh  oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm

     百度:alien:“alien”可以在rpm\dpkg\slackware tgz\deb\slp 格式见进行转换

   开始进入正轨:

     sudo apt-get install alien   正常

     dkpg -i oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm  正常

     dkpg -i oracle-instantclient11.2-sqlplus-11.2.0.4.0-1.x86_64.rpm  正常

3. 默认安装路径为(/usr/lib/oracle/11.2/client64)

  新建配置文件文件夹:

  mkdir -p /usr/lib/oracle/11.2/client64/network/admin

  更改文件的权限

  chown -R python:python /usr/lib/oracle/11.2/client64/network/admin

4.添加连接数据库所需要的TNS配置文件

  cd  /usr/lib/oracle/11.2/client64/network/admin/

  vim tnsnames.ora(根据自己所要连接的oracle进行配置)

ORCL =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.169.80.18)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl.168.80.6)
)
)

5.配置环境变量

vim /home/python/.bashrc

添加如下内容

export  ORACLE_HOME=/usr/lib/oracle/11.2/client64
export TNS_ADMIN=$ORACLE_HOME/network/admin
export NLS_LANG='simplified chinese_china'.ZHS16GBK
export LD_LIBRARY_PATH=$ORACLE_HOME/lib
export PATH=$ORACLE_HOME/bin:$PATH

生效环境变量:source /home/python/.bashrc

6.测试:

echo $ORACLE_HOEM  正常

sqlplus sgcc/root@ORCL  正常

  

Ubuntu安装Oracleclient远程连接数据库的更多相关文章

  1. 给ubuntu安装VNC远程桌面

    (只有背景,没有菜单栏问题没有解决)Virtual Network Computing(VNC)是进行远程桌面控制的一个软件.客户端的键盘输入和鼠标操作通过网络传输到远程服务器,控制服务器的操作.服务 ...

  2. 本地不安装oracle-client,使用pl/sql developer连接数据库

    一.问题描述 本地未安装oracle-client端,由于机器资源有限,希望通过pl/sql developer进行远程数据库连接.单纯的安装pl/sql developer无法远程连接数据库. 二. ...

  3. 在本地没有安装Oracle的情况下,使用plsql远程连接数据库

    远程连接数据库的方式不止一种.这里主要写在本地没有安装Oracle的情况下,使用plsql可视化工具远程连接数据库的方式. 一.前提 首先你本地得安装有plsql工具.具体的安装步骤就不多说了. 二. ...

  4. Ubuntu 18.1远程登录服务器--ssh的安装

    默认的Ubuntu 18.1桌面版没有安装ssh远程登录服务: 打开"终端窗口",输入"sudo apt-get update"-->回车-->&q ...

  5. Linux Ubuntu 16.04 安装步骤+远程环境

    简介 Ubantu 16.04 系统是一款比较稳定的linux系统,适合用户使用以及针对一些兼容性的服务搭建. 这里我推荐安装桌面版,用于方便使用. 准备工作 1.准备1个U盘空间5G以上 2.需下载 ...

  6. linux ubuntu安装好后,开通远程登录

    1.设置root密码 ubuntu安装好后,用初始的第一个用户登录,然后修改root密码: sudo passwd root 2.检查sshd服务是否启动 (1)查看sshd状态 -----若没有ss ...

  7. ubuntu安装 LNMP+redis

    一.更新软件源 1.修改软件源为163的源 sudo vim /etc/apt/sources.list 替换源为163的源: deb http://mirrors.163.com/ubuntu/ i ...

  8. 新安装mariadb远程登陆配置及相关问题排查

    前言: 安装过程不再赘述,直接说问题,mysql的远程连接需要解决两个问题:1.允许root用户远程连接.2.允许任意ip远程连接数据库.当然,在测试和解决问题之前,得首先保证你的数据库与远程主机之间 ...

  9. 【基于WinForm+Access局域网共享数据库的项目总结】之篇三:Access远程连接数据库和窗体打包部署

    篇一:WinForm开发总体概述与技术实现 篇二:WinForm开发扇形图统计和Excel数据导出 篇三:Access远程连接数据库和窗体打包部署 [小记]:最近基于WinForm+Access数据库 ...

随机推荐

  1. spring cloud 网管篇zuul

    1, consul 2, zuul 程序的yml 文件 server: port: 8083spring: application: name: zuulInfo # 应用名称 cloud: cons ...

  2. Elastic_Search 和java的入门结合

    1, pom 文件添加依赖... 2, config 配置文件 3, 写接口文件

  3. C#多线程---I/O线程实现异步请求

    一.场景 利用I/O线程来模拟浏览器对服务器请求的异步操作. 二.例子 1 using System; 2 using System.Collections.Generic; 3 using Syst ...

  4. Ubuntu的build-essential有什么作用

    Ubuntu缺省情况下,并没有提供C/C++的编译环境,因此还需要手动安装.但是如果单独安装gcc以及g++比较麻烦,幸运的是,Ubuntu提供了一个build-essential软件包.查看该软件包 ...

  5. Map 综述(二):彻头彻尾理解 LinkedHashMap

    摘要: HashMap和双向链表合二为一即是LinkedHashMap.所谓LinkedHashMap,其落脚点在HashMap,因此更准确地说,它是一个将所有Entry节点链入一个双向链表的Hash ...

  6. 哈希表(HashMap)分析及实现(JAVA)

    转自:http://www.java3z.com/cwbwebhome/article/article8/83560.html?id=4649 探讨Hash表中的一些原理/概念,及根据这些原理/概念, ...

  7. NLP与深度学习(二)循环神经网络

    1. 循环神经网络 在介绍循环神经网络之前,我们先考虑一个大家阅读文章的场景.一般在阅读一个句子时,我们是一个字或是一个词的阅读,而在阅读的同时,我们能够记住前几个词或是前几句的内容.这样我们便能理解 ...

  8. ArrayList线程不安全怎么办?(CopyOnWriteArrayList详解)

    ArrayList线程不安全怎么办? 有三种解决方法: 使用对应的 Vector 类,这个类中的所有方法都加上了 synchronized 关键字 就和 HashMap 和 HashTable 的关系 ...

  9. go语言内存对齐

    内存对齐 为保证程序顺利高效的运行,编译器会把各种类型的数据安排到合适的地址并占用合适的长度,这就是内存对齐 每种类型的对齐值就是他的内存边界 64位 类型 对齐边界 (对齐值) int8 1byte ...

  10. 将视图批量新增到PowerDesigner中并以model图表的形式展示

    1:需求 数据库中的所有视图大概64个左右,都需要新增到PowerDesigner中,以图表(model)的形式给展示出来,如下: 2:问题点: 由于2020年春节期间病毒的原因,我们需要远程办公,新 ...