使用 Docker 部署
在继续操作之前,我们推荐您先阅读《写在前面》,这可以快速帮助你了解 Ikaros。
此文档仅提供使用默认 H2 数据库的 Docker 运行方式,主要用于体验和测试,在生产环境我们不推荐使用 H2 数据库。
如果需要使用其他数据库部署,我们推荐使用 Docker Compose 部署:使用 Docker Compose 部署
环境搭建
- Docker 安装文档:https://docs.docker.com/engine/install/
我们推荐按照 Docker 官方文档安装 Docker,因为部分 Linux 发行版软件仓库中的 Docker 版本可能过旧。
使用 Docker 镜像
可用的 Ikaros 的 Docker 镜像:
目前 Ikaros 并未更新 Docker 的 latest 标签镜像,主要因为 暂未发布正式版本。我们推荐使用固定版本的标签,比如 ikarosrun/ikaros:v0.20.6
。
ikarosrun/ikaros:v0.20.6
:表示最新的可用镜像,每次发布时都会根据GitHub的标签构建一个新的镜像ikarosrun/ikaros:dev
:表示开发中的镜像,不推荐使用,每次Pull Request合并到主分支都会构建并覆盖该镜像。。
后续文档以 ikarosrun/ikaros:v0.20.6
为例。
创建容器
docker run \
-it -d \
--name ikaros \
-p 9999:9999 \
-v ~/.ikaros:/root/.ikaros \
ikarosrun/ikaros:v0.20.6 \
--ikaros.security.initializer.master-username=tomoki \
--ikaros.security.initializer.master-password=tomoki信息注意:此命令默认使用自带的 H2 Database 数据库。如需使用 PostgreSQL,请参考:使用 Docker Compose 部署
- -it:开启输入功能并连接伪终端
- -d:后台运行容器
- --name:为容器指定一个名称
- -p:端口映射,格式为
主机(宿主)端口:容器端口
。 - -v:工作目录映射。形式为:
-v 宿主机路径:/root/.ikaros
,后者不能修改。
变量详解:
提示r2dbc的数据库配置,和flyway的数据库配置,需要连同一个数据库,这意味着ip和端口和用户名密码都必须相同!!!
参数名 是否必须 描述 spring.r2dbc.url
是 数据库连接地址,详细可查阅下方的 数据库配置
spring.r2dbc.username
是 数据库用户名 spring.r2dbc.password
是 数据库密码 spring.sql.init.platform
是 数据库平台名称,支持 postgresql
、h2
spring.flyway.url
是 flyway数据库链接地址,详细可查阅下方的 数据库配置
spring.flyway.user
是 数据库用户名,与 spring.r2dbc.username
的值相同spring.flyway.password
是 数据库密码,与 spring.r2dbc.password
的值相同ikaros.security.initializer.master-username
否 初始超级管理员用户名, 默认 tomoki
ikaros.security.initializer.master-password
否 初始超级管理员密码, 第一次运行程序打印在控日志里 ikaros.external-url
否 外部访问地址,需要根据自己的情况进行修改,影响的功能包括不限于API文档等,比如: https://demo.ikaros.run ikaros.security.expiry.access-token-day
否 AccessToken
有效期,单位天,默认3天过期ikaros.security.expiry.refresh-token-month
否 RefreshToken
有效期,单位月,默认3个月过期数据库配置:
链接方式 链接地址格式 spring.sql.init.platform
R2dbc PostgreSQL r2dbc:pool:postgresql://{HOST}:{PORT}/{DATABASE}
postgresql R2dbc H2 Database r2dbc:h2:file:///${ikaros.work-dir}/db/ikaros?MODE=MySQL&DB_CLOSE_ON_EXIT=FALSE
h2 Flyway PostgreSQL jdbc:postgresql://{HOST}:{PORT}/{DATABASE}
postgresql Flyway H2 Database jdbc:h2:file:${ikaros.work-dir}/database/ikaros
h2 链接地址格式内的以下部分需要替换:
{HOST}
: 你的数据库连接配置的地址,域名或者IP{PORT}
:你的数据库连接配置的端口{DATABASE}
: 你的数据库名称
用浏览器访问
/console
即可进入 Ikaros 管理页面,用户名和密码为启动参数中的master-username
和master-password
。提示如没有用这两个参数启动,则默认的用户名是
tomoki
,密码在打印在日志里(只有首次运行会打印密码)。
升级版本
拉取新版本镜像(请选择最新的标签替换下方的
v0.20.6
)docker pull ikarosrun/ikaros:v0.20.6
停止运行中的容器
docker stop ikaros
docker rm ikaros备份数据(重要)
cp -r ~/.ikaros ~/ikaros.archive
需要注意的是,
ikaros.archive
文件名不一定要根据此文档命名,这里仅仅是个示例。更新 Ikaros
修改版本号后,按照最初安装的方式,重新创建容器即可。
docker run \
-it -d \
--name ikaros \
-p 9999:9999 \
-v ~/.ikaros:/root/.ikaros \
ikarosrun/ikaros:v0.20.6 \
--ikaros.security.initializer.master-username=tomoki \
--ikaros.security.initializer.master-password=tomoki