aceql-http docker 试用

以前有介绍过aceql-http 一个不错的database rest http 暴露,充分利用了tomcat 的好多特性,以下是基于docker 运行的学习

环境准备

  • dockerfile
FROM dalongrong/openjdk11:stretch-jvm-tools
LABEL AUTHOR="rongfengliang"
LABEL EMAIL="1141591465@qq.com"
ENV VERSION=4.0
ENV ACEQL_HTTP_HOST=localhost
WORKDIR /app
RUN wget https://www.aceql.com/rest/soft/${VERSION}/download/aceql-http-${VERSION}.run \
    && chmod +x aceql-http-${VERSION}.run \
    && sh aceql-http-${VERSION}.run \
    && rm -rf aceql-http-${VERSION}.run
ENV PATH=$PATH:/app/aceql-http-${VERSION}/bin
ENV ACEQL_HOME=/app/aceql-http-${VERSION}
COPY aceql-server.properties /app/aceql-http-${VERSION}/conf/aceql-server.properties
COPY entrypoint.sh /entrypoint.sh
RUN chmod +x /entrypoint.sh
EXPOSE 9090
ENTRYPOINT [ "/entrypoint.sh" ]
 
 

简单说明: 基础镜像使用了openjdk11,此镜像集成了一些jvm 性能监控工具,因为 aceql-http 使用了makeself
直接执行就可以解压安装包内容了
entrypoint.sh: 入口

 
#!/bin/sh
aceql-server -start -host ${ACEQL_HTTP_HOST} –port 9090

aceql-server.properties 数据库连接,这个比较简单,为了方便修改为了pg 的(使用docker-compose 的服务)
此文件没有配置用户认证的,如果查看说明以及源码会发现,不配置使用默认,实际上是裸奔的,login 方法直接
返回true,所以如果需要认证,可以使用文档介绍的jwt,具体参考文档

 
# Database names separated by commas
databases = postgres
# Mandatory JDBC properties:
# PostgreSQL example
postgres.driverClassName = org.postgresql.Driver
postgres.url= jdbc:postgresql://postgres:5432/postgres
postgres.username= postgres  
postgres.password= dalong  
 
 
  • docker-compose 服务
version: "3"
services: 
    postgres:
      image: postgres:9.5-alpine
      ports:
      - "5432:5432"
      environment:
      - "POSTGRES_PASSWORD:dalong"
    aceql-http:
      build: ./
      volumes: 
      - "./flame:/app/arthas-output"
      ports:
      - "9090:9090"

启动&&测试

  • 构建镜像
docker-compose build
  • 初始化数据库
CREATE TABLE appdemos (
    id SERIAL PRIMARY KEY,
    appname text
);
CREATE TABLE user_login
(               
  username varchar(255) not null,     
  hash_password varchar(40) not null,
        PRIMARY KEY (username)
);
insert into user_login values ('username', '5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8');
insert into user_login values ('MyUsername', 'eabbec6f31804eb968e2faeaaef150546a595fc3');
  • 请求sessionid

    说明,此处任何的用户账户都可以,因为使用的默认认证,永远返回true,直接看官方文档可能还会迷惑

curl --data-urlencode "password=MySecret" \
 http://localhost:9090/aceql/database/postgres/username/MyUsername/connect

返回内容

 

 

  • insert 数据
curl --data-urlencode "sql=insert into appdemos values (1,'dalongdemo')" http://localhost:9090/aceql/session/ra6x1jbw463x5svw32thonn4l7/execute_update

返回内容

 

 

  • 查询数据
curl --data-urlencode "sql=select * from appdemos" --data "pretty_printing=true" http://localhost:9090/aceql/session/ra6x1jbw463x5svw32thonn4l7/execute_query

返回内容

 

 

说明

以上就是关于aceql-http docker 运行的一些学习,后续可以在学习下jwt 以及自定义认证的

参考资料

https://github.com/rongfengliang/aceql-http-docker
https://github.com/kawansoft/aceql-http/blob/master/aceql-http-4.0-user-guide-server.md#session-management-and-security
https://github.com/kawansoft/aceql-http
https://hub.docker.com/repository/docker/dalongrong/aceql-http

posted on 2020-01-28 11:00  荣锋亮  阅读(489)  评论(0编辑  收藏  举报

导航