使用Docker安装Superset并设置Oracle访问和使用PG作Meta数据库

一、安装 Docker
安装一个linux,可以是Centos或Ubuntu,如果是Centos 7.X,那么要注意先将系统自带的docker先删除。下文以Centos7.9为例


#删除自带的不完整版本
yum remove docker docker-client docker-client-latest \docker-common docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine# 安装完整版 docker-ce
yum install -y yum-utils
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repoyum install docker-cesystemctl start docker
systemctl enable docker# 安装 docker-compose,就是从github中下载一个回来。2.X版本都可以。
curl -L https://github.com/docker/compose/releases/download/v2.21.0/docker-compose-`uname -s`-`uname -m` \-o /usr/local/bin/docker-composechmod a+x /usr/local/bin/docker-compose

二、建立含Oracle和PG数据库驱动的镜像文件

建立 基于 PG 的 meta 数据库mkdir /pgdata
docker pull postgres:12.3
docker run --name postgres12 -e POSTGRES_PASSWORD=password -p 5432:5432 -v /pgdata:/var/lib/postgresql/data -d postgres:12.3docker exec -it postgres12 bash# 进入到 docker 内部
su postgres
psql -U postgres -W (登录时要输入密码,如 docker 所设)# 进入到 docker 的 postgresql 内部
create user superset with password 'password';
create database superset owner superset;exit
exit 
# (退回到宿主操作系统)
exit #编辑  /pgdata/pg_hba.conf 最后一行,看看有没有:host all all all md5# 如果没有,需加上去,以保证数据库能被其它机器访问#关闭  pg库docker stop postgresql12```bashmkdir /root/docker_superset
cd /root/docker_supersetdocker pull postgres:12.3
dockerdocker pull apache/superset:3.0.0 vi superset_conf.py

创建 /root/docker_superset/superset_conf.py 内容如下:

SECRET_KEY = 'superset'
SQLALCHEMY_DATABASE_URI = 'postgresql://superset:password@postgres12/superset'
WTF_CSRF_ENABLED = False
TALISMAN_ENABLED = False
BABEL_DEFAULT_LOCALE = "zh"
LANGUAGES = {"zh": {"flag": "cn", "name": "简体中文"},"en": {"flag": "us", "name": "English"},
}

创建目录 /root/docker_superset/oracle_driver/
在网上找Oracle的驱动文件,

oracle-instantclient-basic-xxxxxxx.rpm 的文件(xxxx是版本号)
将其解压提取里面文件并放到上面的目录中。(https://yum.oracle.com/repo/OracleLinux/OL8/oracle/instantclient21/x86_64/)

下载 libaio1_0.3.113-5_amd64.deb 文件。Debian -- 软件包下载地址选择 -- libaio1_0.3.113-5_amd64.deb (不一定要个版本)
并把文件也放到上面目录中。

创建Dockerfile,COPY里面的内容应按上面的驱动文件实际情况为准。
cat /root/docker_superset/Dockerfile


FROM apache/superset:3.0.0USER root
COPY superset_config.py /app/pythonpath
RUN mkdir /oracledriver
ENV LD_LIBRARY_PATH=/oracledriverCOPY ./oracledriver/adrci /oracledriver/adrci
COPY ./oracledriver/genezi /oracledriver/genezi
COPY ./oracledriver/libclntshcore.so.18.1 /oracledriver/libclntshcore.so.18.1
COPY ./oracledriver/libclntsh.so /oracledriver/libclntsh.so
COPY ./oracledriver/libclntsh.so.18.1 /oracledriver/libclntsh.so.18.1
COPY ./oracledriver/libipc1.so /oracledriver/libipc1.so
COPY ./oracledriver/libmql1.so /oracledriver/libmql1.so
COPY ./oracledriver/libnnz18.so /oracledriver/libnnz18.so
COPY ./oracledriver/libocci.so /oracledriver/libocci.so
COPY ./oracledriver/libocci.so.18.1 /oracledriver/libocci.so.18.1
COPY ./oracledriver/libociei.so /oracledriver/libociei.so
COPY ./oracledriver/libocijdbc18.so /oracledriver/libocijdbc18.so
COPY ./oracledriver/libons.so /oracledriver/libons.so
COPY ./oracledriver/liboramysql18.so /oracledriver/liboramysql18.so
COPY ./oracledriver/ojdbc8.jar /oracledriver/ojdbc8.jar
COPY ./oracledriver/ucp.jar /oracledriver/ucp.jar
COPY ./oracledriver/uidrvci /oracledriver/uidrvci
COPY ./oracledriver/xstreams.jar /oracledriver/xstreams.jarCOPY ./oracledriver/libaio1_0.3.113-5_amd64.deb /oracledriver/libaio1_0.3.113-5_amd64.deb
RUN dpkg -i /oracledriver/libaio1_0.3.113-5_amd64.debRUN pip install cx_oracle psycopg2 pyhive &&\pybabel compile -d /app/superset/translations; exit 0
USER superset

创建本地镜像,在 /root/docker_superset 目录上运行以下命令,留意最后有一个 点,表示当前目录

docker build --no-cache -t superset-pg-ora:3.0.0 . 

在 /root/docker_superset 目录上创建 docker-compose.yml
cat docker-compose.yml


version: '1.0'networks:superset-net:name: ss-netservices:superset:image: superset-pg-ora:3.0.0container_name: supersethostname: supersetrestart: alwaysports:- 8080:8088environment:- TZ=Asia/Shanghainetworks:- superset-netdepends_on:- postgres12postgres12:image: postgres:12.3restart: alwaysvolumes:- /pgdata:/var/lib/postgresql/data- /usr/share/zoneinfo/Asia/Shanghai:/etc/localtimeenvironment:POSTGRES_PASSWORD: passwordnetworks:- superset-net

执行

#起动系统
docker-compose up -d# 创建 superset  的管理员用户
docker exec -it superset superset fab create-admin \--username admin \--firstname Superset \--lastname Admin \--email admin@superset.com \--password admin#升级数据库(包含一部分初始化)
docker exec -it superset superset db upgrade#初始化 Superset
docker exec -it superset superset init

登录后
Oracle的连接串应写成:

oracle+cx_oracle://user:password@ip_address:1521/orcl

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/210787.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

调用win32 api获取电脑名字和系统目录

学习一下几个函数的功能,和调用方式; void CBasenameView::OnDraw(CDC* pDC) {CBasenameDoc* pDoc GetDocument();ASSERT_VALID(pDoc);// TODO: add draw code for native data hereCString str1;TCHAR myname1[50], myname2[50], mydirname1[50], myd…

常见的Linux系统版本

在介绍常见的Linux系统版本之前,首先需要区分Linux系统内核与Linux发行套件系统的不同。Linux系统内核指的是一个由Linus Torvalds负责维护,提供硬件抽象层、硬盘及文件系统控制及多任务功能的系统核心程序。而Linux发行套件系统是我们常说的Linux操作系…

【Vue+Python】—— 基于Vue与Python的图书管理系统

文章目录 🍖 前言🎶一、项目描述✨二、项目展示🏆三、撒花 🍖 前言 【VuePython】—— 基于Vue与Python的图书管理系统 🎶一、项目描述 描述: 本项目为《基于Vue与Python的图书管理系统》,项目…

Minio保姆级教程

转载自:www.javaman.cn Minio服务器搭建和整合 1、centos安装minio 1.1、创建安装目录 mkdir -p /home/minio1.2、在线下载minio #进入目录 cd /home/minio #下载 wget https://dl.minio.io/server/minio/release/linux-amd64/minio1.3、minio配置 1.3.1、添加…

Flutter笔记:滑块及其实现分析1

Flutter笔记 滑块分析1 作者:李俊才 (jcLee95):https://blog.csdn.net/qq_28550263 邮箱 :291148484163.com 本文地址:https://blog.csdn.net/qq_28550263/article/details/134900784 本文从设计角度&#…

SQL命令---删除字段

介绍 使用sql语句删除表字段。 命令 alter table 表名 drop 字段名;例子 删除a表中的name字段。 alter table a drop name;下面是执行删除后的表结构:

微服务实战系列之通信

前言 掰个指头数一数,博主的“微服务实战系列”从无到有,从零走到了十五。如果比作时钟,刚好走过了一刻度。 当初为什么要做这个系列,博主想了又想,私以为作为当下软件领域的几个“hot spot”之一,又乘着…

探秘机器学习核心逻辑:梯度下降的迭代过程 (图文详解)

一 需求解函数 f() 和 g()函数分别为求y值和求导数的函数。 目的:求该函数的最小值: 代码: import numpy as np import matplotlib.pyplot as plt f lambda x : (x - 3.5) ** 2 - 4.5 * x 10 g lambda x : 2 * (x - 3.5) - 4.5x np.l…

架构LAMP

目录 1.什么是LAMP 2.LAMP组成及作用 3.搭建Apache httpd服务 4.编译安装mysqld 服务 5.编译安装PHP 解析环境 6.安装论坛 1.什么是LAMP LAMP架构是目前成熟的企业网站应用模式之一,指的是协同工作的一整套系统和相关软件,能够提供动态Web站点服务…

MATLAB算法实战应用案例精讲-【人工智能】漫谈自动驾驶

目录 常用数据集 一、自动驾驶领域数据集 1. KITTI数据集 2.CityScapes数据集 3.BDD100K数据集

go与ioc

在Go开发服务端程序时,使用IoC(Inversion of Control)机制并不像在Java等语言中那样普遍。Go语言的设计哲学倾向于简洁和直接,更注重代码的可读性和可维护性。 在Go中,通常会使用依赖注入(Dependency Inje…

【Python】视频剪辑小程序

近期遇到一些录制的视频需要剪辑。 手机上剪辑操作很耗时,有几个G的视频,花了一天的空余时间去剪辑。电脑上也有格式工厂,有很方便。 可是学了Pthon,又无意中了解到了moviepy这个库,于是自己写了个简单的视频剪辑程序。…

Windows安装kafka

压缩包下载地址:https://www.apache.org/dyn/closer.cgi?path/kafka/3.6.1/kafka_2.13-3.6.1.tgz 启动kafka步骤 zookeeper-server-start.bat rem 闭命令提示符窗口的命令回显,这样在运行脚本时不会显示脚本的具体命令内容 echo offrem 命令行启动未…

Proteus仿真--8×8LED点阵屏仿电梯数字滚动显示

本文介绍基于88LED点阵屏仿电梯数字滚动显示设计(完整仿真源文件及代码见文末链接) 仿真图如下 其中K1-K5的5个按键分别代表不同楼层,摁下按键后在8X8LED上便会显示到对应楼层的跳变信息,模拟电梯的运作 仿真运行视频 Proteus仿…

nodejs多线程,fork和Worker

一、前言 javascript是单线程执行的,如果想要多线程执行,那么相当于再运行一个node,其实不该理解成多线程,更像是多进程。 二、Worker(‘worker_threads’模块) worker有点类似exec,直接再cmd执行node命令,不同的是两…

《安富莱嵌入式周报》第328期:自主微型机器人,火星探测器发射前失误故障分析,微软推出12周24期免费AI课程,炫酷3D LED点阵设计,MDK5.39发布

周报汇总地址:嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 更新一期视频教程: 【实战技能】 单步运行源码分析,一期视频整明白FreeRTOS内核源码框架和运行…

【STM32】TIM定时器基本定时功能

第一部分:定时器基本定时的功能; 第二部分:定时器的输出比较功能; 第三部分:定时器输入捕获的功能; 第四部分:定时器的编码接口。 1 TIM简介 TIM(Timer)定时器&#…

在OpenCV基于深度学习的超分辨率模型实践

1. 引言 OpenCV是一个开源的计算机视觉库,拥有大量优秀的算法。基于最新的合并,OpenCV包含一个易于使用的接口,主要用于实现基于深度学习方法的超分辨率(SR)。该接口包含预先训练的模型,这些模型可以非常容…

redis中使用事务保护数据完整性

事务是指一个执行过程,要么全部执行成功,要么失败什么都不改变。不会存在一部分成功一部分失败的情况,也就是事务的ACID四大特性(原子性、一致性、隔离性、持久性)。但是redis中的事务并不是严格意义上的事务&#xff…

使用flutter_native_splash替换启动图片,iOS端替换不成功

使用flutter_native_splash替换启动图片,iOS端替换不成功 1、删除App重启手机;2、重新创建一个新的LaunchScreen.storyboard,比如命名为NewLaunchScreen.storyboard,在General里面设置Launch Screen File为这个新的NewLaunchScree…