1.secret management 的作用

  用来存储 其他人不想看到 的数据

2.secret management

  存在 swarm manager 节点 raft database 里。

  secret 可以 assign 给一个 service (or container), 这个 sevice 就能看到这个secret了

  在 container 内部 secret 看起来像文件, 但实际是在内存中

3. secret 的 操作

  创建

    从文件内创建

      vim password

        #password  内容

          123456a

    创建 secret

      docker secret create my-pass password

    删除 password 文件

      rm -rf ./password

    从命令行输入创建

      echo '123456a' | docker secret create my-pass2 -

  查看

    docker secret ls

  删除

    docker secret rm my-pass2

4. secret 的使用

  创建 service 的时候指定 secret

    docker service create --name client --secret my-pass busybox sh -c "while true; do sleep 3600; done"

  查看 service 服务器 位置

    docker service ps client

  在 指定服务器 查看 container id

    docker ps

  进入容器

    docker exec -it [container_id] sh

  查看指定的密码

    cat /run/secrets/my-pass

5. mysql 案例

  创建 mysql service 指定文件根目录 密码文件为 /run/secrets/my-pass

    docker service create --name db --secret my-pass -e MYSQL_ROOT_PASSWORD_FILE=/run/secrets/my-pass mysql:5.7.27

  查看所在服务器位置

    docker service ps db

  在 指定服务器 查看容器id 并进入

    docker ps

    docker exec -it [container_id] sh

  查看docker secret 密码  并 进入mysql

      cat /run/secrets/my-pass

      mysql -uroot -p[my-pass]   

    或简写为:

      mysql -uroot -p$(cat /run/secrets/my-pass)

6. 在 docker stack 中的使用

  编辑 docker-compose.yml

   在各个 service 下添加

    secrets 参数 和 environment 参数

    eg:

      services:

         web:

        image: wordpress

        secrets:

           - my-pass

        environment:

           WORDPRESS_DB_HOST: mysql

         WORDPRESS_DB_PASSWORD_FILE: /run/secrets/my-pass

        ...

  eg: docker-compose.yml

version: '3.1'

services:

db:

image: mysql:5.7.27

volumes:

- db_data:/var/lib/mysql

environment:

MYSQL_ROOT_PASSWORD_FILE: /run/secrets/db_root_password

MYSQL_DATABASE: wordpress

MYSQL_USER: wordpress

MYSQL_PASSWORD_FILE: /run/secrets/db_password

secrets:

- db_root_password

- db_password

wordpress:

depends_on:

- db

image: wordpress:latest

ports:

- "8888:80"

environment:

WORDPRESS_DB_HOST: db:3306

WORDPRESS_DB_USER: wordpress

WORDPRESS_DB_PASSWORD_FILE: /run/secrets/db_password

secrets:

- db_password

secrets:

db_password:

file: password.txt

db_root_password:

file: password.txt

volumes:

db_data:

6. 根据上述的 docker-compose.yml 创建 service

  docker stack deploy wordpress -c=docker-compose.yml

  查看 mysql 所在的服务器

  docker service ls

  docker service [container_name | container id]

  查看所在服务器的 容器 id

  docker ps

  进入 mysql 容器

  docker exec -it [container_id] /bin/bash

  mysql -uroot -p[your setting password]

  能登陆即可

  或能访问 192.168.205.10 也行

36. docker swarm docker secret 的使用和管理的更多相关文章

  1. Dockerfile & Docker Swarm & Docker Stack & Docker Compose

    Dockerfile 通俗地讲,它是为了指导单个镜像从无到有的构建过程.如果你镜像是从Docker registry上面拉下来的,那就用不到这个文件:如果你是自己的应用,想打包成镜像,那就需要这个文件 ...

  2. 37. docker swarm docker service 的更新

    在service 运行的情况下 进行更新 1. 创建 名为 demo 的 overlay 网络 docker network create -d overlay demo 2. 创建 python-f ...

  3. Docker集群管理(三)—— docker swarm mode基础教程

    docker从1.12版(及后续版本)集成了swarmkit.可以方便的实现docker集群.它有哪些特点呢: 集成了集群功能 分散设计:manager和worker两种节点. 声明式服务模式 可伸缩 ...

  4. Docker 三剑客之 Docker Swarm

    上一篇:Docker 三剑客之 Docker Compose 阅读目录: Docker Machine 创建 Docker 主机 Docker Swarm 配置集群节点 Docker Service ...

  5. Docker,Docker Compose,Docker Swarm,Kubernetes之间的区别

    Dcoker Docker 这个东西所扮演的角色,容易理解,它是一个容器引擎,也就是说实际上我们的容器最终是由Docker创建,运行在Docker中,其他相关的容器技术都是以Docker为基础,它是我 ...

  6. docker swarm 搭建与服务更新

    一,docker swarm 是什么 Docker Swarm.Docker Machine与Docker Compose号称Docker三剑客Docker Swarm 和 Docker Compos ...

  7. Docker Swarm 高可用详解

    Docker Swarm 高可用详解 Manager管理节点宕机后其他管理节点仍然可以使用管理 intermal distributed state store:内部分布式状态存储同步共享到每个节点. ...

  8. Docker compose 与 Docker swarm

    安装 docker :https://www.cnblogs.com/klvchen/p/8468855.html 安装 docker-compose : https://www.cnblogs.co ...

  9. docker --swarm创建一个集群

    如果搭建错误可以强制脱离集群网络: docker swarm leave --force 初始化集群网络管理节点: docker swarm init --advertise-addr 10.101. ...

随机推荐

  1. PyPI提供双因素身份验证(2FA),已提高下载安全性

    前天,Python的核心开发团队宣布PyPI现在提供双因素身份验证(2FA),以提高Python包下载的安全性,从而降低未经授权的帐户访问的风险.该团队宣布将在Python Package Index ...

  2. mvn 编译报错mavn sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested targ

    mavn 编译报错: mavn sun.security.validator.ValidatorException: PKIX path building failed: sun.security.p ...

  3. 一个web项目中web.xml<context-param>的作用

    转   <context-param>的作用:web.xml的配置中<context-param>配置作用1. 启动一个WEB项目的时候,容器(如:Tomcat)会去读它的配置 ...

  4. cf221 D. Little Elephant and Array

    题解真的是太神奇了2333 用离线和树状数组(为什么感觉和HH的项链是的,什么鬼),比较巧妙的是他把整个数列分成几段.用一个vector来记录每个数出现的位置.一共就是data[a[i]][sz]-- ...

  5. 使用git提交远程仓库

    git pull    更新 git add 文件名   将文件添加到暂存区 git commit -m ‘注释’   提交 git push origin master   提交到远程仓库

  6. 【转】ASP.NET Core 2.0中的HttpContext

      ASP.NET Core 2.0中的HttpContext相较于ASP.NET Framework有一些变化,这边列出一些之间的区别.   在ASP.NET Framework中的 System. ...

  7. 3.2Adding custom methods to mappers(在映射器中添加自定义方法)

    3.2Adding custom methods to mappers(在映射器中添加自定义方法) 有些情况下,我们需要实现一些MapStruct无法直接自动生成的复杂类型间映射.一种方式是复用其他已 ...

  8. 解决Java POI 导出Excel时文件名中文乱码,兼容浏览器

    String agent = request.getHeader("USER-AGENT").toLowerCase(); response.setContentType(&quo ...

  9. javascript中的私有作用域

    我们知道js中所有的块级作用域都是无效的,块级作用域内的变量,在外部仍然可以被读取,其实是申明在外部的.如何实现变量的私有化,只在块级作用域起效,避免污染全局的变量呢.而且,挂载在全局的变量很难被回收 ...

  10. MFC 实现CTreeCtrl单选

    void CDepartmenManager::SetUncheck(HTREEITEM hTree) { if (!hTree){ return; } m_DePartmentView.SetChe ...