zoukankan      html  css  js  c++  java
  • 零基础用Docker部署微服务

    1. docker架构

    这里的Client和DOCKER_HOST(docker server)都是在本地的,docker仓库Registry是在远程的;

    Client的docker命令通过Docker daemon与docker server进行交互;

    images镜像是由应用已经被docker打包好的镜像,如java、nginx的镜像,这些镜像可以运行在容器containers里;

    每一个container容器都是运行在docker server(宿主机)上的,每一个container容器都是隔离的、独立的;

    每一个container容器相当于一个Linux操作系统,每一个container容器都有自己的ip地址,所以可以在不同的container内部设置相同的端口号,宿主机不同的端口号映射到不同的容器

    Docker是容器化技术的实现。

    2. Docker的安装

     7、安装Docker

    sudo yum install -y docker-ce

    8、启动

    systemctl start docker

    如果把docker加入到开机启动 systemctl enable docker

    查看docker是否运行 ps -ef | grep docker

    9. 查看docker版本

    docker version

     

    3. 配置阿里云上docker加速的地址

    来源:https://cr.console.aliyun.com/cn-hangzhou/mirrors

    4. docker常用命令

    4.1 镜像相关命令

     在docker仓库查找被docker打包的镜像: docker search java 

     利用docker下载java8: docker pull java:8

    查看本地安装的docker镜像: docker images

    删除指定镜像: docker rmi java

    4.2 容器相关命令

    新建并启动容器

    使用docker run命令即可新建并启动容器,下面是一些常用的参数:

    比如新建并启动一个Nginx:

    docker run -d -p 8100:80 nginx

     

    如果当前没有nginx镜像,那么会先自动下载该nginx镜像。

    通过浏览器访问:

    列出当前运行容器

    docker ps

    如图可以看到镜像的名称IMAGE,对应的CONTAINER_ID,以及PORTS。

    停止容器

    docker stop CONTAINER_ID || NAMES

    强制停止容器

    docker kill  CONTAINER_ID 

     

    启动已停止的容器

    docker start CONTAINER_ID 

     

    查看容器所有信息

    docker inspect CONTAINER_ID 

     

    查看容器日志

    持续输出日志(展示88行

    docker logs --tail=88 -f CONTAINER_ID(OR NAMES) 

    docker container logs CONTAINER_ID 

     

    查看容器里的进程

    docker top CONTAINER_ID 

     

    查看已经创建的容器

    docker ps -a

    进入运行的容器(在docker容器中使用jmap等命令查看jvm内存等信息)

    docker container exec -it CONTAINER_ID /bin/bash 或 docker container exec -it CONTAINER_ID sh

     

    退出容器

     exit

    重命名一个容器

    docker rename old_name new_name 

    删除容器

    docker ps -a 查看所有容器(包括未运行的容器)

    docker rm CONTAINER_ID 

    删除镜像

    docker images

    docker rmi IMAGE ID

    查看一个容器对应的端口映射

    docker port 容器名name

     4.3 Dockerfile常用命令

     5. 构建一个自己定义的nginx docker镜像

    创建了一个目录docker,进入该目录下

    vim Dockerfile

    内容如下:

    # Dockerfile文件,自定义一个nginx的index.html
    FROM nginx
    RUN echo '<h1>This is my nginx Dockerfile<h1>' > /usr/share/nginx/html/index.html

    意思是先获得nginx官方镜像,然后我将运行的container容器中nginx的目录下的index.html替换成我的内容。

    在Dockerfile文件所在的目录下,执行 

    docker build -t nginx:mynginx .

    mynginx就是一个tag,相当于版本号,"."表示Dockerfile文件所在的路径,在当前目录下。

     现在,查看一下本地镜像

    docker images

     

    现在已经有本地镜像了,下一步就是新建容器并且运行

    docker run -d -p 8101:80 nginx:mynginx

    用浏览器访问一下

     

    自定义nginx镜像大功告成!

    6. 简单使用docker部署一个微服务项目

    这里打算部署一个eureka server,端口号8200。

    1. 首先把项目mvn clean install,目的是将项目和项目所依赖的jar包打成一个可执行的jar包,java -jar jar包名.jar;

    2. 打成的jar包在项目的target目录下,将jar包上传至Linux服务器的eureka目录下;

    3. 将jar包所在的目录创建一个Dockerfile文件 vim Dockerfile,内容为

    # 基于哪个镜像
    
    FROM java:8
    
    # 将文件挂载到当前容器
    
    VOLUME /tmp
    
    # 复制文件到容器根目录"/",并且命名为app.jar
    
    ADD eureka-0.0.1-SNAPSHOT.jar /app.jar
    # 声明需要暴露的端口
    
    EXPOSE 8200
    
    # 配置容器启动后执行的命令,java -jar /app.jar
    
    ENTRYPOINT ["java","-jar","/app.jar"]

    4. 在Dockerfile文件所在目录,使用docker build 命令构建镜像

    docker build -t eureka-server:0.0.1 .

    检查是否image构建成功: docker images

    5. 新建容器并且运行

    docker run -d -p 8200:8200 eureka-server:0.0.1 

    6. 最后访问宿主机的8200端口

    该微服务部署成功!

     7.docker-compose

     https://www.cnblogs.com/theRhyme/p/10607872.html

    来源:

    www.imooc.com

    图灵学院

  • 相关阅读:
    SpingBoot myBatis neo4j整合项目案例
    GCC 优化选项 -O1 -O2 -O3 -OS 优先级,-FOMIT-FRAME-POINTER(O3的优化很小,只增加了几条优化而已)
    睡个好觉的 12 条军规(坚持固定睡眠时间表,这一条最重要)
    恐怕你确定自己喜欢做什么(如果一件事能让你沉浸其中、安住当下,过后又不令你后悔,那它就是你喜欢的事:时间就应该拿来赚钱或提升赚钱的能力)
    专家解读:缺芯少人的中国集成电路,亟待打破高校学科壁垒
    你们一定要搞清楚被迫加班和自己弄的差别(被动的人得关节炎,主动的人身体更棒了)
    Linux命令排查线上问题常用的几个
    NFS (网络文件系统)
    查看JVM运行时堆内存
    SQL查询速度
  • 原文地址:https://www.cnblogs.com/theRhyme/p/9813019.html
Copyright © 2011-2022 走看看