小白也能用Docker部署微服务

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 零基础用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,内容为

  1. # 基于哪个镜像
  2.  
  3. FROM java:8
  4.  
  5. # 将文件挂载到当前容器
  6.  
  7. VOLUME /tmp
  8.  
  9. # 复制文件到容器根目录"/",并且命名为app.jar
  10.  
  11. ADD eureka-0.0.1-SNAPSHOT.jar /app.jar
  12. # 声明需要暴露的端口
  13.  
  14. EXPOSE 8200
  15.  
  16. # 配置容器启动后执行的命令,java -jar /app.jar
  17.  
  18. 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端口

该微服务部署成功!

相关文章
|
4天前
|
Kubernetes Java Docker
使用Kubernetes和Docker部署Java微服务
使用Kubernetes和Docker部署Java微服务
|
3天前
|
消息中间件 监控 RocketMQ
Docker Compose 一键快速部署 RocketMQ
Docker Compose 一键快速部署 RocketMQ
14 0
|
3天前
|
运维 Serverless 文件存储
函数计算产品使用问题之在利用Docker镜像部署应用时,容器内的应用如何能访问函数计算配置的NAS挂载
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
3天前
|
存储 Serverless 对象存储
函数计算产品使用问题之项目打包为docker镜像,该如何部署上去
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
3天前
|
关系型数据库 MySQL Nacos
使用 Docker 部署 Nacos 并配置 MySQL 数据源
使用 Docker 部署 Nacos 并配置 MySQL 数据源
15 0
|
4天前
|
关系型数据库 应用服务中间件 nginx
Docker + node(koa) + nginx + mysql 线上环境部署
Docker + node(koa) + nginx + mysql 线上环境部署
|
5天前
|
应用服务中间件 nginx Docker
详细解读docker部署项目
详细解读docker部署项目
13 0
|
5天前
|
前端开发 Java Docker
Docker 部署项目,真的太雅了~
Docker 部署项目,真的太雅了~
15 0
|
运维 Kubernetes 前端开发
【云原生】阿里云服务器部署 Docker Swarm集群
阿里云服务器 一键部署 Docker Swarm 集群!
585 0
【云原生】阿里云服务器部署 Docker Swarm集群
|
弹性计算 Linux Shell
阿里云一键部署 Docker Datacenter
使用阿里云ROS一键部署Docker Datacenter
12245 1

热门文章

最新文章