Docker容器的三种创建运行方式,一个比一个好用

开发 前端
现在的项目部署运维中,使用Docker容器越来越多,Docker给我们提供创建容器的方式也有好几种,主要是docker run命令、Dockerfile文件、docker-compose三种方式,一个比一个方便。

 现在的项目部署运维中,使用Docker容器越来越多,Docker给我们提供创建容器的方式也有好几种,主要是docker run命令、Dockerfile文件、docker-compose三种方式,一个比一个方便。

[[353237]]

我们来看下有几种方式的具体用法吧。本文需要先安装docker和docker-compose,不懂安装的可以看我的另外两篇文章centos7安装docker docker-compose安装 ,非常方便就可以安装好,

以创建一个Nginx容器为例。

方式一:docker run命令方式

 

  1. docker run --name some-nginx -p 1080:80 -v /some/content:/usr/share/nginx/html -d nginx 

参数说明:

--name:定义容器名。

-p:宿主机与容器的端口挂载,格式:宿主机端口:容器内部端口

-v:宿主机目录与容器内目录映射,格式:宿主机目录:容器内部目录

-d:后台执行

执行以上命令就可以啦,这里把容器名取名为some-nginx,把容器的80端口映射到宿主机的1080端口,容器内的/usr/share/nginx/html目录映射到宿主机的/some/content目录,使用的是nginx最新的镜像,镜像部分也可以写成 “nginx:版本”比如“nginx:1.15.1”。

在/some/content创建一个index.html,随便输入个内容。

访问下 ip+1080可以看到请求到nginx了。

 

Docker容器的三种创建运行方式,一个比一个好用

 

访问nginx测试

docker run方式在运行简单的容器方面还是比较方便的。

方式二:Dockerfile配置文件构建镜像方式

1.创建一个文件,命名为Dockerfile,输入以下内容。

 

  1. FROM nginx 
  2. COPY html /usr/share/nginx/html 

 

FROM nginx 代表以nginx镜像为基础构建我们的镜像。

注意需要先在Dockerfile同目录创建html目录,不然会报错。

Dockerfile文件内可以自定义镜像内容,有很多指令可以用,比如可以在配置容器创建后运行shell脚本等,可以自行查阅,本文仅做一个简单的用法示例入门。

注意:Dockerfile 的指令每执行一次都会在 docker 上新建一层,所以尽量不要写太多层。

2.在Dockerfile同目录下运行命令创建镜像

 

  1. docker build -t my-nginx-image . 

注意最后面有一个点。

3.运行容器

 

  1. docker run --name some-nginx -p 1080:80 -d my-nginx-image 

在html目录里新建一个index.html文件随便输入个内容,访问下 ip+1080可以看到请求到nginx了。

 

Docker容器的三种创建运行方式,一个比一个好用

 

访问nginx测试

Dockerfile一般用于自定义镜像,因为是个文件,也比命令的方式更易于保存与团队间共享。

方式三:docker -compose方式

在需要管理多个容器时用以上两种方式都不太适合,不仅要管理每个容器的配置信息,还要处理容器间的关系,这时候就需要docker-compose来做容器编排了。

1.创建一个docker-compose.yml文件,输入以下内容

  1. version: "3" 
  2. services: 
  3.   nginx: 
  4.     image: nginx 
  5.     container_name: some-nginx 
  6.     ports: 
  7.       - "1080:80" 
  8.     volumes: 
  9.       - /some/content:/usr/share/nginx/html 

在/some/content创建一个index.html,随便输入个内容,等会访问测试。

2.执行启动命令

 

  1. docker-compose up -d 

访问下 ip+1080可以看到请求到nginx了。

 

Docker容器的三种创建运行方式,一个比一个好用

 

访问测试

docker-compose.yml文件里可以写多个容器配置信息,有提供各种配置项用于容器编排。

比如我有一个springboot项目,需要打包成jar包然后创建容器运行,需要连接一个数据库容器,最后需要一个nginx容器做请求代理。那么docker-compose.yml文件可以这样写。

 

  1. version: "3" 
  2. services: 
  3.   mysql: 
  4.     image: mysql:5.7.26 
  5.     ports: 
  6.       - "13306:3306"   
  7.     restart: "always" 
  8.     container_name: mysql 
  9.     command: 
  10.       --default-authentication-plugin=mysql_native_password --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --max_connections=1000 --default-storage-engine=INNODB --lower_case_table_names=1 --default-time_zone='+8:00' 
  11.       --sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION" 
  12.     privileged: true     
  13.     environment: 
  14.       - MYSQL_ROOT_PASSWORD=123456 
  15.       - TZ="Asia/Shanghai" 
  16.     volumes:   
  17.       - /opt/docker/mysql/conf:/etc/mysql/mysql.conf.d 
  18.       - /etc/localtime:/etc/localtime 
  19.       - /opt/docker/mysql/logs:/var/log/mysql 
  20.       - /opt/docker/mysql/data:/var/lib/mysql 
  21.   my-server: 
  22.     image: java:8 
  23.     restart: "always" 
  24.     container_name: my-server 
  25.     environment: 
  26.       - TZ="Asia/Shanghai" 
  27.     volumes:   
  28.       - /opt/my-serve/my-serve-0.0.1-SNAPSHOT.jar:/data/my-serve-0.0.1-SNAPSHOT.jar 
  29.       - /etc/localtime:/etc/localtime 
  30.       - /opt/var/logs:/var/logs 
  31.     entrypoint: java -jar /data/my-serve-0.0.1-SNAPSHOT.jar --server.port=18081 
  32.   nginx: 
  33.     image: nginx 
  34.     container_name: nginx 
  35.     volumes: 
  36.       - /opt/my-serve:/home/nginx 
  37.       - /opt/docker/nginx/conf.d/:/etc/nginx/conf.d/ 
  38.       - /opt/docker/nginx/log/:/var/log/nginx/ 
  39.       - /opt/docker/nginx/html/:/usr/share/nginx/html/ 
  40.     restart: "always" 
  41.     network_mode: "host" 

 

只要执行 docker-compose up -d 命令就可以把配置文件内的所有容器启动起来,是不是很方便呢。

在实际项目中,一般Dockerfile和docker-compose用得比较多,不过现在Kubernetes越来越火,以后可能Kubernetes也会占领市场也不一定。

好了本次内容就到这了。希望对你有所帮助。

责任编辑:华轩 来源: 今日头条
相关推荐

2019-08-26 19:03:58

2023-01-12 08:47:26

二项式杨辉斐波那契

2021-06-23 16:40:58

JavaTomcatWeb

2018-12-17 09:10:52

机器学习TensorFlow容器

2024-08-20 21:27:04

docker部署容器

2010-02-26 09:36:51

RIA

2017-08-23 08:09:11

UDPDocker容器

2022-07-21 09:50:20

Python日期库pendulum

2014-05-26 09:13:46

DockerPython

2021-09-02 05:37:22

Containerd Kubernetes 容器

2019-12-09 15:00:48

TomcatServlet容器

2020-11-09 06:38:00

ninja构建方式构建系统

2009-08-19 04:14:00

线性链表

2024-02-26 18:11:08

Docker容器镜像

2016-03-08 09:52:22

xcode插件开发

2013-01-14 15:41:27

Android模拟器教程配置

2021-12-30 09:40:33

CentOS家庭实验室Linux

2016-09-26 17:26:20

2024-07-19 10:31:15

2010-11-11 09:13:58

超高密度服务器HP戴尔
点赞
收藏

51CTO技术栈公众号