1-1、部署MySQL
docker search mysql
docker pull mysql:5.6
# 在/root目录下创建mysql目录用于存储mysql数据信息
mkdir ~/mysql
cd ~/mysql
docker run -id \
-p 3307:3306 \
--name=c_mysql \
-v $PWD/conf:/etc/mysql/conf.d \
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.7
docker exec –it c_mysql /bin/bash
1-2、部署Tomcat
docker search tomcat
docker pull tomcat
# 在/root目录下创建tomcat目录用于存储tomcat数据信息
mkdir ~/tomcat
cd ~/tomcat
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat
1-3、部署Nginx
docker search nginx
docker pull nginx
# 在/root目录下创建nginx目录用于存储nginx数据信息
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf
# 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
vim nginx.conf
user nginx;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
docker run -id --name=c_nginx \
-p 80:80 \
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \
-v $PWD/logs:/var/log/nginx \
-v $PWD/html:/usr/share/nginx/html \
nginx
1-4、部署Redis
docker search redis
docker pull redis:5.0
docker run -id --name=c_redis -p 6379:6379 redis:5.0
./redis-cli.exe -h 192.168.149.135 -p 6379
2-1 Docker镜像原理
下面为原理讲解:
2-2 Docker镜像如何制作
2-3 DockerFile概念以及作用
2-4 Docker关键字
FROM:指定父镜像–指定dockerfiel基于哪个image构建 MAINTAINER:作者信息–用来标明这个dockerfile谁写的 LABLE:标签 RUN: 执行linux命令 --默认是 /bin/sh,RUN command或者 Run [“command”,“param1”,“param2”] EXPOSE:暴露端口 CMD:容器启动命令 COPY:复制文件–build的时候复制文件到image中 ADD:添加文件–可以来源于远程服务 ENV:环境变量 VOLUMN:定义外部可以挂载的数据卷–启动容器的时候用-v绑定 volume目录 WORKDIR:工作目录–指定容器内部的工作目录,没有就创建
2-5 案例
案例一:定义DockerFile,发布spring-boot项目
通过dockerfile构建镜像: docker build -f dockerfile文件路径 -t 镜像名称:版本
案例二:自定义centos镜像,默认登录路径为 /usr,可以使用vim
操作:
此时,查看镜像列表:docker images
然后,进入查看目录与vim命令是否生效:docker run -it --name=c4 mycentos
3-1 Docker服务编排
服务编排:按照一定的业务规则批量管理容器 Docker Compose:Docker Compose是一个编排多容器分布式部署的工具 ,提供命令集管理容器化应用的完整开发周期,包括服务构建、启动和停止。 使用步骤:
3-2 Docker Compose安装 & 使用
uname -s
-uname -m
-o /usr/local/bin/docker-composeversion: '3'
services:
nginx:
image: nginx
ports:
- 80:80
links:
- app
volumes:
- ./nginx/conf.d:/etc/nginx/conf.d
app:
image: app
expose:
- "8080"
server {
listen 80;
access_log off;
location / {
proxy_pass http://app:8080;
}
}
1 搭建私有仓库
1、拉取私有仓库镜像
2、启动私有仓库容器
3、打开浏览器 输入地址http://私有仓库服务器ip:5000/v2/_catalog,
看到{“repositories”:[]} 表示私有仓库 搭建成功 4、修改daemon.json
5、重启docker 服务
4-2 上传镜像到私有仓库
1、标记镜像为私有仓库的镜像 docker tag centos:7 私有仓库服务器IP:5000/centos:7 2、上传标记的镜像 docker push 私有仓库服务器IP:5000/centos:7
4-3 从私有仓库拉取镜像
docker pull 私有仓库服务器ip:5000/centos:7
docker容器与传统虚拟机比较