资讯专栏INFORMATION COLUMN

Davinci一键部署 | 论如何三句代码跑起Davinci

ivan_qhz / 3144人阅读

摘要:来源敏捷大数据作者汤波成宜信技术学院导读之前喜欢的小伙伴儿在安装部署遇见问题时需要在区等待技术人员的解答。现在不用怕啦,社区热心用户白菜君帮我们支持了一键启动,以后只需寥寥几行代码,就能舒畅的起来了。

来源:敏捷大数据

作者:汤波成

宜信技术学院

 

导读:之前喜欢Davinci的小伙伴儿在安装部署Davinci遇见问题时需要在github issue区等待技术人员的解答。现在不用怕啦,社区热心用户白菜君帮我们支持了docker-composer一键启动,以后只需寥寥几行代码,Davinci就能舒畅的run起来了。还等什么,赶紧部署起来吧~

敲重点

Davinci Docker原部署教程在这里:

https://github.com/edp963/dav...

里面会不定时更新

记得收藏啊!!

下面是部署教程:

一、环境要求

安装docker后的 windows, linux, mac。

检查是否有docker-compose命令(安装docker后默认会有,否则请手动安装)。

二、完整步骤

git clone https://github.com/edp963/davinci-docker.git
cd /d davinci-docker
# docker build -t="edp963/davinci:v0.3.0-beta.4" .
# 修改docker-compose.yml中邮箱配置docker-compose up -d 复制代码

完成!

你没看错!

就这么简单的完成了!

这样就可以安装部署Davinci了!

再也不用担心安装Davinci时遇到问题了!

然鹅,在部署Docker镜像过程中,我们的白菜君是怎么想的呢?让我们继续往下看:

内容会不定时更新哦,所以请大家收藏这个地址:

https://github.com/edp963/dav...

三、Docker支持环境变量列表

四、原理分析

制作Davinci Docker镜像

1、Dockfile分析

FROM java:8-jre
LABEL MAINTAINER="edp_support@groups.163.com"
# 从github上下载分发包并解压
RUN cd /  
&& mkdir -p /opt/davinci 
&& wget
https://github.com/edp963/davinci/releases/download/v0.3.0-beta.4/davinci-assembly_3.0.1-0.3.0-SNAPSHOT-dist-beta.4.zip
  && unzip
davinci-assembly_3.0.1-0.3.0-SNAPSHOT-dist-beta.4.zip -d /opt/davinci
# 将phantomjs打包到镜像
ADD phantomjs-2.1.1 /opt/phantomjs-2.1.1
# 数据库初始化脚本,等待数据库就绪后启动spring boot
ADD bin/start.sh /opt/davinci/bin/start.sh
# docker镜像是静态的,因此配置文件中的配置需要用环境变量传递,详见12factor# https://12factor.net/zh_cn/
ADD config/application.yml
/opt/davinci/config/application.yml
# 预设davinci必备的两个环境变量ENV
DAVINCI3_HOME /opt/davinciENV PHANTOMJS_HOME /opt/phantomjs-2.1.1
WORKDIR /opt/davinci
# 为什么使用CMD而不是ENTRYPOINT? 因为CMD可以在docker run的时候被替代# 在使用compose或K8S时,很有可能要在启动前执行其它脚本,而不是直接运行# start-server.sh# 在多带带docker run且不附加任何命令时,以下命令默认执行
CMD ["./bin/start-server.sh"]
EXPOSE 8080复制代码

start.sh

#!/bin/bash
# 将sql脚本经过mysql8兼容处理后,写入/initdb目录# /initdb 目录是与mysql容器共享目录# mysql容器将在启动时执行 /docker-entrypoint-initdb.d 中的所有脚本
cd /opt/davinci/bin/mkdir /initdbcat
davinci.sql > /initdb/davinci.sqlsed -i "1iSET
GLOBAL log_bin_trust_function_creators = 1;" /initdb/davinci.sql
 
# 由于docker compose中启动顺序管理交给了容器自己# 详见
https://docs.docker.com/compose/startup-order/# 因此我们需要用curl探测mysql端口,当接受数据字节大于0时认为# 数据库可以连通,接下来我们执行davinci spring boot主程序set
-e
host="$1"shiftcmd="$@"
until [ $(curl -I -m 10 -o /dev/null -s -w %{size_download} $host) -gt 0 ]; do  >&2 echo
"database is unavailable - sleeping"  sleep 1done
source $cmd复制代码

2、构建镜像

docker build -t="edp963/davinci:v0.3.0-beta.4" .复制代码

3、 Docker Compose

version: "3.6"services:  davinci:   
environment:      - MYSQL_CONN=jdbc:mysql://mysql:3306/davinci0.3?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true      - DB_USER=root      - DB_PWD=abc123123      - MAIL_HOST=smtp.163.com      - MAIL_PORT=465      - MAIL_STMP_SSL=true      - MAIL_USER=xxxxxx@163.com      - MAIL_PWD=xxxxxxxx      - MAIL_NICKNAME=davinci    image: "edp963/davinci:v0.3.0-beta.4"    ports:     
- 58080:8080    # 等待mysql就绪后再启动spring boot主程序    command: ["./bin/start.sh",
"mysql:3306", "--", "start-server.sh"]    restart: always    volumes:      - davinci_logs:/opt/davinci/logs      - davinci_userfiles:/opt/davinci/userfiles      - davinci_initdb:/initdb  #共享给mysql作数据初始化  mysql:    image: mysql:8    restart: always    environment:      - MYSQL_ROOT_PASSWORD=abc123123      - MYSQL_DATABASE=davinci0.3    volumes:      - mysql_data:/var/lib/mysql      # 初始化脚本源自davinic容器的initdb目录      - davinci_initdb:/docker-entrypoint-initdb.d:ro   
volumes:  davinci_userfiles:  davinci_logs: 
davinci_initdb:  mysql_data:复制代码

小提示:docker-compose.yml环境变量配置K=V中不能出现空格,V也不能用双引号包裹

4、Docker Compose启动

docker-compose up -d 复制代码

5、仅Docker启动(使用外部数据库)

docker run -p 58081:8080 -e MYSQL_CONN="jdbc:mysql://yourmysqlserver:3306/davinci0.3?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true" 
-e DB_USER="root" -e DB_PWD="pwd" 
-e MAIL_HOST="smtp.163.com"
-e MAIL_PORT="465"
-e MAIL_STMP_SSL="true" 
-e MAIL_USER="xxxxxx@163.com"  
-e MAIL_PWD="xxxxxxx" 
-e MAIL_NICKNAME="davinci_sys" 
edp963/davinci:v0.3.0-beta.4复制代码

6、使用更丰富的配置

可以在宿主中添加一些配置文件,查看davinci配置:https://github.com/edp963/dav...

然后docker run 时将其挂载到 /opt/davinci/config

docker run -p 58081:8080 -e MYSQL_CONN="jdbc:mysql://yourmysqlserver:3306/davinci0.3?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true" 
-e DB_USER="root" -e DB_PWD="pwd" 
-e MAIL_HOST="smtp.163.com"  -e MAIL_PORT="465" -e MAIL_STMP_SSL="true" 
-e MAIL_USER="xxxxxx@163.com"  -e MAIL_PWD="xxxxxxx" 
-e MAIL_NICKNAME="davinci_sys" 
-v/etc/davinci:/opt/davinci/config 
edp963/davinci:v0.3.0-beta.4

 

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/27753.html

相关文章

  • 通用图床服务架构解析(百万级回源/天)

    摘要:转发通过,将请求通过负载均衡,均衡给后端处理的服务。图床同时也支持同步上传回调通知的方式,将图片上传结果反馈给业务方。 Hulk 图床是支持 360 公司绝大部分业务的图片服务,支持多种图片处理功能,如:裁剪、压缩、滤镜、pHash 计算、人脸识别、格式转换、gif 首帧提取……等等,支持的业务线包括:搜索、图搜、新闻、信息流、广告……等等,每天 CDN 回源图床后端 150+ 亿 P...

    XFLY 评论0 收藏0
  • 通用图床服务架构解析(百万级回源/天)

    摘要:转发通过,将请求通过负载均衡,均衡给后端处理的服务。图床同时也支持同步上传回调通知的方式,将图片上传结果反馈给业务方。 Hulk 图床是支持 360 公司绝大部分业务的图片服务,支持多种图片处理功能,如:裁剪、压缩、滤镜、pHash 计算、人脸识别、格式转换、gif 首帧提取……等等,支持的业务线包括:搜索、图搜、新闻、信息流、广告……等等,每天 CDN 回源图床后端 150+ 亿 P...

    Karrdy 评论0 收藏0

发表评论

0条评论

ivan_qhz

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<