docker compose fullstack example -- keycloak web grant-type: password

Posted 柳暗花明

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了docker compose fullstack example -- keycloak web grant-type: password相关的知识,希望对你有一定的参考价值。

fastapi-react-postgres-keycloak-sso

https://github.com/fanqingsong/fastapi-react-postgres-keycloak-sso

 

version: "3"

services:
  nginx:
    image: nginx:1.17
    volumes:
      - ./nginx/nginx.conf:/etc/nginx/conf.d/default.conf
      - ./logs/nginx:/var/log/nginx
    ports:
      - 80:80
    depends_on:
      - frontend
      - backend

  backend:
    restart: unless-stopped
    build:
      context: backend
      dockerfile: Dockerfile
    env_file:
      - .env
    environment:
      PYTHONPATH: .
      DATABASE_URL: postgresql://$POSTGRES_USER:$POSTGRES_PASSWORD@postgres:5432/$POSTGRES_USER
    volumes:
      - ./logs/backend:/logs
    ports:
      - 8888:8888
    depends_on:
      - postgres
      - keycloak

  frontend:
    build:
      context: frontend
      dockerfile: Dockerfile
    ports:
      - 8000:8000
    environment:
      NODE_ENV: development
      CHOKIDAR_USEPOLLING: "true"

  keycloak:
    image: jboss/keycloak:12.0.4
    environment:
      DB_VENDOR: POSTGRES
      DB_SCHEMA: public
      DB_ADDR: keycloak_postgres
      DB_DATABASE: $KEYCLOAK_DB_DATABASE
      DB_USER: $KEYCLOAK_DB_USER
      DB_PASSWORD: $KEYCLOAK_DB_PASSWORD
      KEYCLOAK_USER: $KEYCLOAK_ADMIN_USERNAME
      KEYCLOAK_PASSWORD: $KEYCLOAK_ADMIN_PASSWORD
      JDBC_PARAMS: "useSSL=false"
    ports:
      - 8080:8080
    depends_on:
      - keycloak_postgres

  postgres:
    image: postgres
    restart: always
    environment:
      POSTGRES_USER: $POSTGRES_USER
      POSTGRES_PASSWORD: $POSTGRES_PASSWORD
    ports:
      - 5432:5432
    volumes:
      - postgres_data:/var/lib/postgresql/data

  keycloak_postgres:
    image: postgres
    volumes:
      - keycloak_postgres_data:/var/lib/postgresql/data
    environment:
      POSTGRES_DB: $KEYCLOAK_DB_DATABASE
      POSTGRES_USER: $KEYCLOAK_DB_USER
      POSTGRES_PASSWORD: $KEYCLOAK_DB_PASSWORD

volumes:
  postgres_data:
  keycloak_postgres_data:

 

python-keycloak

https://python-keycloak.readthedocs.io/en/latest/

from keycloak import KeycloakOpenID

# Configure client
keycloak_openid = KeycloakOpenID(server_url="http://localhost:8080/auth/",
                                 client_id="example_client",
                                 realm_name="example_realm",
                                 client_secret_key="secret")

# Get WellKnown
config_well_known = keycloak_openid.well_known()

# Get Code With Oauth Authorization Request
auth_url = keycloak_openid.auth_url(
    redirect_uri="your_call_back_url",
    scope="email",
    state="your_state_info")

# Get Access Token With Code
access_token = keycloak_openid.token(
    grant_type=\'authorization_code\',
    code=\'the_code_you_get_from_auth_url_callback\',
    redirect_uri="your_call_back_url")


# Get Token
token = keycloak_openid.token("user", "password")
token = keycloak_openid.token("user", "password", totp="012345")

# Get token using Token Exchange
token = keycloak_openid.exchange_token(token[\'access_token\'], "my_client", "other_client", "some_user")

# Get Userinfo
userinfo = keycloak_openid.userinfo(token[\'access_token\'])

# Refresh token
token = keycloak_openid.refresh_token(token[\'refresh_token\'])

# Logout
keycloak_openid.logout(token[\'refresh_token\'])

 

Docker-compose容器

Docker-compose容器 快速单机编排

Docker-compose前言

  • 我们知道使用一个 Dockerfile 模板文件一次只能够定义一个单独的应用容器(镜像),如果需要定义多个容器就需要使用服务编排技术
  • Docker Compose 是 Docker 的官方产品 ,用来对多个容器进行服务编排
  • Dockerfile 可以让用户管理一个单独的应用容器;而 Compose 则允许用户在一个模板(yaml格式)中定义一组上下相关联的应用容器(被称为一个 project,即项目),例如一个 web项目由apache容器 + 后端的Mysql数据库容器 + php容器组成

Docker-Compose 简介

Docker-Compose 用来实现Docker容器快速编排

  • 通过 Compose,不需要使用shell脚本来启动容器,而使用 YAML 文件来配置应用程序需要的所有服务,然后使用一个命令,根据 YAML 的文件配置创建并启动所有服务
  • Docker-Compose 项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排
  • Docker-Compose 将所管理的容器分为三层
    • 工程(project):一个工程包含多个服务
    • 服务(service):一个服务当中可包括多个容器实例
    • 容器(container)
  • Docker-Compose 运行目录下的所有文件(docker-compose.yml、extends文件 或 环境变量文件等)组成一个工程,若无特殊指定 工程名即为当前目录名
  • 一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像、参数、依赖
  • 一个服务当中可包括多个容器实例,**但是:Docker-Compose 并没有解决负载均衡的问题,**因此需要借助其它工具实现服务发现及负载均衡,比如 Consul 技术
  • Docker-Compose 的工程配置文件默认为 docker-compose.yml,可通过环境变量 COMPOSB_FILE 或 -f 参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器
  • 使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。在工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个wieb项目,除了web服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等
  • Compose 允许用户通过一个单独的 docker-compose.yml 模板文件(YAML格式)来定义一组相关联的应用容器为一个项目 (project)
  • Docker-Compose 项目由 Python 编写,调用 Docker 服务提供的API来对容器进行管理。因此,只要所操作的平台支持 Docker API,就可以在其上利用Compose 来进行编排管理

YAML 文件格式 及 编写注意事项

  • yaml 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。类似于XML数据描述语言,语法比 XMAL简单的很多
  • YAML数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号[]括起来, hash用花括号{}括起来

ps:使用 YAML时需要注意下面事项

  • 使用缩进表示层级关系,不支持制表符tab键缩进,只能使用空格键缩进
  • 缩进长度没有限制,只要元素对齐就表示这些元素属于一个层级
  • 通常开头缩进2个空格
  • 字符后缩进1个空格,如冒号:空格 逗号,空格 横杠-空格文本之间的空格>
  • 用#号注释
  • 如果包含特殊字符用单引号’ '引起来
  • 布尔值必须用引号" "括起来
  • 区分大小写
  • 字符串可以不用引号标注

YAML支持的数据结构:

对象:键值对的集合,又称为映射(map)/ 哈希(hashes) / 字典(dictionary)

# YAML表示
age : 12
name : huang
 
# 对应的Json表示
{'age':12,'name':'huang'}

数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)

使用连字符(-)表示:
# YAML表示
- a
- b
- 12
# 对应Json表示
['a','b',12]

纯量(scalars):单个的、不可再分的值

部署Compose工程

Docker-compose.yml 文件配置指令参考

  • version:指定此yml文件基于的compase的版本
  • services:指定创建容器的服务选项
    • 服务名:例如nginx等
      • hostname:容器主机名
      • build :指定构建镜像上下文路径
        • context:上下文路径
        • dockerfile:指定构建镜像的 Dockerfile 文件名
      • ports:暴露容器端口,与-p相同,但端口不能低于60;例如:- 1234:80
      • networks:加入顶级networks下配置的网络
      • deploy:指定部署和运行服务相关配置,只能在Swarm模式使用
      • volumes:挂载宿主机路径或命令卷
  • image:指定容器运行的镜像
  • command:执行命令,覆盖默认命令
  • container_name:指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale(扩展)
  • environment:添加环境变量
  • restart:重启策略,重启策略是no,always,no-failure,unless-stoped
    • no,默认策略,在容器退出时不重启容器
    • on-failure,在容器非正常退出时(退出状态非0),才会重启容器
    • on-failure:3,在容器非正常退出时重启容器,最多重启3次
    • always,在容器退出时总是重启容器
    • unless-stopped,在容器退出时总是重启容器,但是不考虑在 Docker守护进程启动时就已经停止了的容器
  • networks:配置网络,指定网卡设备等

Docker-compose 基本命令

基本的使用格式

docker-compose [options] [COMMAND][ARGS...]

相关选项:

--verbose:输出更多调试信息
--version:打印版本并退出
-f:使用特定的compose模板文件,默认为docker-compose.yml
-p:指定项目名称,默认使用目录名称

Docker Compose 常用命令:

build重新构建服务
ps列出容器
up创建和启动容器
exec在容器里面执行命令
scale指定一个服务容器启动数量
top显示正在运行的容器进程
logs查看服务容器的输出
down删除容器、网络、数据卷和镜像
stop/start/restart停止/启动/重启服务

Docker Compose 文件结构

yum install -y tree
tree /opt/compose_nginx
/opt/compose_nginx/
├── docker-compose.yml					#创建模板脚本
├── nginx
│?? ├── Dockerfile						#创建容器脚本
│?? ├── nginx-1.12.0.tar.gz				#复制源码包
│?? └── run.sh							#启动服务脚本
└── wwwroot
    └── index.html						#站点网页

准备依赖文件

mkdir -p /opt/compose_nginx/nginx /opt/compose_nginx/wwwroot
cd /opt/compose_nginx/nginx
cp nginx-1.12.0.tar.gz ./

vim run.sh
#!/bin/bash
/usr/local/nginx/sbin/nginx

vim Dockerfile
#基于基础镜像
FROM centos:7
#用户信息
MAINTAINER this is nginx image <wl>
#添加环境包
RUN yum -y update
RUN yum -y install pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx
#上传nginx软件压缩包,并解压
ADD nginx-1.12.0.tar.gz /usr/local/src/
#指定工作目录
WORKDIR /usr/local/src/nginx-1.12.0
RUN ./configure \\
--prefix=/usr/local/nginx \\
--user=nginx \\
--group=nginx \\
--with-http_stub_status_module && make && make install
ENV PATH /usr/local/nginx/sbin:$PATH
#指定http和https端口
EXPOSE 80
EXPOSE 443
//方法一:
RUN echo "daemon off;" >> /usr/local/nginx/conf/nginx.conf			#关闭 nginx 在后台运行
#添加宿主机中run.sh到容器中
ADD run.sh /run.sh
RUN chmod 755 /run.sh
CMD ["/run.sh"]
//方法二:
ENTRYPOINT [ "/usr/local/nginx/sbin/nginx", "-g", "daemon off;" ]


echo "<h1>this is test web</h1>" > /opt/compose_nginx/wwwroot/index.html

编写配置文件docker-compose.yml

vim /opt/compose_nginx/docker-compose.yml
version: '3'
services:
  nginx:
    hostname: nginx
    build:
      context: ./nginx
      dockerfile: Dockerfile
    ports:
      - 1216:80
      - 1217:443
    networks:
      - lnmp
    volumes:
      - ./wwwroot:/usr/local/nginx/html
networks:
  lnmp:


cd /opt/compose_nginx/
docker-compose -f docker-compose.yml up -d
----------------------------------------------------------------------------------------------------------
-f, --file FILE :使用特定的 compose 模板文件,默认为 docker-compose.yml
-p, --project-name NAME :指定项目名称,默认使用目录名称
-d :在后台运行
----------------------------------------------------------------------------------------------------------

docker ps -a
CONTAINER ID   IMAGE                 COMMAND     CREATED              STATUS              PORTS                                         NAMES
b48dceee248f   compose_nginx_nginx   "/run.sh"   About a minute ago   Up About a minute   0.0.0.0:1216->80/tcp, 0.0.0.0:1217->443/tcp   compose_nginx_nginx_1

cd /opt/compose_nginx/
docker-compose ps					#必须在docker-compose.yml所在目录执行此命令

浏览器访问:http://192.168.80.15:1216

创建compose目录,创建Dockerfile文件

创建后面用于测试的站点目录,创建compose的yml文件

简历运行脚本

进入目录后进行编排

容器创建成功


总结


1.Docker-Compose将所管理的容器分为三层,分别是 工程(project),服务(service)以及容器(container),服务由默认配置文件docker-compose.yml来定义,容器时通过dockerfile编写的脚本定义
2.通过Compose 编排,一次能将多个镜像一起编排。缺点:Compose只能单机编排,不能跨主机,跨主机可以用 swarm 和 k8s
3.docker swarm :docker集群管理调度工具,可以多台主机构建成一个docker集群,用户可以通过api接口管理多个主机上的docker
4.K8S kubernets谷歌开发的一款开源容器编排工具,占有80%以上的市场份额
5.执行 docker-compose 命令必须在 dicker-compose.yml 所在目录下执行

以上是关于docker compose fullstack example -- keycloak web grant-type: password的主要内容,如果未能解决你的问题,请参考以下文章

Docker-compose容器

Docker-compose容器

Docker-compose容器

Docker快速入门——Docker-Compose

idea 使用docker插件部署docker-compose失败?

“docker-compose”命令为 docker-compose.yml 文件设置路径